Skip to content

Installation

KMY(雪あすか) edited this page Jan 13, 2024 · 110 revisions

一般的な注意事項

kmyblueは頻繁にバージョンアップを行います。

  • 安定したバージョンを使いたい場合は、LTSの利用を強くお勧めします。 LTSはMastodon本家の安定版リリースのみをベースとしています。kmyblue独自機能追加はほとんど行わず、バグ修正や重要な仕様変更のみを取り込みます。以下のインストール手順でも、LTSのインストール方法が記載されています
  • LTS以外のバージョンは、リリースとしての体裁は整えていますが開発版です。kmyblueの最新機能を使いたい人向けに提供しています
    • 本家Mastodonの開発中のバージョンを平然と取り込みます。バグや未翻訳の部分が含まれていることがあります
    • セキュリティパッチを適用しようとするとメジャーアップデートしなければいけない場面が多くあります
    • バグ修正などのサポート期間は次のメジャーアップデートが出るまでです(間隔1週間~1ヶ月くらい)
      • LTSの場合、サポート期間は次のLTSが出るまで=本家で次のバージョンが出るまでです(移行期間というのを検討中です)
    • 特に最新コミットでは、デバッグ用コードや、kmy.blue本番サーバーで動作確認を行うためのコードが含まれている場合があります。ブランチの最新コミットではなく最新タグを取り込むことを強くおすすめします

本家Mastodonからkmyblueに変更する

本家Mastodonに戻すところまではサポートしていません。自己責任でお願いします。 また、実運用環境の作業で問題が起きてデータ消失など発生しても自己責任となっておりますので、必ずバックアップはとってください。

  1. kmyblueのリリースノートに、kmyblueバージョンに対応した本家Mastodonのバージョンが記載されています。あなたのMastodonがそれよりも新しい場合、そのままではマイグレーションが行えませんので、kmyblueの新しいリリースが出るまで待ってください。またはLTSの使用を諦めるなど各種検討をお勧めします
  2. Gitのリモートにkmyblueを追加して、そのままフェッチ・チェックアウトしてください
  3. データベースのマイグレーションなどを行ってください
sudo systemctl stop mastodon-*

# ここでgitのリモートにkmyblue追加して、フェッチ・チェックアウトする

bundle install
yarn install
RAILS_ENV=production bin/rails db:migrate
RAILS_ENV=production bin/rails assets:clobber
RAILS_ENV=production bin/rails assets:precompile

# ElasticSearchを使用する場合
# --full true つければ他サーバーの投稿の大部分も取り込まれますが時間が非常にかかります
# サーバー再起動の後の実施でも可ですが、検索時にエラーが発生する可能性あるため
# 一時的に ES_ENABLED=false にすることをおすすめします
RAILS_ENV=production bin/tootctl search deploy

RAILS_ENV=production bin/tootctl cache clear
sudo systemctl start mastodon-web mastodon-streaming mastodon-sidekiq

必須ソフトウェアのバージョン

Ruby、ElasticSearch、ImageMagick、PostgreSQLなど必須ソフトウェアのバージョンは、本家Mastodonに準じます。リリースノートに対応する本家Mastodonバージョンが記載されていますので、本家Mastodonのリリースノートから対応するバージョンを探して調べてください。

初期環境からセットアップする

自力でセットアップ

kmyblueのセットアップ方法は、本家Mastodonとほとんど同じです。違うのはクローンするリポジトリが異なる点、チェックアウトするタグの命名規則が異なる点だけです。(※kmyblueの設定に問題がある時は、気付き次第改善します。アセットのプリコンパイルでエラーが出た時はご連絡ください)

チェックアウトするタグの名前は、ReleasesTagsをご確認ください。kb_developmentブランチ(デフォルトブランチ)そのままだと、ほとんどの場合は開発中のバージョンになってしまいます。

Mastodon公式ドキュメントに、セットアップ手順が丁寧に書かれています。現在このドキュメントはUbuntu 20.04 LTSを前提としていますが、22.04でもかなり参考になるはずです。
この通りにすれば絶対うまくいくというわけではありませんが(多くの場合、kmyblue特有の問題ではなく本家Mastodonでも同じ問題が発生します)、必ず助けになります。

自動セットアップスクリプト

Ubuntu 22.04 LTSの利用を前提としています。また動作確認は主にArmで行っておりますが、x86でも一応確認しています。あらかじめドメインの取得/メールサーバー(SMTPサーバー)の契約を済ませてください。

