GNU/Linux >> Linux Esercitazione >  >> Fedora

Come installare il forum NodeBB su Fedora 29

NodeBB è un software per forum basato su Node.js creato per il Web moderno. È costruito su un database MongoDB o Redis. Utilizza prese web per interazioni istantanee e notifiche in tempo reale. NodeBB ha molte funzionalità moderne pronte all'uso, come l'integrazione con i social network e le discussioni in streaming. Ulteriori funzionalità sono abilitate tramite l'uso di plug-in di terze parti. NodeBB è un progetto open source che può essere trovato su Github. In questa guida, ti illustreremo passo dopo passo il processo di installazione di NodeBB sul sistema operativo Fedora 29 utilizzando Nginx come proxy inverso, MongoDB come database e acme.sh e Let's Encrypt per HTTPS.

Requisiti

NodeBB richiede l'installazione del seguente software:

  • Versione di Node.js 6 o superiore
  • Versione MongoDB 2.6 o successiva o versione Redis 2.8.9 o superiore
  • Versione Nginx 1.3.13 o superiore
  • Git

NOTA : L'installazione delle dipendenze di NodeBB potrebbe richiedere più di 512 megabyte di memoria di sistema. Ti consigliamo di abilitare una partizione di swap per compensare se il tuo sistema Linux ha memoria insufficiente.

Prerequisiti

  • Un sistema Fedora 29 in esecuzione con almeno 1 GB o RAM.
  • Nome di dominio con A /AAAA record impostati.
  • Un utente non root con privilegi sudo.

Passaggi iniziali

Controlla la tua versione di Fedora:

cat /etc/fedora-release
# Fedora release 29 (Twenty Nine)

Imposta il fuso orario:

timedatectl list-timezones
sudo timedatectl set-timezone 'Region/City'

Aggiorna i pacchetti del tuo sistema operativo (software). Questo è un primo passo importante perché ti assicura di avere gli ultimi aggiornamenti e correzioni di sicurezza per i pacchetti software predefiniti del tuo sistema operativo:

sudo dnf check-upgrade || sudo dnf upgrade -y

Installa alcuni pacchetti essenziali che sono necessari per l'amministrazione di base del sistema operativo Fedora:

sudo dnf install -y curl wget vim bash-completion git socat

Per semplicità, disabilita SELinux e Firewall:

sudo setenforce 0; sudo systemctl stop firewalld.service; sudo systemctl disable firewalld.service

Passaggio 1:installa Node.js e npm

NodeBB è basato su Node.js. Stiamo per installare consigliato versione per NodeBB che è versione 8  nel momento in cui scrivo. Su Linux, hai alcune opzioni di installazione di Node.js:Linux Binaries (x86/x64), Source Code o tramite Package Manager. Utilizzeremo l'opzione di gestione dei pacchetti che rende l'installazione e l'aggiornamento di Node.js un gioco da ragazzi.

Scarica e installa l'ultima versione di supporto a lungo termine (LTS) di Node.js dal repo Fedora:

sudo dnf -y install nodejs

Per compilare e installare componenti aggiuntivi nativi da npm potresti anche dover installare gli strumenti di compilazione:

sudo dnf install -y gcc-c++ make
# or
# sudo dnf groupinstall -y 'Development Tools'

NOTAnpm è distribuito con Node.js, il che significa che quando scarichi Node.js, ottieni automaticamente npm installato sul tuo sistema.

Controlla le versioni di Node.js e npm :

node -v && npm -v
# v10.15.0
# 6.4.1

Npm è un progetto separato da Node.js e tende ad aggiornarsi più frequentemente. Di conseguenza, anche se hai appena scaricato Node.js (e quindi npm), probabilmente dovrai aggiornare il tuo npm. Fortunatamente, npm sa come aggiornarsi! Per aggiornare il tuo npm, digita questo nel tuo terminale:

sudo npm install -g [email protected]

Questo comando aggiornerà npm all'ultima versione stabile.

Ricontrolla la versione npm con:

npm -v
# 6.7.0

E dovrebbe restituire i numeri di versione più recenti.

Fase 2:installa e configura MongoDB

NodeBB ha bisogno di un database per archiviare i suoi dati e supporta MongoDB e Redis. In questo tutorial, abbiamo scelto MongoDB come motore dell'archivio dati. Quindi, nei prossimi passaggi, scaricheremo e installeremo il database MongoDB dal repository rpm MongoDB ufficiale:

Per installare la versione stabile del pacchetto MongoDB, immetti il ​​seguente comando:

sudo dnf install -y mongodb mongodb-server

