Cara Memasang Wiki.js di FreeBSD 11

Wiki.js adalah aplikasi wiki modern gratis dan open source yang dibangun di atas Node.js, MongoDB, Git, dan Markdown. Kode sumber Wiki.js di-host secara publik di Github . Panduan ini akan menunjukkan kepada Anda bagaimana menginstal Wiki.js pada instance FreeBSD 11 Vultr yang baru dengan menggunakan Node.js, MongoDB, PM2, Nginx, Git dan Acme.sh.

Persyaratan

Persyaratan untuk menjalankan Wiki.js adalah sebagai berikut:

  • Node.js versi 6.11.1 atau lebih baru
  • MongoDB versi 3.2 atau yang lebih baru
  • Git versi 2.7.4 atau yang lebih baru
  • Server web seperti Nginx, Apache, IIS, Caddy, atau H2O. Panduan ini akan menggunakan Nginx.
  • Repositori yang sesuai dengan Git (publik atau pribadi) Ini adalah opsional
  • Minimal RAM 512MB. Sangat disarankan untuk menggunakan mesin dengan setidaknya 1GB RAM.
  • Nama domain dengan A/ AAAAcatatan diatur. Dalam panduan ini kita akan menggunakan wiki.example.comsebagai contoh domain.

Sebelum kamu memulai

Periksa versi FreeBSD.

uname -ro
# FreeBSD 11.2-RELEASE

Pastikan sistem FreeBSD Anda mutakhir.

freebsd-update fetch install
pkg update && pkg upgrade -y

Instal sudo, vim, unzip, wget, git, bashdan socatpaket jika mereka tidak hadir pada sistem Anda.

pkg install -y sudo vim unzip wget git bash socat

Buat akun pengguna baru dengan nama pengguna pilihan Anda (kami akan gunakan johndoe).

adduser

# Username: johndoe
# Full name: John Doe
# Uid (Leave empty for default): <Enter>
# Login group [johndoe]: <Enter>
# Login group is johndoe. Invite johndoe into other groups? []: wheel
# Login class [default]: <Enter>
# Shell (sh csh tcsh nologin) [sh]: bash
# Home directory [/home/johndoe]: <Enter>
# Home directory permissions (Leave empty for default): <Enter>
# Use password-based authentication? [yes]: <Enter>
# Use an empty password? (yes/no) [no]: <Enter>
# Use a random password? (yes/no) [no]: <Enter>
# Enter password: your_secure_password
# Enter password again: your_secure_password
# Lock out the account after creation? [no]: <Enter>
# OK? (yes/no): yes
# Add another user? (yes/no): no
# Goodbye!

Jalankan visudoperintah dan batalkan komentar pada %wheel ALL=(ALL) ALLbaris, untuk memungkinkan anggota wheelgrup untuk mengeksekusi perintah apa pun.

# Uncomment by removing the hash (#) sign
%wheel ALL=(ALL) ALL

Sekarang, beralihlah ke pengguna Anda yang baru dibuat.

su - johndoe

CATATAN: Ganti johndoedengan nama pengguna Anda.

Siapkan zona waktu.

sudo tzsetup

Instal Node.js

Wiki.js membutuhkan Node.js 6.11.1 atau yang lebih baru, jadi pertama-tama kita perlu menginstal versi Node.js. yang sesuai.

Instal Node.js dan NPM.

sudo pkg install -y node8 npm-node8

Periksa versinya.

node -v && npm -v
# v8.12.0
# 6.4.1

Instal MongoDB

Wiki.js menggunakan MongoDB sebagai mesin basis data.

Instal MongoDB.

sudo pkg install -y mongodb36

Periksa versinya.

mongo --version | head -n 1 && mongod --version | head -n 1
# MongoDB shell version v3.6.6
# db version v3.6.6

Aktifkan dan mulai MongoDB.

sudo sysrc mongod_enable=yes
sudo service mongod start

Instal Acme.sh dan dapatkan sertifikat Let's Encrypt ( opsional )

Mengamankan wiki Anda dengan HTTPS tidak diperlukan, tetapi itu adalah praktik yang baik untuk mengamankan lalu lintas situs Anda. Untuk mendapatkan sertifikat SSL dari Let's Encrypt, kami akan menggunakan klien Acme.sh. Acme.sh adalah perangkat lunak unix shell murni untuk mendapatkan sertifikat SSL dari Let's Encrypt dengan nol dependensi. Itu membuatnya sangat ringan dibandingkan dengan beberapa klien protokol Acme lain yang membutuhkan banyak ketergantungan untuk berjalan dengan sukses.