【注意】ないと思いますがこのkmyblueをさらにフォークしたMastodonを使いたい場合、ならびにその他のフォーク・本家Mastodonをインストールしたい場合、特に案内がない限り以下の手順は使わないでください。kmyblueがインストールされてしまいます

kmyblueでは上記本家Mastodonのドキュメントに掲載されているコマンドを独自に改良(例:Node.js 16→20、Ruby 3.0.6→3.2.2など)したものをスクリプトにまとめています。以下にセットアップ方法を案内します。
これはDockerではなく、サーバーに直接ソフトウェアをインストールするものです。OSは初期状態であることを前提とします。そうでない場合は、できるだけ前項の手動インストールをおすすめします。

注意:自動セットアップスクリプトは以下をサポートしません。kmyblueを簡単にインストールできるようにしたものですが、あくまでLinuxの操作経験がある方に向けて作ったものであり、細かいチューイングやトラブル対応は各自でやらなければいけません。
端的に言うと、Linuxの操作経験・知識、もし無くても根気が前提です。

  • サーバーのファイアウォール設定
    • 80、443ポートを開ける必要があります
    • Amazon EC2の場合はサーバーの外側で設定する必要があり、デフォルトではいずれも閉じています
    • その他のサービスでは、ファイアウォールの設定が端末の外(コントロールパネルなど)にないか、設定方法など事前に確認してください
  • DNS(サーバーとドメインを繋げる)設定
  • ElasticSearchのインストール
  • サーバーのチューイング(人が増えた場合の設定変更など)
  • スクリプト自体に間違いがあった場合のトラブルシューティング
  • Cloudflareとの連携時のトラブルシューティング
    • Cloudflareの設定次第(というか初期設定)でWebが表示されなくなる場合がありますが、これはMastodon本体の問題です。解決方法は各自調べてください。面倒な場合はCloudflareのDNS設定でプロキシをオフにする方法もあります(後でいつでも再設定可能)が、Cloudflareの長所が活かせなくなります
    • Cloudflareを使う予定がある方は、トラブルが発生したときの原因の切り分けのために、DNSのプロキシをオフにすることをおすすめします。このページの下に、管理人の覚えている限りの設定を置いておきます

自動セットアップスクリプトは、以下の設定を行います。

項目
PostgreSQL ユーザー名 mastodon
PostgreSQL DB名 mastodon_production
PostgreSQL パスワード ohagi

また、以下のパスに設定ファイルをコピーします。

# aptのソース
/etc/apt/sources.list.d/nodesource.list
/etc/apt/sources.list.d/postgresql.list

# 新しく作成するユーザー
mastodon    <-- sudo su - mastodon でアクセスし、exitでrootに戻る

# Mastodonリポジトリ
/home/mastodon/live    <-- ユーザーmastodonで使う

# MastodonのNginx設定ファイル
/etc/nginx/sites-available/mastodon

# systemdサービス
mastodon-web.service
mastodon-streaming.service
[email protected]   <-- 普段は手打ちで使わないが、コピーの必要あり
mastodon-sidekiq.service

その他の設定ファイルは以下の場所に作成されます。ただしバージョンによってパスが変わる場合があります。

# PostgreSQL
/etc/postgresql/16/main

# Redis
/etc/redis/redis.conf

インストール手順

まず初期状態のUbuntu 22.04を立ち上げます。RAMは2GB以上にしましょう。これは推奨ではなく必須です。

次に、以下のコマンドを入力します。curlはインストールされてると思いますが、されてなければ事前にsudo apt install curlで入れてください。最新かLTSかは基本的には後で選びますが、実際にインストールするkmyblueのバージョンによって使用するセットアップスクリプトが異なりますのでご注意ください。
この選択は、実際にインストールされるkmyblueのバージョンを確定するものではありません。インストールしたいバージョンに応じて以下の中から選んだ上で、次のステップ(./setup2.sh)でバージョンを再度選択する必要があります。

バージョン8以前(5.x LTS含む)インストールの場合

sudo /bin/bash -c "$(curl -fsSL https://raw.githubusercontent.com/kmycode/mastodon/kb_development/install/5.0/setup1.sh)"

バージョン9以降インストールの場合

sudo /bin/bash -c "$(curl -fsSL https://raw.githubusercontent.com/kmycode/mastodon/kb_development/install/9.0/setup1.sh)"

このシェルスクリプトの実行には時間がかかります。実行途中で何度かユーザーの確認を求める画面が出ることがあります。私が確認したものは、全画面紫色のものが複数回、mastodonというユーザーを作成するときのユーザー情報入力です。基本的には全部何も入力・変更せずEnterで構いません。

