GNU/Linux >> Linux の 問題 >  >> Panels >> Panels

Ubuntu18.04にMastodonをインストールする方法

この記事では、Ubuntu18.04VPSにMastodonをインストールします。

マストドンは、Twitterとして知られている有名なソーシャルメディアプラットフォームに非常によく似た無料のオープンソースネットワークプラットフォームです。ただし、Twitterとは異なり、単一の中央機関はなく、広告もありません。 MastodonはRubyとJavaScriptで記述されており、そのオープンソースの性質により、誰でもプライベートかつ安全に使用できるようになっています。誰でもマストドンサーバーを作成し、友達と一緒に独自のコミュニティを構築できます。さらに、Mastodonは、iOS、Android、およびその他のプラットフォーム用の複数のアプリによってサポートされ、利用可能です。これにより、どこにいても友達と連絡を取り合うことができます。マストドンのインストールから始めましょう。

前提条件:

インストールを開始する前に、前提条件を満たしている必要があります。

  • Ubuntu18.04を実行しているサーバー
  • rootアクセスまたはsudo権限を持つユーザー
  • Mastodonサーバーのドメイン名(またはサブドメイン)。例: your_domain_name.com

SSHプロトコルを使用してVPSにログインすることから始めます。

このチュートリアルではすべてのコマンドをrootとして実行するため、rootアカウントを使用していない場合は、rootに切り替えるか、コマンドの前でsudoコマンドを使用します。または、「sudo」というプレフィックスを付けて各コマンドを実行するようにしてください。

sudo -i

ステップ1:必要なリポジトリを追加する

このステップでは、必要なリポジトリをシステムに追加します。

システムにcurlがインストールされていることを確認するには、次のコマンドを実行します。

apt install -y curl

次のcurlコマンドを使用してNodeSourceリポジトリを有効にします。

curl -sL https://deb.nodesource.com/setup_8.x | bash -

次のコマンドを使用して、リポジトリのGPGキーをインポートします。この後、YarnAPTリポジトリを有効にします:

curl -sS https://dl.yarnpkg.com/debian/pubkey.gpg | apt-key add -
echo "deb https://dl.yarnpkg.com/debian/ stable main" | tee /etc/apt/sources.list.d/yarn.list

ステップ2:パッケージのインストール

次に、Mastodonに必要なシステムパッケージをインストールします:

apt update

apt install -y \
imagemagick ffmpeg libpq-dev libxml2-dev libxslt1-dev file git-core \
g++ libprotobuf-dev protobuf-compiler pkg-config nodejs gcc autoconf \
bison build-essential libssl-dev libyaml-dev libreadline6-dev \
zlib1g-dev libncurses5-dev libffi-dev libgdbm5 libgdbm-dev \
nginx redis-server redis-tools postgresql postgresql-contrib \
certbot yarn libidn11-dev libicu-dev libjemalloc-dev

インストールしたばかりの依存関係について簡単に説明します。

  • imagemagick –マストドンは画像関連の操作にImageMagickを使用しています
  • ffmpeg –マストドンはGIFをMP4に変換するためにFFmpegを使用します
  • libprotobuf-devおよびprotobuf-compiler –マストドンはこれらを言語検出に使用します
  • nginx –nginxはWebサーバーとして使用されます
  • redis-* – Mastodonは、メモリ内のデータ構造ストアにRedisを使用しています
  • postgresql-* –マストドンはSQLデータベースとしてPostgreSQLを使用しています
  • nodejs –ノードはMastodonのストリーミングAPIに使用されます
  • 毛糸 –yarnはNode.jsパッケージマネージャーです
  • その他の-devパッケージ、g ++ –これらはruby-buildを使用したRubyのコンパイルに必要です。

ステップ3:Rubyのインストール

RubyもMastodonの要件の1つであり、このステップでインストールします。 「rbenv」を使用してRubyのバージョンを管理します。ただし、特定のLinuxユーザー用にrbenvをインストールする必要があるため、最初に行う必要があるのは、新しいMastodonユーザーを作成することです。 Mastodonユーザーを作成するには、次のコマンドを実行します。