Controlla la versione di MongoDB:

mongo --version | head -n 1 && mongod --version | head -n 1
# MongoDB shell version v4.0.1
# db version v4.0.1

Avvia e abilita (impostalo per l'avvio al riavvio ) Servizio MongoDB:

sudo systemctl start mongod.service
sudo systemctl enable mongod.service

Controlla lo stato del server di database MongoDB eseguendo:

sudo systemctl status mongod.service
# active (running)

Quindi, crea il database e l'utente MongoDB per NodeBB.

Connettiti prima al server MongoDB.

mongo

Passa all'admin integrato banca dati.

> use admin

Crea un utente amministrativo.

> db.createUser( { user: "admin", pwd: "<Enter a secure password>", roles: [ { role: "readWriteAnyDatabase", db: "admin" }, { role: "userAdminAnyDatabase", db: "admin" } ] } )

NOTA: Sostituisci il segnaposto <Enter a secure password> con la tua password selezionata.

Aggiungi un nuovo database chiamato nodebb .

> use nodebb

Il database verrà creato e il contesto passerà a nodebb . Quindi crea il nodebb utente con i privilegi appropriati.

> db.createUser( { user: "nodebb", pwd: "<Enter a secure password>", roles: [ { role: "readWrite", db: "nodebb" }, { role: "clusterMonitor", db: "admin" } ] } )

NOTA: Ancora una volta, sostituisci il segnaposto <Enter a secure password> con la tua password selezionata.

Esci dalla shell Mongo.

> quit()

Riavvia MongoDB e verifica che l'utente amministrativo creato in precedenza possa connettersi.

sudo systemctl restart mongod.service
mongo -u admin -p your_password --authenticationDatabase=admin

Se tutto è andato bene, il tuo MongoDB dovrebbe essere installato e preparato per NodeBB. Nel passaggio successivo, ci occuperemo dell'installazione e della configurazione del server web.

Passaggio 3:installa acme.sh client e ottenere il certificato Let's Encrypt (opzionale )

Proteggere il tuo forum NodeBB con HTTPS non è necessario, ma è una buona pratica per proteggere il traffico del tuo sito. Per ottenere il certificato TLS da Let's Encrypt utilizzeremo il client acme.sh. Acme.sh è un puro software shell unix per ottenere certificati TLS da Let's Encrypt con zero dipendenze.

Scarica e installa acme.sh:

sudo su - root
git clone https://github.com/Neilpang/acme.sh.git
cd acme.sh 
./acme.sh --install --accountemail [email protected]
source ~/.bashrc
cd ~

Controlla la versione di acme.sh:

acme.sh --version
# v2.8.0

Ottieni RSAECC/ECDSA certificati per il tuo dominio/nome host:

# RSA 2048
acme.sh --issue --standalone -d example.com --keylength 2048
# ECDSA
acme.sh --issue --standalone -d example.com --keylength ec-256

Se desideri certificati falsi per i test, puoi aggiungere --staging segnala i comandi precedenti.

Dopo aver eseguito i comandi precedenti, i tuoi certificatichiavi sarà in:

  • Per RSA/home/username/example.com directory.
  • Per ECC/ECDSA/home/username/example.com_ecc directory.

Per elencare i certificati emessi puoi eseguire:

acme.sh --list

Crea una directory per archiviare i tuoi certificati. Useremo /etc/letsencrypt directory.

mkdir -p /etc/letsecnrypt/example.com
sudo mkdir -p /etc/letsencrypt/example.com_ecc

Installa/copia i certificati nella directory /etc/letsencrypt.

# RSA
acme.sh --install-cert -d example.com --cert-file /etc/letsencrypt/example.com/cert.pem --key-file /etc/letsencrypt/example.com/private.key --fullchain-file /etc/letsencrypt/example.com/fullchain.pem --reloadcmd "sudo systemctl reload nginx.service"
# ECC/ECDSA
acme.sh --install-cert -d example.com --ecc --cert-file /etc/letsencrypt/example.com_ecc/cert.pem --key-file /etc/letsencrypt/example.com_ecc/private.key --fullchain-file /etc/letsencrypt/example.com_ecc/fullchain.pem --reloadcmd "sudo systemctl reload nginx.service"

Tutti i certificati verranno rinnovati automaticamente ogni 60 giorni.

Dopo aver ottenuto i certificati, esci dall'utente root e torna al normale utente sudo:

exit

Fase 4:installa e configura Nginx

NodeBB può funzionare correttamente con molti server web. In questo tutorial, abbiamo selezionato Nginx.

Installa il pacchetto Nginx, emetti il ​​seguente comando:

sudo dnf install -y nginx

Dopo l'installazione, puoi verificare la versione di Nginx eseguendo:

nginx -v
# 1.14.1

Avvia e abilita (impostalo per l'avvio al riavvio ) Servizio Nginx:

sudo systemctl start nginx.service
sudo systemctl enable nginx.service

Controlla lo stato del server web Nginx eseguendo:

sudo systemctl status nginx.service
# active (running)

NodeBB per impostazione predefinita viene eseguito sulla porta 4567 . Per evitare di digitare http://example.com:4567 , configureremo Nginx come proxy inverso per l'applicazione NodeBB. Ogni richiesta in porto 80443 (se viene utilizzato SSL ) verrà inoltrato alla porta 4567 .

Esegui sudo vim /etc/nginx/conf.d/nodebb.conf e configura Nginx come proxy inverso HTTPS.

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

server_name forum.example.com;

client_max_body_size 50M;

# RSA
ssl_certificate /etc/letsencrypt/example.com/fullchain.pem;
ssl_certificate_key /etc/letsencrypt/example.com/private.key;
# ECDSA
ssl_certificate /etc/letsencrypt/example.com_ecc/fullchain.pem;
ssl_certificate_key /etc/letsencrypt/example.com_ecc/private.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";
}

}