上記スクリプトの実行が終了したあとは、下記コマンドを入力します。

sudo su - mastodon

# [推奨] LTS(比較的安定版)を使う場合
./setup2.sh

# 最新バージョンを取り込む場合(バージョン9以降インストールの場合、latestでも可)
./setup2.sh newest

# [非推奨] kb_developmentの最新コミットを取り込む場合(開発用)
./setup2.sh debug
exec bash
exit
sudo /home/mastodon/setup3.sh
sudo su - mastodon
./setup4.sh

これが終わったら早速セットアップといきたいのですが、その前にPostgresSQLのmastodonアカウントのパスワードを変更したい人はいったんrootユーザーに戻って、以下のコマンドを実行してください。

sudo -u postgres psql << EOF
  ALTER USER mastodon WITH PASSWORD 'ohagi';
EOF

Mastodonの初期セットアップは、下記コマンドより実行できます。(さっきrootに戻った人はsudo su - mastodonmastodonユーザーにログインし直して、~/liveディレクトリに移動してね)途中で設定に失敗した場合は最初からやり直す必要が発生するので、自動インストールスクリプトに以下のコマンドは含めていません。
今回のセットアップで、Dockerは使用していません。

cd live
RAILS_ENV=production bundle exec rake mastodon:setup

メールの送信設定でテストメールが届かなかった(設定に失敗した)場合、設定やり直したほうがいいです。後から設定修正はできますが、テストメールを送るための代替手段はありません(bundle rails c使っていじる方法もありますがRubyの知識が必要なので省略)。

Mastodonの最新更新情報をチェックしますか?と聞かれますが、実際に確認する先はMastodon本家ではなくkmyblueフォーク専用のページに変更しています。kmyblueがアップデートしたら通知を受け取ることができますので、Yesにすることをお勧めします。(デフォルトではLTSのアップデートのみチェックします。設定で変更できます)

PostgreSQLやRedisの接続情報は、すでに画面内に表示されているはずです。各種設定項目を入力したあと、以下の3つの作業があります。3つとも「やりますか?」と聞かれますが、初回なので必ず行ってください。

  • データベースの初期化
    • 間違っていいえを選択した場合、RAILS_ENV=production bin/rails db:setupで行ってください
  • アセットのプリコンパイル
    • Webクライアント用のJavaScriptファイルをあらかじめ作る仕組みです
    • 間違っていいえを選択した場合、または失敗した場合、RAILS_ENV=production bin/rails assets:precompileで行ってください
  • 初期アカウントの作成
    • アカウント作成時にパスワードが表示されるので忘れずにメモ。パスワードなくした時に変更する手順はここから探してください
    • 間違っていいえを選択した場合、RAILS_ENV=production bin/tootctl accounts create alice --email [email protected] --role Owner --confirmedで行ってください。なおその場合、admininfoなど一部の予約されたIDは使用できません(逆に言うとadminでアカウント作りたければこの初期設定が唯一のチャンスです)

なお上記コマンド( mastodon:setup )は、初期セットアップが終わってサーバーが立ち上がったのを確認したら二度と使わないでください。サーバーにはそれぞれ固有の暗号化用キーというのがあるのですが、それがクリアされてしまいます。後からサーバーの設定を変更する場合は.env.production(環境変数)というファイルを編集してサーバーを再起動する感じになります。環境変数の一覧は、このページの下にリンクがあります。

そのあとは必要に応じてcertbotの設定を行います。HTTPS接続できるようSSL証明書を作成する作業になります。すでにSSL証明書用意できてるよというつよつよの方はこの手順をスキップして、Nginxの設定をいい感じにして再起動、Mastoodnサーバーの起動までいってください。
下記のコマンドを実行する前に、あらかじめドメインのDNS設定を完了させてください。なお certbotによって取得したSSL証明書は、90日ごとに更新する必要があります

sudo cp /home/mastodon/live/dist/nginx-before-certbot.conf /etc/nginx/sites-available/mastodon
sudo vi /etc/nginx/sites-available/mastodon

# example.com を自分のドメインに置き換える

sudo systemctl reload nginx
sudo certbot --nginx -d example.com    # <- ドメイン置き換える

sudo cp /home/mastodon/live/dist/nginx.conf /etc/nginx/sites-available/mastodon
sudo vi /etc/nginx/sites-available/mastodon

# example.com を自分のドメインに置き換える
# SSL証明書ファイル設定(2行)のコメントを外してドメインを置き換える

sudo systemctl reload nginx

以上まで終わったら、Mastodonを起動します。これであなたのドメインからMastodonにアクセスできます。

