如何在CentOS 7上安装Oxwall
Oxwall是一个开源社交网络软件平台,可用于免费构建自定义社交网站(SNS)。在这篇文章中,
NodeBB是一个基于Node.js的论坛。它利用Web套接字进行即时交互和实时通知。NodeBB源代码公开托管在Github上。本指南将引导您在新的Ubuntu 18.04 LTS Vultr实例上使用Node.js,MongoDB作为数据库,Nginx作为反向代理以及Acme.sh获得SSL证书,以完成NodeBB的安装过程。
NodeBB要求安装以下软件:
A
/ AAAA
记录的域名检查Ubuntu版本。
lsb_release -ds
# Ubuntu 18.04 LTS
创建一个non-root
具有sudo
访问权限的新用户帐户并切换到该帐户。
adduser johndoe --gecos "John Doe"
usermod -aG sudo johndoe
su - johndoe
注意:用您的用户名替换johndoe
。
设置时区。
sudo dpkg-reconfigure tzdata
确保您的系统是最新的。
sudo apt update && sudo apt upgrade -y
安装必要的软件包。
sudo apt install -y git build-essential apt-transport-https
NodeBB由Node.js驱动,因此需要安装。建议安装当前LTS版本的Node.js。
从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是NodeBB的默认数据库。
安装MongoDB。
sudo apt install -y mongodb
检查版本。
mongo --version | head -n 1 && mongod --version | head -n 1
# MongoDB shell version v3.6.3
# db version v3.6.3
为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 Shell。
> quit()
重新启动MongoDB,并验证先前创建的管理用户是否可以连接。
sudo systemctl restart mongodb.service
mongo -u admin -p your_password --authenticationDatabase=admin
从官方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/ubuntu/ $(lsb_release -sc) nginx\ndeb-src https://nginx.org/packages/mainline/ubuntu/ $(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:4567
,我们将Nginx配置为NodeBB应用程序的反向代理。port 80
或443
(如果使用SSL)上的每个请求都将转发到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
不需要使用HTTPS保护论坛安全,但这可以保护您网站的流量。Acme.sh是一个纯unix shell软件,用于以零依赖关系从Let's Encrypt获得SSL证书。
下载并安装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
检查版本。
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 [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
运行上述命令后,您的证书和密钥将位于以下目录中:
/etc/letsencrypt/forum.example.com
/etc/letsencrypt/forum.example.com_ecc
从“加密”获取证书后,我们需要配置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
创建一个文档根目录。
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 start
以手动启动NodeBB服务器。
./nodebb start
执行此命令后,您将能够在Web浏览器中访问您的论坛。
当通过启动时./nodebb start
,NodeBB将不会在系统重新启动时自动再次启动。为避免这种情况,我们需要将NodeBB设置为系统服务。
如果正在运行,请停止NodeBB。
./nodebb stop
创建一个新的非特权nodebb
用户。
sudo adduser nodebb
将/var/www/nodebb
目录的所有权更改为nodebb
user。
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实例现已启动并正在运行。
Oxwall是一个开源社交网络软件平台,可用于免费构建自定义社交网站(SNS)。在这篇文章中,
使用其他系统?Review Board是一个免费且开源的工具,用于检查源代码,文档,图像等。这是基于网络的软件战
使用其他系统?October 1.0 CMS是基于Laravel框架构建的简单,可靠,免费和开源的内容管理系统(CMS)
Xubuntu是XFCE + Ubuntu!XFCE是Ubuntu的轻量级GUI /桌面。Vultr服务器需要其他依赖项,默认情况下未安装这些依赖项。
使用其他系统?Monica是一个开源的个人关系管理系统。可以将其视为CRM(销售团队使用的一种流行工具
简介SSL(代表安全套接字层)及其后续版本TLS(代表传输层安全性)是需要加密的加密协议。
使用其他系统?MODX Revolution是一种快速,灵活,可扩展,免费和开源的企业级内容管理系统(CMS),由
朱莉娅(Julia)通常称为JuliaLang,是一种用于数值计算的编程语言。Julia的速度和C一样快,但是却不牺牲可读性
Ruby on Rails(RoR)是用Ruby编程语言编写的框架,可让您将Ruby与HTML,CSS和类似的程序结合使用。
使用其他系统?Anchor是用PHP编写的轻量级开源博客CMS。Anchors源代码托管在GitHub上。本指南将向您展示
简介Debian 10(Buster)是Debian 9(Stretch)的后继产品。它于2019年7月6日发布。在本教程中,我们将升级一个existin
在Linux服务器上正确设置日期和时间非常重要。您的服务器日志和其他重要信息都将反映时区
使用其他系统?Taiga是用于项目管理的免费和开源应用程序。与其他项目管理工具不同,Taiga使用增量
本文是有关在Ubuntu 14.04上安装和配置Nagios的2部分系列文章的一部分。第1部分:Nagios服务器第2部分:远程主机概述Nagio
Vultr提供了几种不同的方式来访问VPS以进行配置,安装和使用。访问凭据VPS ar的默认访问凭据
使用其他系统?Grav是用PHP编写的开源平面文件CMS。Grav源代码公开托管在GitHub上。本指南将向您展示如何
使用其他系统?Pagekit 1.0 CMS是一个美观,模块化,可扩展,轻量级,免费和开源的内容管理系统(CMS),具有
使用其他系统?BigTree CMS 4.2是一种快速,轻量级,免费和开源的企业级内容管理系统(CMS),具有广泛的功能。
FTP是用于通过Internet传输文件的有用协议,本指南将向您展示如何设置vsFTPd(非常安全的文件传输协议守护程序)o
简介如果您经营一个重要的网站,则最好将文件镜像到辅助服务器。如果您的主服务器有网络
在Arch Linux上使用Makepkg可以避免系统污染,确保仅安装必要的依赖关系。
快速学习如何在Ubuntu 16.04上安装OpenSIPS控制面板,为VoIP提供商提供支持的功能。
学习如何在Fedora 28上安装Akaunting,一款适合小型企业和自由职业者的开源会计软件。
使用其他系统?Mailtrain是一个基于Node.js和MySQL / MariaDB构建的开源自托管新闻通讯应用程序。
了解導致Minecraft延遲的原因和解決方案,包括優化伺服器性能和減少滯後的步驟。
勒索軟件攻擊呈上升趨勢,但人工智能能否幫助應對最新的計算機病毒?AI 是答案嗎?在這裡閱讀知道是 AI 布恩還是禍根
ReactOS,一個開源和免費的操作系統,這裡有最新版本。它能否滿足現代 Windows 用戶的需求並打倒微軟?讓我們更多地了解這種老式但更新的操作系統體驗。
Whatsapp 終於為 Mac 和 Windows 用戶推出了桌面應用程序。現在您可以輕鬆地從 Windows 或 Mac 訪問 Whatsapp。適用於 Windows 8+ 和 Mac OS 10.9+
閱讀本文以了解人工智能如何在小型公司中變得流行,以及它如何增加使它們成長並為競爭對手提供優勢的可能性。
最近,Apple 發布了 macOS Catalina 10.15.4 補充更新以修復問題,但似乎該更新引起了更多問題,導致 mac 機器變磚。閱讀這篇文章以了解更多信息