데비안 9에서 NodeBB 포럼을 설치하는 방법

NodeBB 는 Node.js 기반 포럼입니다. 즉각적인 상호 작용 및 실시간 알림을 위해 웹 소켓을 사용합니다. NodeBB 소스 코드는 Github에서 공개적으로 호스팅됩니다 . 이 가이드는 Node.js, MongoDB를 데이터베이스로, Nginx를 리버스 프록시로, Acme.sh를 SSL 인증서로 사용하여 새로운 Debian 9 Vultr 인스턴스에서 NodeBB 설치 프로세스를 안내합니다.

요구 사항

NodeBB는 다음 소프트웨어가 설치되어 있어야합니다.

  • 힘내
  • Node.js 버전 6.9.0 이상
  • MongoDB 버전 2.6 이상
  • 니 진스
  • 최소 1024MB RAM
  • A/ AAAA레코드가 설정된 도메인 이름

시작하기 전에

데비안 버전을 확인하십시오.

lsb_release -ds
# Debian GNU/Linux 9.4 (stretch)

시스템이 최신인지 확인하십시오.

apt update && apt upgrade -y

필요한 패키지를 설치하십시오.

apt install -y sudo dirmngr git build-essential apt-transport-https

액세스 권한이 있는 새 non-root사용자 계정을 sudo만들고 전환하십시오.

adduser johndoe --gecos "John Doe"
usermod -aG sudo johndoe
su - johndoe

참고 : 대체 johndoe사용자 이름과 함께.

시간대를 설정하십시오.

sudo dpkg-reconfigure tzdata

Node.js 설치

NodeBB는 Node.js에 의해 구동되므로 설치해야합니다. Node.js의 현재 LTS 버전을 설치하는 것이 좋습니다.

NodeSource 저장소에서 Node.js를 설치하십시오.

curl -sL https://deb.nodesource.com/setup_10.x | sudo -E bash -
sudo apt install -y nodejs

Node.js 및 npm의 설치를 확인하십시오.

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

MongoDB 설치 및 구성

MongoDB는 NodeBB의 기본 데이터베이스입니다.

공식 MongoDB 저장소에서 MongoDB를 설치하십시오.

sudo apt-key adv --keyserver hkp://keyserver.ubuntu.com:80 --recv 9DA31620334BD75D9DCB49F368818C72E52529D4
echo "deb https://repo.mongodb.org/apt/debian stretch/mongodb-org/4.0 main" | sudo tee /etc/apt/sources.list.d/mongodb-org-4.0.list
sudo apt update
sudo apt install -y mongodb-org

버전을 확인하십시오.

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

MongoDB를 시작하고 활성화하십시오.

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

NodeBB 용 MongoDB 데이터베이스 및 사용자를 작성하십시오.

MongoDB에 연결하십시오.

mongo

내장 admin데이터베이스로 전환하십시오 .

> use admin

관리 사용자를 작성하십시오.

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

참고 : 자리 표시자를 <Enter a secure password>자신이 선택한 암호로 바꿉니다 .

라는 새 데이터베이스를 추가하십시오 nodebb.

> use nodebb

데이터베이스가 생성되고 컨텍스트가로 전환됩니다 nodebb. 그런 다음 nodebb적절한 권한으로 사용자를 작성하십시오 .

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

참고 : 다시 자리 표시자를 <Enter a secure password>자신이 선택한 암호로 바꿉니다.

Mongo 쉘을 종료하십시오.

> quit()

MongoDB를 다시 시작하고 이전에 작성된 관리자가 연결할 수 있는지 확인하십시오.

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

Nginx 설치 및 구성

공식 Nginx 저장소에서 최신 메인 라인 버전의 Nginx를 설치하십시오.

wget https://nginx.org/keys/nginx_signing.key
sudo apt-key add nginx_signing.key
rm nginx_signing.key
sudo -s
printf "deb https://nginx.org/packages/mainline/debian/ $(lsb_release -sc) nginx\ndeb-src https://nginx.org/packages/mainline/debian/ $(lsb_release -sc) nginx\n" >> /etc/apt/sources.list.d/nginx_mainline.list
exit
sudo apt update
sudo apt install -y nginx