adduser --disabled-login mastodon

次に、次のコマンドを使用してユーザーマストドンに切り替えます。

su - mastodon

そして、次のコマンドを使用して、rbenvとrbenv-buildをインストールします。

git clone https://github.com/rbenv/rbenv.git ~/.rbenv
cd ~/.rbenv && src/configure && make -C src
echo 'export PATH="$HOME/.rbenv/bin:$PATH"' >> ~/.bashrc
echo 'eval "$(rbenv init -)"' >> ~/.bashrc
exec bash
git clone https://github.com/rbenv/ruby-build.git ~/.rbenv/plugins/ruby-build

rbenvとrbenv-buildのインストールが完了したら、必要な正確なRubyバージョンをインストールできます。

RUBY_CONFIGURE_OPTS=--with-jemalloc rbenv install 2.6.0
rbenv global 2.6.0

ruby_2.6.0にはデフォルトのgemバージョンと互換性のないバンドラーが付属しているため、gemを更新する必要があります:

gem update --system

これに加えて、バンドラーをインストールする必要があります:

gem install bundler --no-document

すべてのステップが処理されたら、rootユーザーに戻ることができます:

exit

ステップ4:PostgreSQLの設定

別のパスワードを必要とせずに、同じユーザー名でLinuxユーザーが使用できるPostgreSQLユーザーを作成します。これは、「ID」認証を使用する非常に単純な方法であり、セットアップが簡単で、ローカルユーザーがパスワードなしでデータベースにアクセスできるようにします。

postgresユーザーに切り替えてから、 psql を実行すると、Postgresプロンプトを開くことができます。 コマンド、または次のコマンドを実行できます:

sudo -u postgres psql

コマンドを実行します:

CREATE USER mastodon CREATEDB;

次のコマンドでPostgresプロンプトを終了します:

\q

ステップ5:マストドンの設定

Mastodonをインストールするためのサーバーを準備したので、Mastodonコードのダウンロードに進むことができます。次のコマンドでマストドンユーザーに切り替えます:

su - mastodon

次のコマンドを実行して、gitを使用してMastodonの最新の安定したリリースのクローンを作成します。

git clone https://github.com/tootsuite/mastodon.git live && cd live
git checkout $(git tag -l | grep -v 'rc[0-9]*$' | sort -V | tail -n 1)

ステップ6:RubyとJavaScriptの依存関係をインストールする

これらは、インストールする必要がある最後の依存関係です。残りのRuby依存関係をインストールするためにbundleを使用します:

bundle install \
-j$(getconf _NPROCESSORS_ONLN) \
--deployment --without development test

そしてyarnを使用してNode.jsの依存関係をインストールします:

yarn install --pure-lockfile

ステップ7:構成ファイルの生成

構成ファイルを生成するために、対話型セットアップウィザードを実行できます。

RAILS_ENV=production bundle exec rake mastodon:setup

これで、マストドンユーザーとの関係がすべてであるため、rootアカウントに戻すことができます。

exit

ステップ8:Nginxのセットアップ

Mastodonには、デフォルトでNginx構成テンプレートが付属しています。次のステップでは、この構成テンプレートのコピーを使用して、必要に応じて調整します。

cp /home/mastodon/live/dist/nginx.conf /etc/nginx/sites-available/mastodon.conf
ln -s /etc/nginx/sites-available/mastodon.conf /etc/nginx/sites-enabled/mastodon.conf

次に、/etc/nginx/sites-available/mastodon.confを編集します your_domain.comを実際のドメイン名に置き換えます。

nano /etc/nginx/sites-available/mastodon.conf

変更を有効にするには、Nginxをリロードする必要があります:

systemctl reload nginx

何らかの理由でその場所に誤ってNginxファイルがない場合は、次のNginx構成を使用して、必要に応じて変更できます。

map $http_upgrade $connection_upgrade {
default upgrade;
'' close;
}

proxy_cache_path /var/cache/nginx levels=1:2 keys_zone=CACHE:10m inactive=7d max_size=1g;

