GNU/Linux >> Tutoriales Linux >  >> Fedora

Cómo instalar el foro NodeBB en Fedora 29

NodeBB es un software de foro basado en Node.js creado para la web moderna. Se basa en una base de datos MongoDB o Redis. Utiliza sockets web para interacciones instantáneas y notificaciones en tiempo real. NodeBB tiene muchas características modernas listas para usar, como la integración de redes sociales y las discusiones de transmisión. La funcionalidad adicional se habilita mediante el uso de complementos de terceros. NodeBB es un proyecto de código abierto que se puede encontrar en Github. En esta guía, lo guiaremos paso a paso por el proceso de instalación de NodeBB en el sistema operativo Fedora 29 usando Nginx como proxy inverso, MongoDB como base de datos y acme.sh y Let's Encrypt para HTTPS.

Requisitos

NodeBB requiere que se instale el siguiente software:

  • Versión de Node.js 6 o mayor
  • Versión de MongoDB 2.6 o superior o versión de Redis 2.8.9 o mayor
  • Versión de Nginx 1.3.13 o mayor
  • Git

NOTA : La instalación de las dependencias de NodeBB puede requerir más de 512 megabytes de memoria del sistema. Se recomienda habilitar una partición de intercambio para compensar si su sistema Linux tiene memoria insuficiente.

Requisitos

  • Un sistema Fedora 29 en ejecución con al menos 1 GB o RAM.
  • Nombre de dominio con A /AAAA registros configurados.
  • Un usuario no root con privilegios sudo.

Pasos iniciales

Compruebe su versión de Fedora:

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

Configurar la zona horaria:

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

Actualice los paquetes de su sistema operativo (software). Este es un primer paso importante porque garantiza que tenga las últimas actualizaciones y correcciones de seguridad para los paquetes de software predeterminados de su sistema operativo:

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

Instale algunos paquetes esenciales que son necesarios para la administración básica del sistema operativo Fedora:

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

Para simplificar, deshabilite SELinux y Firewall:

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

Paso 1:Instalar Node.js y npm

NodeBB se basa en Node.js. Vamos a instalar recomendado versión para NodeBB, que es la versión 8  en el momento de escribir este artículo. En Linux, tiene algunas opciones de instalación de Node.js:binarios de Linux (x86/x64), código fuente o mediante administradores de paquetes. Usaremos la opción Administración de paquetes que hace que la instalación y actualización de Node.js sea muy sencilla.

Descargue e instale la última versión de soporte a largo plazo (LTS) de Node.js desde el repositorio de Fedora:

sudo dnf -y install nodejs

Para compilar e instalar complementos nativos de npm, es posible que también deba instalar herramientas de compilación:

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

NOTAnpm se distribuye con Node.js, lo que significa que cuando descarga Node.js, automáticamente se instala npm en su sistema.

Verifique las versiones de Node.js y npm :

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

Npm es un proyecto separado de Node.js y tiende a actualizarse con más frecuencia. Como resultado, incluso si acaba de descargar Node.js (y, por lo tanto, npm), probablemente necesite actualizar su npm. Afortunadamente, npm sabe cómo actualizarse. Para actualizar su npm, escriba esto en su terminal:

sudo npm install -g [email protected]

Este comando actualizará npm a la última versión estable.

Vuelva a comprobar la versión de npm con:

npm -v
# 6.7.0

Y debería devolver los últimos números de versión.

Paso 2:Instalar y configurar MongoDB

NodeBB necesita una base de datos para almacenar sus datos y es compatible con MongoDB y Redis. En este tutorial, elegimos MongoDB como motor de almacenamiento de datos. Entonces, en los próximos pasos, descargaremos e instalaremos la base de datos MongoDB desde el repositorio rpm oficial de MongoDB:

Para instalar la versión estable del paquete MongoDB, emita el siguiente comando:

sudo dnf install -y mongodb mongodb-server

Compruebe la versión de MongoDB:

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

Iniciar y habilitar (configúralo para que se inicie al reiniciar ) Servicio MongoDB:

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

Compruebe el estado del servidor de la base de datos MongoDB ejecutando:

sudo systemctl status mongod.service
# active (running)

A continuación, cree la base de datos MongoDB y el usuario para NodeBB.

Primero conéctese al servidor MongoDB.

mongo

Cambiar al admin integrado base de datos.

> use admin

Cree un usuario administrativo.

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

NOTA: Reemplace el marcador de posición <Enter a secure password> con su propia contraseña seleccionada.

Agregue una nueva base de datos llamada nodebb .

> use nodebb

Se creará la base de datos y se cambiará el contexto a nodebb . A continuación, cree el nodebb usuario con los privilegios apropiados.

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

NOTA: Nuevamente, reemplace el marcador de posición <Enter a secure password> con su propia contraseña seleccionada.

Salga del shell de Mongo.

> quit()

Reinicie MongoDB y verifique que el usuario administrativo creado anteriormente pueda conectarse.

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

Si todo salió bien, su MongoDB debería estar instalado y preparado para NodeBB. En el próximo paso, nos ocuparemos de la instalación y configuración del servidor web.

