Misskey install shell script v3.0.0

Pasang Misskey dengan satu shell script!

Kamu dapat memasang misskey pada peladen Ubuntu hanya dengan menjawab beberapa pertanyaan saja.

Terdapat juga script untuk memutakhirkan.

Untuk v12
日本語版はこちら

Lisensi

Lisensi MIT

Bahan

  1. Domain
  2. Peladen Ubuntu
  3. Akun Cloudflare (Direkomendasikan)

Jangan pernah mengganti nama domain (hostname) peladen ketika kamu sudah mulai menggunakannya!

Pengaturan Clouflare

Jika kamu menggunakan nginx dan Cloudflare, kamu harus mengatur Cloudflare terlebih dahulu untuk:

  • Mengatur DNS.
  • Pada tab pengaturan SSL/TLS, ubah mode enkripsi ke "Full".

Prosedur

1. SSH

Menyambung ke peladen melalui SSH.
(Jika kamu memiliki peladen dengan lingkungan desktop terpasang, buka Terminal/shell)

2. Pembersihan

Pastikan semua paket telah termutakhirkan dan boot ulang.

sudo apt update; sudo apt full-upgrade -y; sudo reboot

3. Jalankan pemasangan

Hubungkan ulang SSH dan mulai pemasangan Misskey.

wget https://raw.githubusercontent.com/joinmisskey/bash-install/main/ubuntu.sh -O ubuntu.sh; sudo bash ubuntu.sh

4. Untuk memutakhirkan

Terdapat juga script untuk memutakhirkan peladen Misskey.

Script pemutakhirant tidak memutakhirkan lingkungan peladen.
Mohon untuk merujuk ke CHANGELOG (Bahasa Jepang) dan Daftar rilis di GitHub (Bahasa Inggris) serta lakukan operasi migrasi sesuai arahan.

Pertama, unduh script.

wget https://raw.githubusercontent.com/joinmisskey/bash-install/main/update.ubuntu.sh -O update.sh

Jalankan ini ketika kamu ingin memutakhirkan Misskey.

sudo bash update.sh
  • Pada lingkungan systemd, opsi -r dapat digunakan untuk memutakhirkan dan memboot ulang sistem.
  • Pada lingkungan docker, kamu dapat menentukan repository:tag sebagai argumen.

Lingkungan dimana operasi ini telah diuji

Oracle Cloud Infrastructure

Script ini bekerja dengan baik pada bentuk compute berikut yang disediakan oleh Oracle Cloud Infrastructure Always Free services.

  • VM.Standard.E2.1.Micro (AMD)
  • VM.Standard.A1.Flex (ARM) [1OCPU RAM6GB or greater]

Jawab untuk menggunakan iptables.

Isu & PRs Dipersilahkan

Apabila script ini tidak dapat bekerja pada lingkungan diatas, kemungkinan karena bug. Kami mengapresiasi apabila kamu dapat melaporkan hal tersebut sebagai isu dengan syarat tertentu yang telah kamu input ke dalam script.

Sangat sulit untuk memberikan bantuan untuk lingkungan selain yang disebutkan di atas, namun kami masih dapat membantu mencarikan solusi dari masalah kamu apabila kamu memberikan informasi detil mengenai lingkungan peladenmu.

Saran untuk fitur juga dipersilahkan.

Tips

Cara memilih opsi dan spesifikasi.

Systemd or Docker?

Mulai dari v1, terdapat metode pemasangan systemd atau Docker yang dapat dipilih.

Ketika memilih metode pemasangan Docker, Misskey akan dipasang dan dijalankan melalui Docker sedangkan Redis, Postgres dan sebagainya akan dipasang dan dijalankan pada host peladen langsung.

Apabila kamu memilih menggunakan image dari Docker Hub, kebutuhan untuk build Misskey tidak diperlukan dan pilihan ini merupakan rekomendasi dari kami. Namun ketika melakukan pemutakhiran, migrasi tetap dibutuhkan dan downtime tetap tidak dapat terhindarkan. Selain itu, dengan menggunakan image dari Docker Hub tidak perlu lagi menyiapkan lingkungan untuk build Misskey (tidak ada git pull). Dengan kata lain, apabila ingin menyiapkan dan menjalankan fork akan lebih merepotkan.

Karena alasan performa, metode build Docker secara lokal tidak dipergunakan lagi.

Metode pemasangan systemd sangat direkomendasikan apabila kamu ingin menggunakan ataupun menjalankan fork. Metode pemasangan ini juga tidak mengharuskan kamu untuk mengunggah image ke Docker Hub.

Urutan rekomendasi yang disarankan adalah sebagai berikut:

  1. Docker Hub
  2. systemd
  3. Docker Build

