Operations grimoire/Mastodon: Difference between revisions
From Nasqueron Agora
(Created page with "== Logs == ;Web :<code>docker logs --tail=100 --follow mastodon_web_1 | grep -v status=20 | grep -v Render | grep -v X-Accel-Mapping</code> ;Other containers :<code>docker log...") |
(Lost 2FA procedure) |
||
Line 34: | Line 34: | ||
$ docker-compose up -d | $ docker-compose up -d | ||
$ docker-compose run --rm web rails db:migrate | $ docker-compose run --rm web rails db:migrate | ||
</source> | |||
== Maintenance scripts == | |||
=== Lost 2FA === | |||
There is currently no interface or Rake task or helper script to reset 2FA. | |||
You can so use the database: | |||
<source lang="console"> | |||
$ cd /opt/mastodon | |||
$ docker-compose run --rm db psql --host=db -U postgres | |||
UPDATE users SET otp_required_for_login=false WHERE email='user@domain.tld'; | |||
</source> | </source> |
Latest revision as of 18:44, 11 November 2018
Logs
- Web
docker logs --tail=100 --follow mastodon_web_1 | grep -v status=20 | grep -v Render | grep -v X-Accel-Mapping
- Other containers
docker logs --tail=100 --follow mastodon_db_1
docker logs --tail=100 --follow mastodon_sidekiq_1
docker logs --tail=100 --follow mastodon_streaming_1
docker logs --tail=100 --follow mastodon_redis_1
Upgrade procedure
Backup
- PostgreSQL
docker exec mastodon_db_1 pg_dump -Fc -U postgres postgres > mastodon-db-`date +%Y-%m-%d`.dump
- Redis
- Copy the rdb with
cp /srv/data/mastodon/redis/dump.rdb dump.rdb.`date +%Y-%m-%d`
Build image
$ cd /opt/mastodon
$ git fetch
$ git rebase origin/master # or a version tag
$ docker-compose build
Deploy new containers
$ docker-compose run --rm web rails db:migrate
$ docker-compose up -d
Sometimes, the database migration is time consuming. In such case:
$ docker-compose run --rm -e SKIP_POST_DEPLOYMENT_MIGRATIONS=true web rails db:migrate
$ docker-compose up -d
$ docker-compose run --rm web rails db:migrate
Maintenance scripts
Lost 2FA
There is currently no interface or Rake task or helper script to reset 2FA.
You can so use the database:
$ cd /opt/mastodon
$ docker-compose run --rm db psql --host=db -U postgres
UPDATE users SET otp_required_for_login=false WHERE email='user@domain.tld';