sudo systemctl enable --now mastodon-web mastodon-sidekiq mastodon-streaming

基本設定はここまでです。お疲れさまでした。

以降、bin/railsbundleなどを実行する時は、sudo su - mastodonで実行ユーザーをmastodonにしたうえで、カレントディレクトリをliveに変更してください。

Web表示時のトラブル

真っ白な画面が表示される場合は、Nginxの設定などに失敗している可能性があります。

真っ黒な画面が表示されるだけの場合はアセットのプリコンパイルに失敗している可能性がありますので、以下コマンドをお試しください。

RAILS_ENV=production bin/rails assets:clobber
RAILS_ENV=production bin/rails assets:precompile

ページそのものが表示されない場合、サーバーのファイアウォール設定も原因の可能性がありますので確認してください。Amazon EC2など、ファイアウォールの設定がサーバーの外にあってデフォルトで80番・443番ポートを閉じているものもあります。

Cloudflare連携時のトラブル

まず、CloudflareのDNS設定でプロキシをオフにして正常に表示されるか確認してください。正常ならCloudflareの問題です。

管理者はCloudflareで何を設定したのかよく覚えてませんが、最低でも以下の設定はしたと思います。キャッシュの設定は変更しないと、アップデートの時に困ります。
これ以外にも必要な設定があるかもしれない/Cloudflareの仕様が変わってるかもしれないので、細かいところは申し訳ないですがご自身で調べてください。

  • 「SSL/TLS>概要」の「お客様の SSL/TLS 暗号化モード」 - フル(厳密)英語:「Full (struct)」
    • この設定を行うと、サーバー側にもSSL証明書が必要になります。上記のcertbot設定で大丈夫です
  • 「SSL/TLS>エッジ証明書」の「HTTPS の自動リライト」 - オフ
  • 「Speed>最適化」の「コンテンツの最適化」の「Auto Minify」 - JavaScript、CSS、HTML、全てオフ
  • 「Caching>Cache Rules」にルールを登録 - /api/で始まるすべての「URIパス」について、
    • キャッシュステータス:キャッシュをパイパスする
    • ブラウザTTL:オリジンをオーバーライドする 期限:「キャッシュなし」(この設定は不要かも)

設定変更後はキャッシュのパージをおすすめします。

ImageMagick 7へのアップデート(任意)

上記のセットアップスクリプトでは、ImageMagick 6がインストールされます。6では、一部環境でAVIFという画像フォーマットを扱うことはできません。Ubuntu 22.04+ImageMagick 6なら扱えるという情報があったのでこのままにしているのですが(自分で試しても大丈夫だった)、気になる方はオプションで以下のスクリプトを実行することで、6から7にバージョンアップすることができます。
※上記手順でセットアップを行い、Mastodonや関連パッケージがインストールされていることが前提です。それ以外の環境で実行した場合、依存パッケージが足りないなどでエラーが出る可能性があります

sudo /bin/bash -c "$(curl -fsSL https://raw.githubusercontent.com/kmycode/mastodon/kb_development/install/5.0/setup-imagemagick-7.sh)"

インストールに失敗した場合は、以下のコマンドでいったん挽回できます。

rm -rf ImageMagick
sudo apt install imagemagick

Misskeyの開発陣がAVIFを使いたがっているようです。あちら側の言葉を文面通り受け取ると、Misskeyからの画像がPNGもJPGも関係なく全てAVIFに変換されて流れてくるようになるらしいです。つまりMisskeyからの画像が正常に認識されなくなる可能性があります。Ubuntu 22.04以外の方は上記スクリプトの実行、Ubuntu 22.04の方も最低でも自分のサーバーでAVIF画像をアップロードできるか、表示できるかの確認をぜひおすすめします。

ElasticSearch(全文検索エンジン)のインストール(任意)

全文検索を行うには、ElasticSearchサーバーが必要です。ここではMastodonと同じ端末にインストールする方法を案内しますが、別々のサーバーにしたほうがいいです。search deployという作業は必要ですが、いつでもサーバーを変更することはできます。
なおkmyblueにおいて、タグ検索、アンテナにElasticSearchは必要ありません。

kmyblueでは、Sudachiプラグインを『指定された方法で(Sudachiドキュメントと異なる方法で)』インストールしないと動作しません。ElasticSearchインストール→Sudachiインストール→Mastodonサーバー設定変更、の順番で行います。

ElasticSearchのインストール方法、サーバー設定変更方法(サーバー再起動はちょっと待って。後半にあるMastodonのソースコードを変更する作業は不要です)
https://docs.joinmastodon.org/admin/elasticsearch/