버전을 확인하십시오.

sudo nginx -v
# nginx version: nginx/1.15.0

Nginx를 활성화하고 시작하십시오.

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

NodeBB는 기본적으로 port에서 실행됩니다 4567. 입력을 피하기 위해 http://example.com:4567Nginx를 NodeBB 응용 프로그램의 리버스 프록시로 구성합니다. 포트 80또는 443SSL을 사용하는 경우 모든 요청은 port 로 전달됩니다 4567.

sudo vim /etc/nginx/conf.d/nodebb.conf아래 표시된 기본 리버스 프록시 구성으로이를 실행하십시오 .

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";
  }

}

위의 구성에서 server_name도메인 / 호스트 이름으로 지시문을 업데이트하십시오 .

구성을 확인하십시오.

sudo nginx -t

Nginx를 다시로드하십시오.

sudo systemctl reload nginx.service

Acme.sh 클라이언트를 설치하고 Let 's Encrypt 인증서를 얻습니다 (선택 사항)

HTTPS로 포럼을 보호 할 필요는 없지만 사이트 트래픽을 보호합니다. Acme.sh는 Let 's Encrypt에서 종속 관계없이 SSL 인증서를 얻기위한 순수 Unix 셸 소프트웨어입니다.

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 your_email@example.com
cd ~
source ~/.bashrc

버전을 확인하십시오.

acme.sh --version
# v2.7.9

에 대한 RSA 및 ECDSA 인증서를 얻습니다 forum.example.com.

# 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 your_email@example.com --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 your_email@example.com --ocsp-must-staple --keylength ec-256

위 명령을 실행하면 인증서와 키가 다음 디렉토리에 있습니다.

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

Let 's Encrypt에서 인증서를 얻은 후에는 인증서를 사용하도록 Nginx를 구성해야합니다.

sudo vim /etc/nginx/conf.d/nodebb.conf다시 실행 하고 Nginx를 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";
  }

}

구성을 확인하십시오.

sudo nginx -t

Nginx를 다시로드하십시오.

sudo systemctl reload nginx.service

NodeBB 설치

문서 루트 디렉토리를 작성하십시오.

sudo mkdir -p /var/www/nodebb

/var/www/nodebb디렉토리의 소유권을로 변경하십시오 johndoe.

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

문서 루트 폴더로 이동하십시오.

cd /var/www/nodebb

최신 NodeBB를 문서 루트 폴더에 복제하십시오.

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

NodeBB setup 명령을 실행하고 프롬프트가 표시되면 각 질문에 대답하십시오.

./nodebb setup

NodeBB 설정이 완료된 후 NodeBB ./nodebb start서버를 수동으로 시작하도록 실행 하십시오.

./nodebb start

이 명령을 수행하면 웹 브라우저에서 포럼에 액세스 할 수 있습니다.

시스템 서비스로 NodeBB 실행

를 통해 ./nodebb start시작하면 시스템이 재부팅 될 때 NodeBB가 자동으로 다시 시작되지 않습니다. 이를 방지하려면 NodeBB를 시스템 서비스로 설정해야합니다.

실행중인 경우 NodeBB를 중지하십시오.

./nodebb stop

nodebb사용자를 작성하십시오 .

sudo adduser nodebb

/var/www/nodebb디렉토리 의 소유권을로 변경하십시오 nodebb.

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

시스템 nodebb.service단위 구성 파일을 작성 하십시오. 이 장치 파일은 NodeBB 데몬의 시작을 처리합니다. sudo vim /etc/systemd/system/nodebb.service다음 내용으로 파일을 실행 하고 채 웁니다.

