Kërkesat
Perpara se te fillosh
Instaloni Node.js
Instaloni dhe konfiguroni MongoDB
Instaloni dhe konfiguroni Nginx
Instaloni klientin Acme.sh dhe merrni një certifikatë Let's Encrypt (opsionale)
Instaloni NodeBB
Ekzekutoni NodeBB si një shërbim sistemi
NodeBB është një forum i bazuar në Node.js. Ai përdor prizat në internet për ndërveprime të menjëhershme dhe njoftime në kohë reale. Kodi burimor NodeBB është i pritur publikisht në Github . Ky udhëzues do t'ju përcjellë në procesin e instalimit të NodeBB në një shembull të ri Fedora 28 Vultr duke përdorur Node.js, MongoDB si bazë të dhënash, Nginx si një përfaqësues të kundërt dhe Acme.sh për certifikatat SSL.
Kërkesat
NodeBB kërkon që të instalohet softueri i mëposhtëm:
- Git
- Node.js versioni 6.9.0 ose më i ri
- Versioni MongoDB 2.6 ose më i ri
- Nginx
- Minimumi 1024 MB RAM
- Emri i domenit me
A
/ AAAA
konfigurimin e regjistrimeve
Perpara se te fillosh
Kontrolloni versionin Fedora.
cat /etc/fedora-release
# Fedora release 28 (Twenty Eight)
Krijoni një llogari të re përdoruesi jo-root me sudo
akses dhe kaloni në të.
useradd -c "John Doe" johndoe && passwd johndoe
usermod -aG wheel johndoe
su - johndoe
SHËNIM : Zëvendësojeni johndoe
me emrin tuaj të përdoruesit.
Vendosni zonën kohore.
timedatectl list-timezones
sudo timedatectl set-timezone 'Region/City'
Sigurohuni që sistemi juaj të jetë i përditësuar.
sudo dnf check-upgrade || sudo dnf upgrade -y
Instaloni paketat e nevojshme.
sudo dnf install -y git wget vim gcc-c++ make
Për thjeshtësi, çaktivizoni SELinux dhe Firewall.
sudo setenforce 0
sudo systemctl stop firewalld
sudo systemctl disable firewalld
Instaloni Node.js
NodeBB drejtohet nga Node.js dhe kështu duhet të instalohet. Rekomandohet instalimi i versionit aktual LTS të Node.js.
Instaloni Node.js.
sudo dnf install -y nodejs
Verifikoni instalimin e Node.js dhe npm.
node -v && npm -v
# v8.11.3
# 5.6.0
MongoDB është baza e të dhënave e paracaktuar për NodeBB.
Instaloni MongoDB.
sudo dnf install -y mongodb mongodb-server
Kontrolloni versionin.
mongo --version | head -n 1 && mongod --version | head -n 1
# MongoDB shell version v3.6.3
# db version v3.6.3
Aktivizo dhe nis shërbimin MongoDB.
sudo systemctl enable mongod.service
sudo systemctl start mongod.service
Krijoni një bazë të dhënash MongoDB dhe përdorues për NodeBB.
Së pari lidheni me serverin MongoDB.
mongo
Kaloni në admin
bazën e të dhënave të integruar .
> use admin
Krijo një përdorues administrativ.
> db.createUser( { user: "admin", pwd: "<Enter a secure password>", roles: [ { role: "readWriteAnyDatabase", db: "admin" }, { role: "userAdminAnyDatabase", db: "admin" } ] } )
SHËNIM: Zëvendësoni mbajtësin e vendit <Enter a secure password>
me fjalëkalimin tuaj të zgjedhur.
Shtoni një bazë të dhënash të re të quajtur nodebb
.
> use nodebb
Baza e të dhënave do të krijohet dhe konteksti do të kalojë në nodebb
. Më pas krijoni nodebb
përdoruesin me privilegjet e duhura.
> db.createUser( { user: "nodebb", pwd: "<Enter a secure password>", roles: [ { role: "readWrite", db: "nodebb" }, { role: "clusterMonitor", db: "admin" } ] } )
SHËNIM: Përsëri, zëvendësoni mbajtësin e vendit <Enter a secure password>
me fjalëkalimin tuaj të zgjedhur.
Dilni nga guaska Mongo.
> quit()
Rinisni MongoDB dhe verifikoni që përdoruesi administrativ i krijuar më parë mund të lidhet.
sudo systemctl restart mongod.service
mongo -u admin -p your_password --authenticationDatabase=admin
Instaloni Nginx.
sudo dnf install -y nginx
Kontrolloni versionin.
sudo nginx -v
# nginx version: nginx/1.12.1
Aktivizo dhe nis Nginx.
sudo systemctl enable nginx.service
sudo systemctl start nginx.service
NodeBB si parazgjedhje funksionon në port 4567
. Për të shmangur shtypjen http://example.com:4567
, ne do të konfigurojmë Nginx si një përfaqësues të kundërt për aplikacionin NodeBB. Çdo kërkesë në port 80
ose 443
( nëse përdoret SSL ) do të përcillet në port 4567
.
Ekzekutoni sudo vim /etc/nginx/conf.d/nodebb.conf
dhe plotësoni atë me konfigurimin bazë të përfaqësuesit të kundërt më poshtë.
server {
listen [::]:80;
listen 80;
server_name forum.example.com;
root /usr/share/nginx/html;
client_max_body_size 50M;
location /.well-known/acme-challenge/ {
allow all;
}
location / {
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 $scheme;
proxy_set_header Host $http_host;
proxy_hide_header X-Powered-By;
proxy_set_header X-Nginx-Proxy true;
proxy_pass http://127.0.0.1:4567;
proxy_redirect off;
# Socket.IO Support
proxy_http_version 1.1;
proxy_set_header Upgrade $http_upgrade;
proxy_set_header Connection "upgrade";
}
}
Në konfigurimin e mësipërm, përditësoni server_name
direktivën me domenin/emrin tuaj të hostit.
Kontrolloni konfigurimin.
sudo nginx -t
Rifresko Nginx.
sudo systemctl reload nginx.service
Instaloni klientin Acme.sh dhe merrni një certifikatë Let's Encrypt (opsionale)
Sigurimi i forumit tuaj me HTTPS nuk është i nevojshëm, por do të sigurojë trafikun e faqes suaj. Acme.sh është një softuer i pastër i guaskës unix për marrjen e certifikatave SSL nga Let's Encrypt me zero varësi.
Shkarkoni dhe instaloni 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 ~
source ~/.bashrc
Kontrolloni versionin.
/etc/letsencrypt/acme.sh --version
# v2.7.9
Merrni certifikatat RSA dhe ECDSA për forum.example.com
domenin/emrin e hostit.
# RSA 2048
sudo /etc/letsencrypt/acme.sh --issue --home /etc/letsencrypt -d forum.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 forum.example.com --webroot /usr/share/nginx/html --reloadcmd "sudo systemctl reload nginx.service" --accountemail [email protected] --ocsp-must-staple --keylength ec-256
Pas ekzekutimit të komandave të mësipërme, certifikatat dhe çelësat tuaj do të jenë në drejtoritë e mëposhtme:
- RSA:
/etc/letsencrypt/forum.example.com
- ECC/ECDSA:
/etc/letsencrypt/forum.example.com_ecc
Pas marrjes së certifikatave nga Let's Encrypt, duhet të konfigurojmë Nginx për t'i përdorur ato.
Ekzekutoni sudo vim /etc/nginx/conf.d/nodebb.conf
përsëri dhe konfiguroni Nginx si një përfaqësues të kundërt HTTPS.
server {
listen [::]:443 ssl http2;
listen 443 ssl http2;
listen [::]:80;
listen 80;
server_name forum.example.com;
root /usr/share/nginx/html;
client_max_body_size 50M;
location /.well-known/acme-challenge/ {
allow all;
}
# RSA
ssl_certificate /etc/letsencrypt/forum.example.com/fullchain.cer;
ssl_certificate_key /etc/letsencrypt/forum.example.com/forum.example.com.key;
# ECDSA
ssl_certificate /etc/letsencrypt/forum.example.com_ecc/fullchain.cer;
ssl_certificate_key /etc/letsencrypt/forum.example.com_ecc/forum.example.com.key;
location / {
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 $scheme;
proxy_set_header Host $http_host;
proxy_set_header X-NginX-Proxy true;
proxy_pass http://127.0.0.1:4567;
proxy_redirect off;
# Socket.IO Support
proxy_http_version 1.1;
proxy_set_header Upgrade $http_upgrade;
proxy_set_header Connection "upgrade";
}
}
Kontrolloni konfigurimin.
sudo nginx -t
Rifresko Nginx.
sudo systemctl reload nginx.service
Instaloni NodeBB
Krijoni një direktori rrënjësore të dokumentit.
sudo mkdir -p /var/www/nodebb
Ndrysho pronësinë e /var/www/nodebb
drejtorisë në johndoe
.
sudo chown -R johndoe:johndoe /var/www/nodebb
Navigoni te dosja rrënjë e dokumentit.
cd /var/www/nodebb
Klononi NodeBB-në më të fundit në dosjen rrënjë të dokumentit.
git clone -b v1.10.x https://github.com/NodeBB/NodeBB.git .
Ekzekutoni komandën e konfigurimit NodeBB dhe përgjigjuni çdo pyetjeje kur ju kërkohet.
./nodebb setup
Pasi të përfundojë konfigurimi i NodeBB, vraponi ./nodebb start
për të nisur manualisht serverin tuaj NodeBB.
./nodebb start
Pas kësaj komande, do të keni mundësi të hyni në forumin tuaj në shfletuesin tuaj të internetit.
Ekzekutoni NodeBB si një shërbim sistemi
Kur niset përmes ./nodebb start
, NodeBB nuk do të ndizet përsëri automatikisht kur sistemi të rindizet. Për ta shmangur këtë, do të na duhet të konfigurojmë NodeBB si një shërbim sistemi.
Nëse po funksionon, ndaloni NodeBB.
./nodebb stop
Krijo një nodebb
përdorues të ri .
sudo useradd nodebb
Ndrysho pronësinë e /var/www/nodebb
drejtorisë në nodebb
përdorues.
sudo chown -R nodebb:nodebb /var/www/nodebb
Krijo nodebb.service
skedarin e konfigurimit të njësisë systemd. Ky skedar i njësisë do të trajtojë fillimin e deamonit NodeBB. Ekzekutoni sudo vim /etc/systemd/system/nodebb.service
dhe plotësoni skedarin me përmbajtjen e mëposhtme.
[Unit]
Description=NodeBB
Documentation=https://docs.nodebb.org
After=system.slice multi-user.target mongod.service
[Service]
Type=forking
User=nodebb
StandardOutput=syslog
StandardError=syslog
SyslogIdentifier=nodebb
Environment=NODE_ENV=production
WorkingDirectory=/var/www/nodebb
PIDFile=/var/www/nodebb/pidfile
ExecStart=/usr/bin/env node loader.js
Restart=always
[Install]
WantedBy=multi-user.target
SHËNIM: Vendosni shtigjet e emrit të përdoruesit dhe të drejtorisë sipas emrave të zgjedhur.
Aktivizojeni nodebb.service
në rindezje dhe filloni menjëherë nodebb.service
.
sudo systemctl enable nodebb.service
sudo systemctl start nodebb.service
Kontrolloni nodebb.service
statusin.
sudo systemctl status nodebb.service
sudo systemctl is-enabled nodebb.service
Kjo eshte. Shembulli juaj NodeBB tani është në funksionim.