インストール終わったら、下記URLの説明を見てElasticSearchにSudachiプラグインを追加してください。Sudachiプラグインは、ElasticSearchのバージョンによってダウンロードするファイルが分かれていますので、必ずお手元のElasticSearchのバージョンを確認して最適なファイルをダウンロードしてください。対応するバージョンがない場合もありますが、その時はElasticSearchのバージョンを下げます
手順書と異なる点として、辞書ファイル(sudachi dictionary archive)は/etc/elasticsearch/sudachiに格納してください。

https://github.com/WorksApplications/elasticsearch-sudachi

Sudachiインストール終了後、追加で/etc/elasticsearch/sudachi/config.jsonに下記を記述して保存してください。system_full.dicを使用する場合は適宜systemDictプロパティの内容を置き換えてください。

{
  "systemDict": "system_core.dic"
}

Mastodonサーバーを再起動します。ElasticSearchとの疎通確認は、検索機能を通して試します。

環境変数をもっと細かく設定する、後から変える(任意)

https://docs.joinmastodon.org/admin/config/
kmyblue独自の環境変数

画像の置き場所をローカルではなくS3などのクラウドストレージにする(任意)

任意となっていますが、下記に当てはまる場合はMastodonサーバーを公開する前に最初から設定すべきです。後回しにすると死にます。

  • 将来的に人の多いサーバーにするつもりがある(SidekiqをWebとは別のサーバーに分離するかもしれない)
  • Webサーバーのストレージ容量に上限がある(例えば100GBは、1人でも大量のアカウントをリモートフォローする/連合リレーに参加することを考えると、少ない方です)

設定手順はこちらを見てください。
https://docs.joinmastodon.org/admin/optional/object-storage/

こちらなどのサイトも参考になります。
https://hyper-text.org/archives/2017/04/mastodon-instance-with-amazon-s3.shtml

きちんと設定したつもりでも画像がアップロードできないトラブルが起きやすいので、Webサーバーを起動して一度アップロードを試してください。journalctl -r -u mastodon-webでエラー内容を確認してください。特に以下のストレージでは気をつけてください。その他のストレージにも注意点があるかもしれません。

  • AWS S3では、セキュリティ上の理由で非推奨な設定項目を変更する必要があります。料金の関係でCloudFrontとの連携の検討をお勧めします(保存場所そのままでURLだけ変更するならいつでも大丈夫です)
  • Wasabiは設定が面倒です

サーバーの初期設定、Cronの設定を行う

前半部分はサーバー立ち上げた時に真っ先に管理画面開いていろいろ確認するタイプの人間ならもう設定済だと思いますが、後半のCronの設定は確認してください(忘れても大体大丈夫かと)

https://docs.joinmastodon.org/admin/setup/

サーバーのメンテナンス(tootctlコマンド)

https://docs.joinmastodon.org/admin/tootctl/

おはぎと話す(任意)

RAILS_ENV=production bin/tootctl ohagi good
RAILS_ENV=production bin/tootctl ohagi tsubuan

特に意味はありません。

サーバーの負荷を減らす(任意)

人が増えるとサーバーの負荷も上がります。人が増えても快適にサーバーを使えるようにするための設定例がここにあります。これに限らずMastodonの公式ドキュメントには有用な情報がたくさんあるので、読むことをお勧めします。
これらはMastodon公式ドキュメント通りにセットアップしたことを前提にしていますが、上記のセットアップ方法でも問題なく取り扱えます。

https://docs.joinmastodon.org/admin/scaling/

特にpgBouncerについては別途サーバー機器を用意する必要もないことから、小規模サーバーでも簡単に導入可能です。ぜひご検討ください。

また、pgTuneというサイトを使ってPostgreSQLの設定を最適化することも可能です。

サーバーのログを確認する(任意)

エラーが出るなどした場合は、以下よりログを確認できます。Web画面上でエラー画面が表示される/Web操作時に画面左下にエラーが表示される場合はmastodon-web、他サーバーへの投稿の配信がおかしい/他サーバーからの投稿が表示されない/検索できないなどの場合はmastodon-sidekiqを見ます。

journalctl -r -u mastodon-web
journalctl -r -u mastodon-sidekiq
journalctl -r -u mastodon-streaming

ユーザー設定画面でも「Sidekiq」という項目があり、そこからバックエンドタスクの状況を簡単に確認できます(上級者向け)。

kmyblueをアップデートする

アップデート手順を参照してください。

その他のチップ

サーバー管理のヒントを参照してください。

Clone this wiki locally