[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

참고 : 선택한 이름에 따라 사용자 이름과 디렉토리 경로를 설정하십시오.

nodebb.service재부팅시 활성화 하고 즉시 시작하십시오 nodebb.service.

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

nodebb.service상태를 확인하십시오 .

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

그게 다야. NodeBB 인스턴스가 시작되어 실행 중입니다.

댓글 남기기

NTLite를 사용하여 업데이트로 Windows 사용자 지정 ISO를 만드는 방법

NTLite를 사용하여 업데이트로 Windows 사용자 지정 ISO를 만드는 방법

NTLite를 사용하여 Vultr 시스템과 호환되는 Windows 사용자 지정 ISO를 만드는 방법을 단계별로 설명합니다. 최신 드라이버와 업데이트 통합을 포함한 완벽 가이드.

Vultr에서 BGP 구성

Vultr에서 BGP 구성

Vultr BGP 설정을 위한 단계별 튜토리얼. ASN 할당부터 IP 라우팅 구성, BIRD 데몬 설정, FreeBSD 특이사항 및 실전 문제 해결 팁 7가지 포함한 최종 가이드

WsgiDAV를 사용하여 Debian 10에 WebDAV 배포

WsgiDAV를 사용하여 Debian 10에 WebDAV 배포

WebDAV (Web Distributed Authoring and Versioning)를 이용한 원격 파일 작성을 위한 프레임워크로, WsgiDAV 설치 및 구성 방법을 안내합니다.

데비안 7에 Mailcow 설치

데비안 7에 Mailcow 설치

Mailcow는 DoveCot, Postfix 및 기타 여러 오픈 소스 패키지를 기반으로 하는 경량 메일 서버입니다. 데비안에서 Mailcow 설치 방법을 안내합니다.

AI가 랜섬웨어 공격의 증가와 싸울 수 있습니까?

AI가 랜섬웨어 공격의 증가와 싸울 수 있습니까?

랜섬웨어 공격이 증가하고 있지만 AI가 최신 컴퓨터 바이러스를 처리하는 데 도움이 될 수 있습니까? AI가 답인가? AI boone 또는 bane인지 여기에서 읽으십시오.

ReactOS: 이것이 Windows의 미래입니까?

ReactOS: 이것이 Windows의 미래입니까?

오픈 소스이자 무료 운영 체제인 ReactOS가 최신 버전과 함께 제공됩니다. 현대 Windows 사용자의 요구 사항을 충족하고 Microsoft를 무너뜨릴 수 있습니까? 이 구식이지만 더 새로운 OS 환경에 대해 자세히 알아보겠습니다.

WhatsApp 데스크톱 앱 24*7을 통해 연결 유지

WhatsApp 데스크톱 앱 24*7을 통해 연결 유지

Whatsapp은 마침내 Mac 및 Windows 사용자용 데스크톱 앱을 출시했습니다. 이제 Windows 또는 Mac에서 Whatsapp에 쉽게 액세스할 수 있습니다. Windows 8 이상 및 Mac OS 10.9 이상에서 사용 가능

AI는 어떻게 프로세스 자동화를 다음 단계로 끌어올릴 수 있습니까?

AI는 어떻게 프로세스 자동화를 다음 단계로 끌어올릴 수 있습니까?

인공 지능이 소규모 회사에서 어떻게 인기를 얻고 있으며 어떻게 인공 지능이 성장할 가능성을 높이고 경쟁자가 우위를 점할 수 있는지 알아보려면 이 기사를 읽으십시오.

macOS Catalina 10.15.4 추가 업데이트로 인해 해결보다 더 많은 문제가 발생함

macOS Catalina 10.15.4 추가 업데이트로 인해 해결보다 더 많은 문제가 발생함

최근 Apple은 문제를 해결하기 위해 macOS Catalina 10.15.4 추가 업데이트를 출시했지만 이 업데이트로 인해 Mac 컴퓨터의 브릭킹으로 이어지는 더 많은 문제가 발생하는 것 같습니다. 자세히 알아보려면 이 기사를 읽어보세요.

빅데이터의 13가지 상용 데이터 추출 도구

빅데이터의 13가지 상용 데이터 추출 도구

빅데이터의 13가지 상용 데이터 추출 도구