Controlla la configurazione di Nginx:

sudo nginx -t

Infine, affinché le modifiche abbiano effetto, dobbiamo ricaricare Nginx:

sudo systemctl reload nginx.service

Fase 5:installa e configura NodeBB

Crea una directory principale del documento in cui dovrebbe risiedere NodeBB:

sudo mkdir -p /var/www/nodebb

Vai alla directory principale del documento:

cd /var/www/nodebb

Modifica la proprietà del /var/www/nodebb directory a tuo_utente.

sudo chown -R [your_user]:[your_user] /var/www/nodebb

NOTA:  Sostituisci your_user nel comando precedente con il tuo utente non root che avresti dovuto creare come prerequisito per questo tutorial .

Clona l'ultimo repository NodeBB nella cartella principale del documento:

git clone -b v1.11.x https://github.com/NodeBB/NodeBB.git .

Avvia lo script di configurazione eseguendo l'app con setup bandiera. Rispondi a ciascuna delle domande:

./nodebb setup

Al termine della configurazione di NodeBB, esegui ./nodebb start per avviare manualmente il tuo server NodeBB:

./nodebb start

Dopo aver eseguito questo comando, dovresti essere in grado di accedere al tuo nuovissimo forum nel tuo browser web:

Passaggio 6:esegui NodeBB come servizio di sistema

All'avvio tramite ./nodebb start , NodeBB non si riavvierà automaticamente al riavvio del sistema. Per evitarlo, dovremo configurare NodeBB come servizio di sistema.

Se in esecuzione, arresta NodeBB:

./nodebb stop

Crea un nuovo nodebb utente:

sudo useradd nodebb

Modifica la proprietà del /var/www/nodebb directory in nodebb utente:

sudo chown -R nodebb:nodebb /var/www/nodebb

Crea nodebb.service file di configurazione dell'unità systemd. Questo file di unità gestirà l'avvio di NodeBB demone. Esegui sudo vim /etc/systemd/system/nodebb.service e aggiungi i seguenti contenuti:

[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

NOTA: Imposta il nome utente e i percorsi della directory in base ai nomi scelti.

Abilita nodebb.service al riavvio e avvia immediatamente nodebb.service:

sudo systemctl enable nodebb.service
sudo systemctl start nodebb.service

Controlla il nodebb.service stato:

sudo systemctl status nodebb.service
sudo systemctl is-enabled nodebb.service

Congratulazioni! Hai installato e distribuito con successo la piattaforma di discussione NodeBB sul sistema Fedora 29. Dovresti essere in grado di accedere al tuo forum sul tuo dominio e interagire con il tuo forum.

Link

  • https://nodebb.org/
  • https://docs.nodebb.org/
  • https://github.com/NodeBB/NodeBB

Fedora
  1. Come installare il forum NodeBB su CentOS 7

  2. Come installare Node.js su Fedora 35 / Fedora 34

  3. Come installare Java 17 in Fedora 35

  4. Come installare Notepad++ su Fedora 35

  5. Come installare Wireshark su Fedora 35

Come installare Fedora 34 Server

Come installare PowerShell su Fedora

Come installare Skype su Fedora 34/35

Come installare Discord su Fedora 34/35

Come installare SQLite su Fedora 35

Come installare Vai su Fedora 35