server {
listen 80;
listen [::]:80;
server_name your_domain.com;
root /home/mastodon/live/public;
location /.well-known/acme-challenge/ { allow all; }
location / { return 301 https://$host$request_uri; }
}

server {
listen 443 ssl http2;
listen [::]:443 ssl http2;
server_name your_domain.com;

ssl_protocols TLSv1.2;
ssl_ciphers HIGH:!MEDIUM:!LOW:!aNULL:!NULL:!SHA;
ssl_prefer_server_ciphers on;
ssl_session_cache shared:SSL:10m;

# Uncomment these lines once you acquire a certificate:
# ssl_certificate /etc/letsencrypt/live/your_domain.com/fullchain.pem;
# ssl_certificate_key /etc/letsencrypt/live/your_domain.com/privkey.pem;

keepalive_timeout 70;
sendfile on;
client_max_body_size 80m;

root /home/mastodon/live/public;

gzip on;
gzip_disable "msie6";
gzip_vary on;
gzip_proxied any;
gzip_comp_level 6;
gzip_buffers 16 8k;
gzip_http_version 1.1;
gzip_types text/plain text/css application/json application/javascript text/xml application/xml application/xml+rss text/javascript;

add_header Strict-Transport-Security "max-age=31536000";

location / {
try_files $uri @proxy;
}

location ~ ^/(emoji|packs|system/accounts/avatars|system/media_attachments/files) {
add_header Cache-Control "public, max-age=31536000, immutable";
add_header Strict-Transport-Security "max-age=31536000";
try_files $uri @proxy;
}

location /sw.js {
add_header Cache-Control "public, max-age=0";
add_header Strict-Transport-Security "max-age=31536000";
try_files $uri @proxy;
}

location @proxy {
proxy_set_header Host $host;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_set_header X-Forwarded-Proto https;
proxy_set_header Proxy "";
proxy_pass_header Server;

proxy_pass http://127.0.0.1:3000;
proxy_buffering on;
proxy_redirect off;
proxy_http_version 1.1;
proxy_set_header Upgrade $http_upgrade;
proxy_set_header Connection $connection_upgrade;

proxy_cache CACHE;
proxy_cache_valid 200 7d;
proxy_cache_use_stale error timeout updating http_500 http_502 http_503 http_504;
add_header X-Cached $upstream_cache_status;
add_header Strict-Transport-Security "max-age=31536000";

tcp_nodelay on;
}

location /api/v1/streaming {
proxy_set_header Host $host;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_set_header X-Forwarded-Proto https;
proxy_set_header Proxy "";

proxy_pass http://127.0.0.1:4000;
proxy_buffering off;
proxy_redirect off;
proxy_http_version 1.1;
proxy_set_header Upgrade $http_upgrade;
proxy_set_header Connection $connection_upgrade;

tcp_nodelay on;
}

error_page 500 501 502 503 504 /500.html;
}

新しいファイルを確認するには、ファイルを保存して終了し、上記のようにNginxを再起動することを忘れないでください。

ステップ9:SSL証明書を取得する

Let’s Encryptを使用して、無料のSSL証明書を生成します:

certbot certonly --webroot -d your_domain.com -w /home/mastodon/live/public/

your_domain.comを実際のドメイン名に置き換えることを忘れないでください。これで、/etc/nginx/sites-available/mastodon.confを編集できます 構成ファイル:

nano /etc/nginx/sites-available/mastodon.conf

ssl_certificateのコメントを外して変更します およびssl_certificate_key 行。構成ファイルの編集が終了したら、変更を有効にするためにNginxをもう一度リロードする必要があります:

systemctl reload nginx

この時点で、好みのWebブラウザーでドメインにアクセスしようとすると、Mastodonを表示できなくなります。これは、マストドンプロセスがまだ開始されていないためです。

ステップ10:systemdサービスの設定

このステップでは、サーバーでMastodonサービスを開始して有効にします。マストドンディレクトリからsystemdサービステンプレートをコピーするだけです:

cp /home/mastodon/live/dist/mastodon-*.service /etc/systemd/system/

これらのファイルでユーザー名とパスが正しいことを再確認して確認できます:

  • /etc/systemd/system/mastodon-web.service
  • /etc/systemd/system/mastodon-sidekiq.service
  • /etc/systemd/system/mastodon-streaming.service

最後に、Mastodonsystemdサービスを開始して有効にすることができます。

systemctl start mastodon-web mastodon-sidekiq mastodon-streaming
systemctl enable mastodon-web mastodon-sidekiq mastodon-streaming

万が一systemdファイルが見つからない場合は、次の構成を使用できます。 3つのsystemdマストドンサービスファイルを作成する必要があります。

Mastodon Web Workersサービスの場合は、次のように入力します。

nano /etc/systemd/system/mastodon-web.service

次のコードを配置します:

[Unit]
Description=mastodon-web
After=network.target

[Service]
Type=simple
User=mastodon
WorkingDirectory=/home/mastodon/live
Environment="RAILS_ENV=production"
Environment="PORT=3000"
ExecStart=/home/mastodon/.rbenv/shims/bundle exec puma -C config/puma.rb
ExecReload=/bin/kill -SIGUSR1 $MAINPID
TimeoutSec=15
Restart=always

[Install]
WantedBy=multi-user.target

次に、保存して終了します。

マストドンバックグラウンドキューサービスの場合:

nano /etc/systemd/system/mastodon-sidekiq.service

次のコードを貼り付けます:

[Unit]
Description=mastodon-sidekiq
After=network.target

[Service]
Type=simple
User=mastodon
WorkingDirectory=/home/mastodon/live
Environment="RAILS_ENV=production"
Environment="DB_POOL=25"
Environment="MALLOC_ARENA_MAX=2"
ExecStart=/home/mastodon/.rbenv/shims/bundle exec sidekiq -c 25
TimeoutSec=15
Restart=always

[Install]
WantedBy=multi-user.target

次に、ファイルを保存して終了します。

MastodonストリーミングAPIサービスの場合:

nano /etc/systemd/system/mastodon-streaming.service

次のコードを配置します:

[Unit]
Description=mastodon-streaming
After=network.target

[Service]
Type=simple
User=mastodon
WorkingDirectory=/home/mastodon/live
Environment="NODE_ENV=production"
Environment="PORT=4000"
Environment="STREAMING_CLUSTER_NUM=1"
ExecStart=/usr/bin/node ./streaming
TimeoutSec=15
Restart=always

[Install]
WantedBy=multi-user.target

保存して終了します。

変更を有効にするには、systemctlデーモンリストをリロードする必要があります。

systemctl daemon-reload

これで、以前と同じようにMastodonsystemdサービスを開始して有効にできるはずです。

おめでとう!サーバーにMastodonが正常にインストールされました。 https://your_domain.com/にアクセスしてアクセスできます。

この記事では、Ubuntu18.04にMastodonをインストールする方法を紹介しました。これで、この知識を使用して、このすばらしいアプリケーションを使用してプライベートソーシャルネットワークを作成できます。

もちろん、マネージドUbuntu Hostingをご利用の場合は、Ubuntu18.04VPSにMastodonをインストールする必要はありません。管理者に聞いてリラックスしてください。管理者はすぐにUbuntu18.04にMastodonをインストールします。

PS。 Ubuntu 18.04 VPSにMastodonをインストールする方法に関するこの投稿が気に入った場合は、下のボタンを使用してソーシャルネットワーク上の友達と共有するか、コメントセクションにコメントを残してください。ありがとうございます。


Panels
  1. Ubuntu14.04にATutorをインストールする方法

  2. Ubuntu16.04にTraqをインストールする方法

  3. Ubuntu16.04にPipをインストールする方法

  1. Ubuntu16.04にWildFlyをインストールする方法

  2. Ubuntu16.04にRをインストールする方法

  3. Ubuntu18.04にGoをインストールする方法

  1. Ubuntu18.04にISPConfig3をインストールする方法

  2. Ubuntu18.04にWebminをインストールする方法

  3. Ubuntu10.04にPanda3Dをインストールする方法