Pandangan tentang 26 Teknik Analisis Data Besar: Bahagian 1
Pandangan tentang 26 Teknik Analisis Data Besar: Bahagian 1
Wiki.js adalah aplikasi wiki moden dan sumber terbuka dan bebas yang dibina di atas Node.js, MongoDB, Git dan Markdown. Kod sumber Wiki.js dihoskan secara terbuka di Github . Panduan ini akan menunjukkan kepada anda cara memasang Wiki.js pada instance Fedora 28 Vultr yang baru dengan menggunakan Node.js, MongoDB, PM2, Nginx, Git dan Acme.sh.
Keperluan untuk menjalankan Wiki.js adalah seperti berikut:
A
/ AAAA
rekod disediakanSemak versi OS.
cat /etc/fedora-release
# Fedora release 28 (Twenty Eight)
Buat akaun pengguna bukan root yang baru dengan akses sudo dan beralih kepadanya.
useradd -c "John Doe" johndoe && passwd johndoe
usermod -aG wheel johndoe
su - johndoe
CATATAN: Ganti johndoe
dengan nama pengguna anda.
Pastikan sistem anda terkini.
sudo dnf check-upgrade || sudo dnf upgrade -y
Sediakan zon waktu.
timedatectl list-timezones
sudo timedatectl set-timezone 'Region/City'
Pasang pakej yang diperlukan dan berguna.
sudo dnf install -y wget vim unzip bash-completion git
Untuk kesederhanaan, matikan SELinux dan Firewall.
sudo setenforce 0
sudo systemctl stop firewalld
sudo systemctl disable firewalld
Wiki.js memerlukan Node.js 6.9.0 atau lebih baru, jadi pertama-tama kita perlu memasang Node.js.
Pasang Node.js.
sudo dnf install -y nodejs
Periksa versi Node.js dan npm.
node -v && npm -v
# v8.11.3
# 5.6.0
Wiki.js menggunakan MongoDB sebagai enjin pangkalan data. Oleh itu, kita perlu memasang MongoDB pada pelayan kita.
Pasang MongoDB.
sudo dnf install -y mongodb mongodb-server
Semak versi MongoDB.
mongo --version | head -n 1 && mongod --version | head -n 1
# MongoDB shell version v3.6.3
# db version v3.6.3
Dayakan dan mulakan MongoDB.
sudo systemctl enable mongod.service
sudo systemctl start mongod.service
Wiki.js boleh berjalan tanpa pelayan web sebenar (seperti Nginx atau Apache). Walau bagaimanapun, sangat disyorkan untuk meletakkan pelayan web standard di depan Wiki.js. Ini memastikan anda boleh menggunakan ciri-ciri seperti SSL, pelbagai laman web, caching, dan lain-lain. Kami akan menggunakan Nginx dalam tutorial ini, tetapi mana-mana pelayan lain akan lakukan, anda hanya perlu mengkonfigurasinya dengan betul.
Pasang Nginx.
sudo dnf install -y nginx
Semak versi.
nginx -v
# nginx version: nginx/1.12.1
Dayakan dan mulailah Nginx.
sudo systemctl enable nginx.service
sudo systemctl start nginx.service
Konfigurasikan Nginx sebagai HTTP
atau atau HTTPS
(jika anda menggunakan SSL) proksi terbalik untuk aplikasi Wiki.js.
Jalankan sudo vim /etc/nginx/conf.d/wiki.js.conf
dan isi dengan konfigurasi proksi terbalik asas di bawah.
server {
listen [::]:80;
listen 80;
server_name wiki.example.com;
root /usr/share/nginx/html;
charset utf-8;
client_max_body_size 50M;
location /.well-known/acme-challenge/ {
allow all;
}
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 perkara yang perlu anda ubah dalam konfigurasi di atas adalah server_name
arahan, dan berpotensi menjadi proxy_pass
arahan jika anda memutuskan untuk mengkonfigurasi beberapa port selain 3000
. Wiki.js menggunakan port 3000
secara lalai.
Periksa konfigurasi.
sudo nginx -t
Muat semula Nginx.
sudo systemctl reload nginx.service
Mengamankan wiki anda dengan HTTPS
tidak diperlukan, tetapi amalan yang baik untuk menjamin trafik laman anda. Untuk mendapatkan sijil SSL dari Let's Encrypt, kami akan menggunakan klien Acme.sh. Acme.sh adalah perisian shell unix murni untuk mendapatkan sijil SSL dari Let's Encrypt dengan kebergantungan sifar. Itu menjadikannya sangat ringan berbanding dengan beberapa klien protokol ACME lain yang memerlukan banyak dependensi untuk berjalan dengan jayanya.
Muat turun dan pasang 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.sh
versi.
/etc/letsencrypt/acme.sh --version
# v2.7.9
Dapatkan sijil RSA dan ECDSA untuk wiki.example.com
.
# RSA 2048
sudo /etc/letsencrypt/acme.sh --issue --home /etc/letsencrypt -d wiki.example.com --webroot /usr/share/nginx/html --reloadcmd "sudo systemctl reload nginx.service" --accountemail [email protected] --ocsp-must-staple --keylength 2048
# ECDSA/ECC P-256
sudo /etc/letsencrypt/acme.sh --issue --home /etc/letsencrypt -d wiki.example.com --webroot /usr/share/nginx/html --reloadcmd "sudo systemctl reload nginx.service" --accountemail [email protected] --ocsp-must-staple --keylength ec-256
Setelah menjalankan perintah di atas, sijil dan kunci anda akan berada di:
/etc/letsencrypt/wiki.example.com
/etc/letsencrypt/wiki.example.com_ecc
CATATAN : Jangan lupa ganti wiki.example.com
dengan nama domain anda.
Selepas mendapatkan sijil dari Let's Encrypt, kita perlu mengkonfigurasi Nginx untuk mengambil kesempatan daripada mereka.
Jalankan sudo vim /etc/nginx/conf.d/wiki.js.conf
lagi dan konfigurasikan Nginx sebagai HTTPS
proksi terbalik.
server {
listen [::]:443 ssl http2;
listen 443 ssl http2;
listen [::]:80;
listen 80;
server_name wiki.example.com;
root /usr/share/nginx/html;
charset utf-8;
client_max_body_size 50M;
location /.well-known/acme-challenge/ {
allow all;
}
# 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;
}
}
Periksa konfigurasi.
sudo nginx -t
Muat semula Nginx.
sudo systemctl reload nginx.service
Buat folder root dokumen kosong, di mana Wiki.js harus dipasang.
sudo mkdir -p /var/www/wiki.example.com
Navigasi ke folder root dokumen.
cd /var/www/wiki.example.com
Tukar pemilikan /var/www/wiki.example.com
folder ke pengguna johndoe
.
sudo chown -R johndoe:johndoe /var/www/wiki.example.com
Dari /var/www/wiki.example.com
folder, jalankan arahan berikut untuk memuat turun dan memasang Wiki.js.
curl -sSo- https://wiki.js.org/install.sh | bash
Anda boleh menjalankan perintah berikut untuk melihat versi Wiki.js. yang sedang dipasang
node wiki --version
# 1.0.78
Setelah pemasangan selesai, anda akan diminta untuk menjalankan wizard konfigurasi.
Mulakan wizard konfigurasi dengan menjalankan.
node wiki configure
Ini akan memberitahu anda untuk menavigasi ke http://localhost:3000
untuk mengkonfigurasi Wiki.js. Jika anda mempunyai Nginx di hadapan Wiki.js, maka itu bermakna anda boleh membuka nama domain anda (contohnya http://wiki.example.com
) dan bukannya pergi localhost
.
Dengan menggunakan penyemak imbas web anda, arahkan ke http://wiki.example.com
dan ikuti arahan di skrin. Semua tetapan yang dimasukkan semasa wizard konfigurasi disimpan dalam config.yml
fail. Wizard konfigurasi akan memulakan Wiki.js secara automatik untuk anda.
Secara lalai, Wiki.js tidak akan dimulakan secara automatik selepas sistem reboot. Untuk menjadikannya bermula pada boot, kita perlu menyediakan pengurus proses PM2. PM2 dibundel dengan Wiki.js sebagai modul NPM tempatan, jadi kita tidak perlu memasang PM2 secara global.
Beritahu PM2 untuk mengkonfigurasi dirinya sebagai perkhidmatan permulaan dengan menjalankan:
/var/www/wiki.example.com/node_modules/pm2/bin/pm2 startup
Akhirnya, simpan konfigurasi PM2 semasa dengan menjalankan perintah: /var/www/wiki.example.com/node_modules/pm2/bin/pm2 save
Contoh Wiki.js anda berjalan sebagai proses latar belakang, menggunakan PM2 sebagai pengurus prosesnya.
Pandangan tentang 26 Teknik Analisis Data Besar: Bahagian 1
Ramai daripada anda tahu Switch akan keluar pada Mac 2017 dan ciri baharunya. Bagi yang tidak tahu, kami telah menyediakan senarai ciri yang menjadikan 'Tukar' sebagai 'gajet yang mesti ada'.
Adakah anda menunggu gergasi teknologi memenuhi janji mereka? semak apa yang masih belum dihantar.
Baca blog untuk mengetahui lapisan berbeza dalam Seni Bina Data Besar dan fungsinya dengan cara yang paling mudah.
Baca ini untuk mengetahui cara Kecerdasan Buatan semakin popular di kalangan syarikat berskala kecil dan cara ia meningkatkan kebarangkalian untuk menjadikan mereka berkembang dan memberikan pesaing mereka kelebihan.
CAPTCHA telah menjadi agak sukar untuk diselesaikan oleh pengguna dalam beberapa tahun kebelakangan ini. Adakah ia dapat kekal berkesan dalam pengesanan spam dan bot pada masa hadapan?
Apabila Sains Berkembang pada kadar yang pantas, mengambil alih banyak usaha kita, risiko untuk menundukkan diri kita kepada Ketunggalan yang tidak dapat dijelaskan juga meningkat. Baca, apakah makna ketunggalan bagi kita.
Apakah teleperubatan, penjagaan kesihatan jauh dan impaknya kepada generasi akan datang? Adakah ia tempat yang baik atau tidak dalam situasi pandemik? Baca blog untuk mencari paparan!
Anda mungkin pernah mendengar bahawa penggodam memperoleh banyak wang, tetapi pernahkah anda terfikir bagaimana mereka memperoleh wang seperti itu? Mari berbincang.
Baru-baru ini Apple mengeluarkan macOS Catalina 10.15.4 kemas kini tambahan untuk menyelesaikan masalah tetapi nampaknya kemas kini itu menyebabkan lebih banyak masalah yang membawa kepada pemusnahan mesin mac. Baca artikel ini untuk mengetahui lebih lanjut