Paso 3:instalar acme.sh cliente y obtener el certificado Let's Encrypt (opcional )

No es necesario proteger su foro de NodeBB con HTTPS, pero es una buena práctica para asegurar el tráfico de su sitio. Para obtener el certificado TLS de Let's Encrypt, utilizaremos el cliente acme.sh. Acme.sh es un software de shell de Unix puro para obtener certificados TLS de Let's Encrypt sin dependencias.

Descargue e instale 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 ~

Comprobar la versión de acme.sh:

acme.sh --version
# v2.8.0

Obtener RSAECC/ECDSA certificados para su dominio/nombre de host:

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

Si desea certificados falsos para las pruebas, puede agregar --staging flage a los comandos anteriores.

Después de ejecutar los comandos anteriores, sus certificadosteclas estará en:

  • Para RSA/home/username/example.com directorio.
  • Para ECC/ECDSA/home/username/example.com_ecc directorio.

Para enumerar sus certificados emitidos, puede ejecutar:

acme.sh --list

Cree un directorio para almacenar sus certificados. Usaremos /etc/letsencrypt directorio.

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

Instalar/copiar certificados en /etc/letsencrypt directorio.

# 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"

Todos los certificados se renovarán automáticamente cada 60 días.

Después de obtener los certificados, salga del usuario raíz y regrese al usuario sudo normal:

exit

Paso 4:Instalar y configurar Nginx

NodeBB puede funcionar bien con muchos servidores web. En este tutorial, seleccionamos Nginx.

Instale el paquete Nginx, emitiendo el siguiente comando:

sudo dnf install -y nginx

Después de la instalación, puede verificar la versión de Nginx ejecutando:

nginx -v
# 1.14.1

Iniciar y habilitar (configúralo para que se inicie al reiniciar ) Servicio Nginx:

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

Verifique el estado del servidor web Nginx ejecutando:

sudo systemctl status nginx.service
# active (running)

NodeBB se ejecuta de forma predeterminada en el puerto 4567 . Para evitar escribir http://example.com:4567 , configuraremos Nginx como proxy inverso para la aplicación NodeBB. Cada solicitud en el puerto 80443 (si se usa SSL ) se reenviará al puerto 4567 .

Ejecute sudo vim /etc/nginx/conf.d/nodebb.conf y configure Nginx como un 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";
}

}

Verifique la configuración de Nginx:

sudo nginx -t

Finalmente, para que los cambios surtan efecto, debemos volver a cargar Nginx:

sudo systemctl reload nginx.service

Paso 5:Instalar y configurar NodeBB

Cree un directorio raíz de documentos donde debe residir NodeBB:

sudo mkdir -p /var/www/nodebb

Navegue al directorio raíz del documento:

cd /var/www/nodebb

Cambiar la propiedad de /var/www/nodebb directorio a su_usuario.

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

NOTA:  Reemplace your_user en el comando anterior con su usuario no root que debería haber creado como requisito previo para este tutorial .

Clone el último repositorio de NodeBB en la carpeta raíz del documento:

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

Inicie el script de configuración ejecutando la aplicación con setup bandera. Contesta cada una de las preguntas:

./nodebb setup

Una vez completada la configuración de NodeBB, ejecute ./nodebb start para iniciar manualmente su servidor NodeBB:

./nodebb start

Después de ejecutar este comando, debería poder acceder a su nuevo foro en su navegador web:

Paso 6:Ejecute NodeBB como servicio del sistema

Cuando se inicia a través de ./nodebb start , NodeBB no volverá a iniciarse automáticamente cuando se reinicie el sistema. Para evitar eso, necesitaremos configurar NodeBB como un servicio del sistema.

Si se está ejecutando, detenga NodeBB:

./nodebb stop

Crear un nuevo nodebb usuario:

sudo useradd nodebb

Cambiar la propiedad de /var/www/nodebb directorio a nodebb usuario:

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

Crear nodebb.service archivo de configuración de la unidad systemd. Este archivo de unidad manejará el inicio de NodeBB deamon. Ejecute sudo vim /etc/systemd/system/nodebb.service y añade el siguiente contenido:

[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: Establezca el nombre de usuario y las rutas del directorio de acuerdo con los nombres elegidos.

Habilitar nodebb.service al reiniciar e inmediatamente iniciar nodebb.service:

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

Compruebe el nodebb.service estado:

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

¡Felicidades! Ha instalado e implementado correctamente la plataforma de debate NodeBB en el sistema Fedora 29. Debería poder acceder a su foro en su dominio e interactuar con su foro.

Enlaces

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

Fedora
  1. Cómo instalar el foro NodeBB en CentOS 7

  2. Cómo instalar Node.js en Fedora 35 / Fedora 34

  3. Cómo instalar Java 17 en Fedora 35

  4. Cómo instalar Notepad++ en Fedora 35

  5. Cómo instalar Wireshark en Fedora 35

Cómo instalar el servidor Fedora 34

Cómo instalar PowerShell en Fedora

Cómo instalar Skype en Fedora 34 / 35

Cómo instalar Discord en Fedora 34 / 35

Cómo instalar SQLite en Fedora 35

Cómo instalar Go en Fedora 35