1
0
Fork 0
peertube/support/doc/production.md

381 lines
10 KiB
Markdown
Raw Normal View History

2018-01-12 17:07:41 +00:00
# Production guide
2018-01-29 10:23:38 +00:00
* [Installation](#installation)
* [Upgrade](#upgrade)
2018-01-29 10:23:38 +00:00
2018-01-12 17:07:41 +00:00
## Installation
2018-07-24 14:22:21 +00:00
Please don't install PeerTube for production on a device behind a low bandwidth connection (example: your ADSL link).
If you want information about the appropriate hardware to run PeerTube, please see the [FAQ](https://github.com/Chocobozzz/PeerTube/blob/develop/FAQ.md#should-i-have-a-big-server-to-run-peertube).
2018-02-09 12:38:19 +00:00
2018-01-12 17:07:41 +00:00
### Dependencies
**Follow the steps of the [dependencies guide](dependencies.md).**
2018-01-12 17:07:41 +00:00
### PeerTube user
Create a `peertube` user with `/var/www/peertube` home:
2018-01-12 17:07:41 +00:00
2018-01-12 17:55:45 +00:00
```
$ sudo useradd -m -d /var/www/peertube -s /bin/bash -p peertube peertube
```
Set its password:
```
$ sudo passwd peertube
2018-01-12 17:07:41 +00:00
```
**On FreeBSD**
```
$ sudo pw useradd -n peertube -d /var/www/peertube -s /usr/local/bin/bash -m
$ sudo passwd peertube
```
or use `adduser` to create it interactively.
2018-01-12 17:07:41 +00:00
### Database
Create the production database and a peertube user inside PostgreSQL:
2018-01-12 17:07:41 +00:00
2018-01-12 17:55:45 +00:00
```
$ sudo -u postgres createuser -P peertube
```
Here you should enter a password for postgresql user peertube, it should be copied in production.yaml file.
Dont just hit enter else it will be empty, default production yaml uses peertube here, but it is better you pick a stronger one.
```
2020-01-29 10:48:19 +00:00
$ sudo -u postgres createdb -O peertube -E UTF8 -T template0 peertube_prod
2018-01-12 17:07:41 +00:00
```
2018-07-19 14:17:54 +00:00
Then enable extensions PeerTube needs:
```
$ sudo -u postgres psql -c "CREATE EXTENSION pg_trgm;" peertube_prod
$ sudo -u postgres psql -c "CREATE EXTENSION unaccent;" peertube_prod
```
### Prepare PeerTube directory
2018-01-12 17:07:41 +00:00
Fetch the latest tagged version of Peertube
```
$ VERSION=$(curl -s https://api.github.com/repos/chocobozzz/peertube/releases/latest | grep tag_name | cut -d '"' -f 4) && echo "Latest Peertube version is $VERSION"
```
Open the peertube directory, create a few required directories
```
2021-01-11 09:09:24 +00:00
$ cd /var/www/peertube
$ sudo -u peertube mkdir config storage versions
```
Download the latest version of the Peertube client, unzip it and remove the zip
2018-01-12 17:55:45 +00:00
```
2021-01-11 09:09:24 +00:00
$ cd /var/www/peertube/versions
$ sudo -u peertube wget -q "https://github.com/Chocobozzz/PeerTube/releases/download/${VERSION}/peertube-${VERSION}.zip"
2021-03-03 11:23:23 +00:00
$ sudo -u peertube unzip -q peertube-${VERSION}.zip && sudo -u peertube rm peertube-${VERSION}.zip
```
2018-05-27 01:25:10 +00:00
Install Peertube:
```
2021-01-11 09:09:24 +00:00
$ cd /var/www/peertube
$ sudo -u peertube ln -s versions/peertube-${VERSION} ./peertube-latest
$ cd ./peertube-latest && sudo -H -u peertube yarn install --production --pure-lockfile
2018-01-12 17:07:41 +00:00
```
### PeerTube configuration
2021-01-04 09:29:08 +00:00
Copy the default configuration file that contains the default configuration provided by PeerTube.
You **must not** update this file.
```
2021-01-11 09:09:24 +00:00
$ cd /var/www/peertube
$ sudo -u peertube cp peertube-latest/config/default.yaml config/default.yaml
2021-01-04 09:29:08 +00:00
```
Now copy the production example configuration:
2018-01-12 17:07:41 +00:00
2018-01-12 17:55:45 +00:00
```
2021-01-11 09:09:24 +00:00
$ cd /var/www/peertube
$ sudo -u peertube cp peertube-latest/config/production.yaml.example config/production.yaml
2018-01-12 17:07:41 +00:00
```
Then edit the `config/production.yaml` file according to your webserver
2021-01-11 09:09:24 +00:00
and database configuration (`webserver`, `database`, `redis`, `smtp` and `admin.email` sections in particular).
Keys defined in `config/production.yaml` will override keys defined in `config/default.yaml`.
2018-01-12 17:07:41 +00:00
2021-01-05 10:01:12 +00:00
**PeerTube does not support webserver host change**. Even though [PeerTube CLI can help you to switch hostname](https://docs.joinpeertube.org/maintain-tools?id=update-hostjs) there's no official support for that since it is a risky operation that might result in unforeseen errors.
2018-01-12 17:07:41 +00:00
### Webserver
We only provide official configuration files for Nginx.
2018-01-12 17:07:41 +00:00
Copy the nginx configuration template:
2018-01-12 17:55:45 +00:00
```
$ sudo cp /var/www/peertube/peertube-latest/support/nginx/peertube /etc/nginx/sites-available/peertube
2018-01-12 17:07:41 +00:00
```
2020-08-14 12:59:15 +00:00
Then set the domain for the webserver configuration file.
Replace `[peertube-domain]` with the domain for the peertube server.
```
$ sudo sed -i 's/${WEBSERVER_HOST}/[peertube-domain]/g' /etc/nginx/sites-available/peertube
$ sudo sed -i 's/${PEERTUBE_HOST}/127.0.0.1:9000/g' /etc/nginx/sites-available/peertube
```
2018-01-18 16:44:13 +00:00
Then modify the webserver configuration file. Please pay attention to the `alias` keys of the static locations.
It should correspond to the paths of your storage directories (set in the configuration file inside the `storage` key).
2018-01-12 17:07:41 +00:00
2018-01-12 17:55:45 +00:00
```
2018-01-12 17:07:41 +00:00
$ sudo vim /etc/nginx/sites-available/peertube
```
2018-02-16 10:04:12 +00:00
Activate the configuration file:
```
$ sudo ln -s /etc/nginx/sites-available/peertube /etc/nginx/sites-enabled/peertube
```
To generate the certificate for your domain as required to make https work you can use [Let's Encrypt](https://letsencrypt.org/):
```
$ sudo systemctl stop nginx
2021-02-04 15:50:35 +00:00
$ sudo certbot certonly --standalone --post-hook "systemctl restart nginx"
2018-03-01 15:12:00 +00:00
$ sudo systemctl reload nginx
```
2018-02-16 10:04:12 +00:00
Now you have the certificates you can reload nginx:
2018-01-12 17:07:41 +00:00
2018-01-12 17:55:45 +00:00
```
2018-01-12 17:07:41 +00:00
$ sudo systemctl reload nginx
```
2021-01-11 09:09:24 +00:00
Certbot should have installed a cron to automatically renew your certificate.
Since our nginx template supports webroot renewal, we suggest you to update the renewal config file to use the `webroot` authenticator:
```
$ # Replace authenticator = standalone by authenticator = webroot
2021-02-04 15:45:00 +00:00
$ # Add webroot_path = /var/www/certbot
2021-01-11 09:09:24 +00:00
$ sudo vim /etc/letsencrypt/renewal/your-domain.com.conf
```
**FreeBSD**
On FreeBSD you can use [Dehydrated](https://dehydrated.io/) `security/dehydrated` for [Let's Encrypt](https://letsencrypt.org/)
```
$ sudo pkg install dehydrated
```
### TCP/IP Tuning
**On Linux**
```
$ sudo cp /var/www/peertube/peertube-latest/support/sysctl.d/30-peertube-tcp.conf /etc/sysctl.d/
$ sudo sysctl -p /etc/sysctl.d/30-peertube-tcp.conf
```
Your distro may enable this by default, but at least Debian 9 does not, and the default FIFO
scheduler is quite prone to "Buffer Bloat" and extreme latency when dealing with slower client
links as we often encounter in a video server.
2018-03-20 07:28:20 +00:00
### systemd
2018-01-12 17:07:41 +00:00
2018-03-20 07:28:20 +00:00
If your OS uses systemd, copy the configuration template:
2018-01-12 17:07:41 +00:00
2018-01-12 17:55:45 +00:00
```
$ sudo cp /var/www/peertube/peertube-latest/support/systemd/peertube.service /etc/systemd/system/
2018-01-12 17:07:41 +00:00
```
2020-08-26 06:31:20 +00:00
Check the service file (PeerTube paths and security directives):
2018-01-12 17:07:41 +00:00
2018-01-12 17:55:45 +00:00
```
$ sudo vim /etc/systemd/system/peertube.service
2018-01-12 17:07:41 +00:00
```
Tell systemd to reload its config:
2018-01-12 17:55:45 +00:00
```
$ sudo systemctl daemon-reload
2018-01-12 17:07:41 +00:00
```
2018-01-15 10:10:46 +00:00
If you want to start PeerTube on boot:
```
2018-01-17 10:47:45 +00:00
$ sudo systemctl enable peertube
2018-01-15 10:10:46 +00:00
```
2018-03-20 07:28:20 +00:00
Run:
2018-01-12 17:07:41 +00:00
2018-01-12 17:55:45 +00:00
```
$ sudo systemctl start peertube
$ sudo journalctl -feu peertube
2018-01-12 17:07:41 +00:00
```
2018-08-21 08:48:57 +00:00
**FreeBSD**
On FreeBSD, copy the startup script and update rc.conf:
2018-03-19 21:48:15 +00:00
```
$ sudo install -m 0555 /var/www/peertube/peertube-latest/support/freebsd/peertube /usr/local/etc/rc.d/
$ sudo sysrc peertube_enable="YES"
2018-03-19 21:48:15 +00:00
```
2018-03-20 07:28:20 +00:00
Run:
2018-03-19 21:48:15 +00:00
```
$ sudo service peertube start
```
### OpenRC
If your OS uses OpenRC, copy the service script:
```
$ sudo cp /var/www/peertube/peertube-latest/support/init.d/peertube /etc/init.d/
```
If you want to start PeerTube on boot:
```
$ sudo rc-update add peertube default
```
Run and print last logs:
```
$ sudo /etc/init.d/peertube start
$ tail -f /var/log/peertube/peertube.log
```
2018-01-12 17:07:41 +00:00
### Administrator
2021-01-11 09:09:24 +00:00
The administrator password is automatically generated and can be found in the PeerTube
logs (path defined in `production.yaml`). You can also set another password with:
2018-01-12 17:07:41 +00:00
2018-01-12 17:55:45 +00:00
```
$ cd /var/www/peertube/peertube-latest && NODE_CONFIG_DIR=/var/www/peertube/config NODE_ENV=production npm run reset-password -- -u root
2018-01-12 17:07:41 +00:00
```
Alternatively you can set the environment variable `PT_INITIAL_ROOT_PASSWORD`,
to your own administrator password, although it must be 6 characters or more.
### What now?
Now your instance is up you can:
2020-08-14 12:59:15 +00:00
* Add your instance to the public PeerTube instances index if you want to: https://instances.joinpeertube.org/
* Check [available CLI tools](/support/doc/tools.md)
2018-03-15 13:31:08 +00:00
2018-01-12 17:07:41 +00:00
## Upgrade
2018-07-19 14:17:54 +00:00
### PeerTube instance
**Check the changelog (in particular BREAKING CHANGES!):** https://github.com/Chocobozzz/PeerTube/blob/develop/CHANGELOG.md
#### Auto
2018-03-29 12:27:55 +00:00
The password it asks is PeerTube's database user password.
```
$ cd /var/www/peertube/peertube-latest/scripts && sudo -H -u peertube ./upgrade.sh
```
2018-02-14 10:09:02 +00:00
#### Manually
2018-01-26 09:50:05 +00:00
Make a SQL backup
```
$ SQL_BACKUP_PATH="backup/sql-peertube_prod-$(date -Im).bak" && \
cd /var/www/peertube && sudo -u peertube mkdir -p backup && \
sudo -u postgres pg_dump -F c peertube_prod | sudo -u peertube tee "$SQL_BACKUP_PATH" >/dev/null
```
2018-01-26 09:50:05 +00:00
Fetch the latest tagged version of Peertube:
2018-01-19 12:58:13 +00:00
```
2018-01-26 09:50:05 +00:00
$ VERSION=$(curl -s https://api.github.com/repos/chocobozzz/peertube/releases/latest | grep tag_name | cut -d '"' -f 4) && echo "Latest Peertube version is $VERSION"
2018-01-19 12:58:13 +00:00
```
2018-01-26 09:50:05 +00:00
Download the new version and unzip it:
2018-01-12 17:55:45 +00:00
```
2018-01-26 09:50:05 +00:00
$ cd /var/www/peertube/versions && \
sudo -u peertube wget -q "https://github.com/Chocobozzz/PeerTube/releases/download/${VERSION}/peertube-${VERSION}.zip" && \
2018-01-26 09:50:05 +00:00
sudo -u peertube unzip -o peertube-${VERSION}.zip && \
sudo -u peertube rm peertube-${VERSION}.zip
```
2018-01-29 10:58:07 +00:00
Install node dependencies:
2018-01-26 09:50:05 +00:00
```
2018-01-29 10:58:07 +00:00
$ cd /var/www/peertube/versions/peertube-${VERSION} && \
sudo -H -u peertube yarn install --production --pure-lockfile
2018-01-26 09:50:05 +00:00
```
2018-01-29 10:58:07 +00:00
Copy new configuration defaults values and update your configuration file:
2018-01-26 09:50:05 +00:00
2018-01-12 17:07:41 +00:00
```
2018-01-29 10:58:07 +00:00
$ sudo -u peertube cp /var/www/peertube/versions/peertube-${VERSION}/config/default.yaml /var/www/peertube/config/default.yaml
2018-02-14 10:09:02 +00:00
$ diff /var/www/peertube/versions/peertube-${VERSION}/config/production.yaml.example /var/www/peertube/config/production.yaml
2018-01-26 09:50:05 +00:00
```
2018-01-29 10:58:07 +00:00
Change the link to point to the latest version:
2018-01-26 09:50:05 +00:00
```
2018-01-29 10:58:07 +00:00
$ cd /var/www/peertube && \
sudo unlink ./peertube-latest && \
2018-01-29 10:58:07 +00:00
sudo -u peertube ln -s versions/peertube-${VERSION} ./peertube-latest
2018-01-26 09:50:05 +00:00
```
### nginx
Check changes in nginx configuration:
```
$ cd /var/www/peertube/versions
$ diff "$(ls --sort=t | head -2 | tail -1)/support/nginx/peertube" "$(ls --sort=t | head -1)/support/nginx/peertube"
```
### systemd
Check changes in systemd configuration:
```
$ cd /var/www/peertube/versions
$ diff "$(ls --sort=t | head -2 | tail -1)/support/systemd/peertube.service" "$(ls --sort=t | head -1)/support/systemd/peertube.service"
```
### Restart PeerTube
If you changed your nginx configuration:
```
$ sudo systemctl reload nginx
```
If you changed your systemd configuration:
2018-01-29 10:58:07 +00:00
2018-01-26 09:50:05 +00:00
```
$ sudo systemctl daemon-reload
```
Restart PeerTube and check the logs:
```
$ sudo systemctl restart peertube && sudo journalctl -fu peertube
2018-01-26 09:50:05 +00:00
```
### Things went wrong?
2018-01-26 09:50:05 +00:00
Change `peertube-latest` destination to the previous version and restore your SQL backup:
```
$ OLD_VERSION="v0.42.42" && SQL_BACKUP_PATH="backup/sql-peertube_prod-2018-01-19T10:18+01:00.bak" && \
cd /var/www/peertube && sudo -u peertube unlink ./peertube-latest && \
sudo -u peertube ln -s "versions/peertube-$OLD_VERSION" peertube-latest && \
sudo -u postgres pg_restore -c -C -d postgres "$SQL_BACKUP_PATH" && \
sudo systemctl restart peertube
```