Gunakan nginx atau tidak?

Apabila kamu ingin membuat peladen Misskey pada satu peladen, disarankan untuk menggunakan nginx.

Tambahkan swap!

Apabila kamu menggunakan swap, pastikan swap kamu memiliki hingga ruang hingga 3GB. Karena script akan dapat berjalan lancar apabila memiliki memori dengan minimal 3GB.

Jika script gagal dan kamu ingin menjalankannya kembali

Perhatikan arahan berikut ini:

  • Apabila Redis atau Postgres telah terpasang, atur install locally ke "No". Biarkan pengaturan host・port apa adanya lalu tekan Enter. Masukkan nama pengguna dan kata sandi seperti yang telah ditentukan pada proses sebelumnya.

Mengenai berkas .env

Script pemasangan membuat dua berkas .env yang dipergunakan untuk memutakhirkan Misskey.

/root/.misskey.env

Diperlukan untuk mengingat pengguna yang menjalankan proses misskey

/home/(pengguna_misskey)/.misskey.env

Dibuat untuk systemd yang dipertujukan mengingat direktori.

/home/(pengguna_misskey)/.misskey-docker.env

Dibuat untuk Docker dengan tujuan menyimpan nomor kontainer beserta image yang sedang berjalan. Nomor kontainer akan diperbarui selama pemutakhiran. Image lama akan dihapus.

Manajemen Mandiri

Setelah pemasangan, ada beberapa catatan yang cukup berguna pada saat ingin mengubah konfigurasi.

Ganti domain "example.com" dengan domain kamu sendiri.

Direktori Misskey

Sumber kode akan diklon pada dikrektori /home/pengguna/direktori. (nilai default untuk pengguna dan direktori adalah misskey)

Kamu dapat menavigasi ke direktori Misskey dengan melakukan perintah berikut.

sudo -iu pengguna
cd direktori

Untuk kembali ke pengguna sebelumnya, jalankan perintah exit.

exit

systemd

Nama proses dalam systemd adalah example.com.
Sebagai contoh untuk memulai ulang proses, jalankan perintah berikut.

sudo systemctl restart example.com

Kamu dapat memeriksa logs dengan menggunakan journalctl.

journalctl -t example.com

Berkas konfigurasi systemd disimpan pada /etc/systemd/system/example.com.service.

Docker

Docker menggunakan pengguna Misskey untuk dijalankan secara tanpa root.

Saat masuk ke pengguna Misskey menggunakan sudo, kamu perlu mengubah XDG_RUNTIME_DIR dan DOCKER_HOST terlebih dahulu.

sudo -iu pengguna
export XDG_RUNTIME_DIR=/run/user/$UID
export DOCKER_HOST=unix://$XDG_RUNTIME_DIR/docker.sock

# Tampilkan daftar Proses
docker ps

# Build (Repositori: local/misskey:latest)
docker build -t local/misskey:latest ./misskey

# Menjalankan Docker
docker run -d -p 3000:3000 --add-host=docker_host:10.0.0.1 -v /home/misskey/misskey/files:/misskey/files -v "/home/misskey/misskey/.config/default.yml":/misskey/.config/default.yml:ro --restart unless-stopped -t "local/misskey:latest"

# Menampilkan log
docker logs --tail 50 -f コンテナID

Proses diatas dapat dilakukan dengan perintah satu baris berikut.

sudo -u pengguna XDG_RUNTIME_DIR=/run/user/$(id -u pengguna) DOCKER_HOST=unix:///run/user/$(id -u pengguna)/docker.sock docker ps

nginx

Pengaturan situs pada nginx disimpan di /etc/nginx/conf.d/example.com.conf.

Redis

Parameter requirepass dan bind diatur di /etc/redis/misskey.conf.

Q. Error 502 tidak dapat diakses setelah melakukan pemutakhiran

Apabila proses migrasi sedang berlangsung, Docker tidak dapat memberikan izin akses langsung. Pastikan dan periksa apakah proses migrasi telah selesai.

Pada kasus menggunankan systemd, perintah pnpm install kemungkinan gagal. Coba jalankan perintah berikut ini di direktori Misskey lalu jalankan pemutakhiran kembali.

pnpm run clean-all

Apabila kamu memeriksa log dengan journalctl, umumnya kamu akan menemukan pernyataan dalam log yang menampilkan re2.

Q. Membangun instansi Misskey lebih dari 1 di peladen yang sama

Script ini tidak dapat melakukan pemasangan instansi Misskey lebih dari 1 pada peladen yang sama. Hal ini dikarenakan beberapa pengaturan nantinya akan ditimpa dan kamu akan mendapatkan banyak galat dan kesalahan dalam proses menjalankan script ini.