Unduh dan instal Acme.sh.

sudo mkdir /etc/letsencrypt
git clone https://github.com/Neilpang/acme.sh.git
cd acme.sh
sudo ./acme.sh --install --home /etc/letsencrypt --accountemail [email protected]
cd ~

Periksa acme.shversinya.

/etc/letsencrypt/acme.sh --version
# v2.8.0

Dapatkan sertifikat RSA dan ECDSA untuk wiki.example.com.

# RSA 2048
sudo /etc/letsencrypt/acme.sh --issue --standalone --home /etc/letsencrypt -d wiki.example.com --ocsp-must-staple --keylength 2048
# ECDSA/ECC P-256
sudo /etc/letsencrypt/acme.sh --issue --standalone --home /etc/letsencrypt -d wiki.example.com --ocsp-must-staple --keylength ec-256

Setelah menjalankan perintah di atas, sertifikat dan kunci Anda akan berada di direktori berikut:

  • RSA: /etc/letsencrypt/wiki.example.com
  • ECC / ECDSA: /etc/letsencrypt/wiki.example.com_ecc

CATATAN: Jangan lupa ganti wiki.example.comdengan nama domain Anda.

Setelah mendapatkan sertifikat dari Let's Encrypt, kita perlu mengkonfigurasi Nginx untuk memanfaatkannya.

Instal dan konfigurasikan Nginx

Wiki.js dapat berjalan tanpa server web yang sebenarnya, namun sangat disarankan untuk meletakkan server web standar di depannya. Ini memastikan Anda dapat menggunakan fitur seperti SSL, banyak situs web, caching dan lainnya. Kami akan menggunakan Nginx dalam tutorial ini, tetapi server lain akan melakukannya, Anda hanya perlu mengkonfigurasinya dengan benar.

Instal Nginx.

sudo pkg install -y nginx

Periksa versinya.

nginx -v
# nginx version: nginx/1.14.0

Aktifkan dan mulai Nginx.

sudo sysrc nginx_enable=yes
sudo service nginx start

Konfigurasikan Nginx sebagai HTTPS (jika Anda menggunakan SSL) proksi balik untuk aplikasi Wiki.js.

Jalankan sudo vim /usr/local/etc/nginx/wiki.js.confdan isi dengan konfigurasi proxy terbalik dasar di bawah ini.

server {

  listen [::]:443 ssl http2;
  listen 443 ssl http2;
  listen [::]:80;
  listen 80;

  server_name wiki.example.com;

  charset utf-8;
  client_max_body_size 50M;

  # RSA
  ssl_certificate /etc/letsencrypt/wiki.example.com/fullchain.cer;
  ssl_certificate_key /etc/letsencrypt/wiki.example.com/wiki.example.com.key;
  # ECDSA
  ssl_certificate /etc/letsencrypt/wiki.example.com_ecc/fullchain.cer;
  ssl_certificate_key /etc/letsencrypt/wiki.example.com_ecc/wiki.example.com.key;

  location / {
    proxy_set_header Host $http_host;
    proxy_set_header X-Real-IP $remote_addr;
    proxy_pass http://127.0.0.1:3000;
    proxy_http_version 1.1;
    proxy_set_header Upgrade $http_upgrade;
    proxy_set_header Connection "upgrade";
    proxy_next_upstream error timeout http_502 http_503 http_504;
  }

}

Satu-satunya hal yang perlu Anda ubah dalam konfigurasi di atas adalah server_namedirektif, dan berpotensi proxy_passarahan jika Anda memutuskan untuk mengkonfigurasi beberapa port selain 3000. Wiki.js menggunakan port 3000secara default. Simpan file dan keluar dengan :+ W+Q

Sekarang kita perlu memasukkan wiki.js.conffile ke file utama nginx.conf.

Jalankan sudo vim /usr/local/etc/nginx/nginx.confdan tambahkan baris berikut ke http {}blok.

include wiki.js.conf;

Periksa konfigurasi.

sudo nginx -t

Muat ulang Nginx.

sudo service nginx reload

Instal Wiki.js

Buat folder root dokumen kosong tempat Wiki.js akan diinstal.

sudo mkdir -p /usr/local/www/wiki.example.com

Arahkan ke folder root dokumen.

cd /usr/local/www/wiki.example.com

Ubah kepemilikan /usr/local/www/wiki.example.comfolder menjadi pengguna johndoe.

sudo chown -R johndoe:johndoe /usr/local/www/wiki.example.com

Dari /usr/local/www/wiki.example.comfolder, jalankan perintah berikut untuk mengunduh dan menginstal Wiki.js.

curl -sSo- https://wiki.js.org/install.sh | bash

VERSION=$(curl -L -s -S https://beta.requarks.io/api/version/stable)
curl -L -s -S https://github.com/Requarks/wiki/releases/download/v$VERSION/wiki-js.tar.gz | tar -f - -xz -C .
curl -L -s -S https://github.com/Requarks/wiki/releases/download/v$VERSION/node_modules.tar.gz | tar -f - -xz -C .
cp -n config.sample.yml config.yml

Anda dapat menjalankan perintah berikut untuk melihat versi Wiki.js. yang saat ini diinstal

node wiki --version
# 1.0.102

Setelah instalasi selesai, Anda akan diminta untuk menjalankan wizard konfigurasi.

Mulai panduan konfigurasi dengan menjalankan.

node wiki configure

Ini akan memberi tahu Anda untuk menavigasi ke http://localhost:3000untuk mengkonfigurasi Wiki.js. Jika Anda memiliki Nginx di depan Wiki.js, itu berarti Anda dapat membuka nama domain Anda (mis. http://wiki.example.com) Alih-alih pergi ke localhost.

Dengan menggunakan browser web Anda, navigasikan ke http://wiki.example.comdan ikuti instruksi di layar. Semua pengaturan yang dimasukkan selama wizard konfigurasi disimpan dalam config.ymlfile. Panduan konfigurasi akan secara otomatis memulai Wiki.js untuk Anda.

Instal dan setup manajer proses PM2

Secara default, Wiki.js tidak akan mulai secara otomatis setelah sistem reboot. Untuk membuatnya mulai saat boot, kita perlu menginstal dan mengatur manajer proses PM2.

Instal PM2 secara global melalui npm.

sudo npm install -g pm2

Periksa versinya.

pm2 -v
# 3.2.2

Arahkan ke folder root dokumen Anda jika Anda belum berada di sana dan hentikan Wiki.js.

cd /usr/local/www/wiki.example.com
node wiki stop

Mulai Wiki.js melalui PM2.

pm2 start server/index.js --name "Wiki.js"

Proses daftar dikelola oleh PM2.

pm2 list

Beri tahu PM2 untuk mengonfigurasikan dirinya sebagai layanan startup dengan menjalankan:

pm2 startup

Akhirnya, simpan konfigurasi PM2 saat ini dengan menjalankan perintah:

pm2 save

Contoh Wiki.js Anda sekarang berjalan sebagai proses latar belakang, menggunakan PM2 sebagai manajer prosesnya.



Leave a Comment

Menginstal pfSense di Server Cloud Vultr

Menginstal pfSense di Server Cloud Vultr

pfSense adalah alat yang ideal untuk administrator sistem yang ingin menambahkan beragam fitur ke jaringan mereka. Ini terutama merupakan open-sourc

Lindungi resolv.conf Dari DHCP Pada FreeBSD 10

Lindungi resolv.conf Dari DHCP Pada FreeBSD 10

Jika Anda menjalankan resolver Anda sendiri, atau ingin menggunakannya dari penyedia pihak ketiga, Anda mungkin menemukan bahwa file /etc/resolv.conf Anda sedang ditimpa oleh DHCP

Cara Memasang Automad CMS di FreeBSD 12

Cara Memasang Automad CMS di FreeBSD 12

Menggunakan Sistem yang Berbeda? Automad adalah open source berbasis sistem manajemen konten (CMS) dan mesin template yang ditulis dalam PHP. Kode sumber Automad i

Cara Memasang X-Cart 5 di FreeBSD 12

Cara Memasang X-Cart 5 di FreeBSD 12

Menggunakan Sistem yang Berbeda? X-Cart adalah platform eCommerce open-source yang sangat fleksibel dengan banyak fitur dan integrasi. Kode sumber X-Cart adalah hoste

Instal WordPress di OpenBSD 6.2

Instal WordPress di OpenBSD 6.2

Pendahuluan WordPress adalah sistem manajemen konten yang dominan di internet. Ini memberdayakan semuanya, mulai dari blog hingga situs web kompleks dengan konten dinamis

Setup dan Konfigurasi Murmur (Mumble Server) Pada FreeBSD 11

Setup dan Konfigurasi Murmur (Mumble Server) Pada FreeBSD 11

Murmur adalah perangkat lunak server resmi untuk protokol komunikasi suara Mumble. Implementasi resmi ini stabil dan efisien. Panduan ini wil

Cara Memasang WonderCMS di FreeBSD 12

Cara Memasang WonderCMS di FreeBSD 12

Menggunakan Sistem yang Berbeda? WonderCMS adalah open source, CMS file flat dan kecil yang ditulis dalam PHP. Kode sumber WonderCMS di-host di Github. Panduan ini wil

Cara Memasang Pagekit 1.0 CMS pada VPS FreeBSD 11 FAMP

Cara Memasang Pagekit 1.0 CMS pada VPS FreeBSD 11 FAMP

Menggunakan Sistem yang Berbeda? Pagekit 1.0 CMS adalah Content Management System (CMS) yang indah, modular, dapat diperpanjang dan ringan, dengan

Cara Mengaktifkan TLS 1.3 di Apache pada FreeBSD 12

Cara Mengaktifkan TLS 1.3 di Apache pada FreeBSD 12

Menggunakan Sistem yang Berbeda? TLS 1.3 adalah versi protokol Transport Layer Security (TLS) yang diterbitkan pada 2018 sebagai standar yang diusulkan dalam RFC 8446

Setup iRedMail di FreeBSD 10

Setup iRedMail di FreeBSD 10

Tutorial ini akan menunjukkan kepada Anda bagaimana menginstal groupware iRedMail pada instalasi baru FreeBSD 10. Anda harus menggunakan server dengan setidaknya satu gigabyte o

Cara Memasang Dolibarr di FreeBSD 12

Cara Memasang Dolibarr di FreeBSD 12

Menggunakan Sistem yang Berbeda? Dolibarr adalah perencanaan sumber daya perusahaan sumber terbuka (ERP) dan manajemen hubungan pelanggan (CRM) untuk bisnis. Dolibarr

Cara Memasang DokuWiki di FreeBSD 12

Cara Memasang DokuWiki di FreeBSD 12

Menggunakan Sistem yang Berbeda? DokuWiki adalah program wiki open source yang ditulis dalam PHP yang tidak memerlukan database. Ini menyimpan data dalam file teks. DokuWik

Cara Memasang Aplikasi Newsletter Mailtrain di FreeBSD 12

Cara Memasang Aplikasi Newsletter Mailtrain di FreeBSD 12

Menggunakan Sistem yang Berbeda? Mailtrain adalah aplikasi buletin self-host open-source yang dibangun di atas Node.js dan MySQL / MariaDB. Sumber mailtrains ada di GitHub. Ini

Menyiapkan Platform Penerbitan Ghost Profesional di OpenBSD 6

Menyiapkan Platform Penerbitan Ghost Profesional di OpenBSD 6

Ghost adalah pemula baru dan terbaik untuk menyaingi WordPress. Pengembangan tema cepat dan mudah dipelajari karena pengembang Ghost memutuskan untuk menggunakan keduanya

Menjalankan WordPress di OpenBSD 6.5 dengan OpenBSDs HTTPD

Menjalankan WordPress di OpenBSD 6.5 dengan OpenBSDs HTTPD

Pendahuluan Semakin dekat Anda memasang OpenBSD ke default dan tanpa banyak paket tambahan, semakin aman. Sementara yang lebih umum

Ubah ukuran Pool Penyimpanan ZFS di FreeBSD / TrueOS

Ubah ukuran Pool Penyimpanan ZFS di FreeBSD / TrueOS

Ketika memutakhirkan instance VPS di Vultr, sistem file Linux secara otomatis diubah ukurannya. Saat menjalankan FreeBSD dengan sistem file ZFS yang canggih, beberapa manual memperburuk

Server Surat Sederhana Dengan Postfix, Dovecot, Dan Saringan Di FreeBSD 10

Server Surat Sederhana Dengan Postfix, Dovecot, Dan Saringan Di FreeBSD 10

Tutorial ini akan menunjukkan kepada Anda cara mendapatkan server mail sederhana di FreeBSD 10, dengan Postfix sebagai MTA, Dovecot sebagai MDA dan Saringan untuk menyortir surat - di seluruh

Instal eSpeak di FreeBSD 12

Instal eSpeak di FreeBSD 12

Menggunakan Sistem yang Berbeda? ESpeak dapat menghasilkan file audio text-to-speech (TTS). Ini dapat bermanfaat karena berbagai alasan, seperti membuat Turin Anda sendiri

OpenBSD sebagai Solusi E-Commerce Dengan PrestaShop dan Apache

OpenBSD sebagai Solusi E-Commerce Dengan PrestaShop dan Apache

Pendahuluan Tutorial ini menunjukkan OpenBSD sebagai solusi e-commerce menggunakan PrestaShop dan Apache. Apache diperlukan karena PrestaShop memiliki UR yang kompleks

Menjalankan Nsd Dan Tidak Terbatas Pada OpenBSD 5.6

Menjalankan Nsd Dan Tidak Terbatas Pada OpenBSD 5.6

Dalam artikel ini, Anda akan belajar betapa mudah dan cepatnya memiliki caching Anda sendiri untuk menyelesaikan server DNS (tidak terikat), serta layanan DNS master / master

Cara Memasang Panel Kontrol Hosting Mudah di Ubuntu 16.04

Cara Memasang Panel Kontrol Hosting Mudah di Ubuntu 16.04

Pelajari langkah-langkah untuk memasang Panel Kontrol Hosting Mudah (EHCP) di Ubuntu 16.04 dengan panduan ini.

Wawasan tentang 26 Teknik Analisis Data Besar: Bagian 1

Wawasan tentang 26 Teknik Analisis Data Besar: Bagian 1

Wawasan tentang 26 Teknik Analisis Data Besar: Bagian 1

6 Hal yang Sangat Menggila dari Nintendo Switch

6 Hal yang Sangat Menggila dari Nintendo Switch

Banyak dari Anda tahu Switch keluar pada Maret 2017 dan fitur-fitur barunya. Bagi yang belum tahu, kami sudah menyiapkan daftar fitur yang membuat 'Switch' menjadi 'gadget yang wajib dimiliki'.

Janji Teknologi Yang Masih Belum Ditepati

Janji Teknologi Yang Masih Belum Ditepati

Apakah Anda menunggu raksasa teknologi untuk memenuhi janji mereka? periksa apa yang belum terkirim.

Fungsionalitas Lapisan Arsitektur Referensi Big Data

Fungsionalitas Lapisan Arsitektur Referensi Big Data

Baca blog untuk mengetahui berbagai lapisan dalam Arsitektur Big Data dan fungsinya dengan cara yang paling sederhana.

Bagaimana AI Dapat Membawa Otomatisasi Proses ke Tingkat Selanjutnya?

Bagaimana AI Dapat Membawa Otomatisasi Proses ke Tingkat Selanjutnya?

Baca ini untuk mengetahui bagaimana Kecerdasan Buatan menjadi populer di antara perusahaan skala kecil dan bagaimana hal itu meningkatkan kemungkinan untuk membuat mereka tumbuh dan memberi keunggulan pada pesaing mereka.

CAPTCHA: Berapa Lama Itu Bisa Tetap Menjadi Teknik yang Layak Untuk Perbedaan Human-AI?

CAPTCHA: Berapa Lama Itu Bisa Tetap Menjadi Teknik yang Layak Untuk Perbedaan Human-AI?

CAPTCHA telah berkembang cukup sulit bagi pengguna untuk dipecahkan dalam beberapa tahun terakhir. Apakah itu akan tetap efektif dalam deteksi spam dan bot di masa mendatang?

Singularitas Teknologi: Masa Depan Peradaban Manusia yang Jauh?

Singularitas Teknologi: Masa Depan Peradaban Manusia yang Jauh?

Saat Sains Berkembang dengan kecepatan tinggi, mengambil alih banyak upaya kita, risiko menundukkan diri kita pada Singularitas yang tidak dapat dijelaskan juga meningkat. Baca, apa arti singularitas bagi kita.

Telemedicine Dan Perawatan Kesehatan Jarak Jauh: Masa Depan Ada Di Sini

Telemedicine Dan Perawatan Kesehatan Jarak Jauh: Masa Depan Ada Di Sini

Apa itu telemedicine, perawatan kesehatan jarak jauh dan dampaknya terhadap generasi mendatang? Apakah itu tempat yang bagus atau tidak dalam situasi pandemi? Baca blog untuk menemukan tampilan!

Pernahkah Anda Bertanya-tanya Bagaimana Hacker Menghasilkan Uang?

Pernahkah Anda Bertanya-tanya Bagaimana Hacker Menghasilkan Uang?

Anda mungkin pernah mendengar bahwa peretas menghasilkan banyak uang, tetapi pernahkah Anda bertanya-tanya bagaimana cara mereka mendapatkan uang sebanyak itu? mari berdiskusi.