使用OpenBSD在Vultr上配置BGP
Vultrs BGP功能使您可以拥有自己的IP空间并在我们的任何位置使用它,而OpenBSD实例则不需要其他软件!
NodeBB是基于Node.js的论坛软件。它利用Web套接字进行即时交互和实时通知。NodeBB源代码公开托管在Github上。本指南将通过使用Node.js,MongoDB作为数据库,Nginx作为反向代理以及Acme.sh获得SSL证书,在全新的FreeBSD 12 Vultr实例上引导您完成NodeBB的安装过程。
NodeBB要求安装以下软件:
A
/ AAAA
记录的域名检查FreeBSD版本。
uname -ro
# FreeBSD 12.0-RELEASE
确保您的FreeBSD系统是最新的。
freebsd-update fetch install
pkg update && pkg upgrade -y
如果系统上没有必要的软件包,请安装它们。
pkg install -y sudo vim unzip wget git bash socat gcc8 pkgconf vips
使用您的首选用户名创建一个新用户帐户(我们将使用johndoe
)。
adduser
# Username: johndoe
# Full name: John Doe
# Uid (Leave empty for default): <Enter>
# Login group [johndoe]: <Enter>
# Login group is johndoe. Invite johndoe into other groups? []: wheel
# Login class [default]: <Enter>
# Shell (sh csh tcsh nologin) [sh]: bash
# Home directory [/home/johndoe]: <Enter>
# Home directory permissions (Leave empty for default): <Enter>
# Use password-based authentication? [yes]: <Enter>
# Use an empty password? (yes/no) [no]: <Enter>
# Use a random password? (yes/no) [no]: <Enter>
# Enter password: your_secure_password
# Enter password again: your_secure_password
# Lock out the account after creation? [no]: <Enter>
# OK? (yes/no): yes
# Add another user? (yes/no): no
# Goodbye!
运行visudo
命令并取消注释该%wheel ALL=(ALL) ALL
行,以允许该wheel
组的成员执行任何命令。
visudo
# Uncomment by removing hash (#) sign
# %wheel ALL=(ALL) ALL
现在,使用切换到新创建的用户su
。
su - johndoe
注意: 用您的用户名替换johndoe
。
设置时区。
sudo tzsetup
NodeBB由Node.js驱动,因此需要安装。建议安装当前LTS版本的Node.js。
安装Node.js和npm。
sudo pkg install -y node10 npm-node10
检查版本。
node -v && npm -v
# v10.15.3
# 6.9.0
MongoDB是NodeBB的默认数据库。
安装MongoDB。
sudo pkg install -y mongodb40
检查版本。
mongo --version | head -n 1 && mongod --version | head -n 1
# MongoDB shell version v4.0.6
# db version v4.0.6
启用并启动MongoDB。
sudo sysrc mongod_enable=yes
sudo service mongod start
为NodeBB创建数据库和用户。
首先连接到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 service mongod restart
mongo -u admin -p your_password --authenticationDatabase=admin
安装Nginx。
sudo pkg install -y nginx
检查版本。
nginx -v
# nginx version: nginx/1.14.2
启用并启动Nginx。
sudo sysrc nginx_enable=yes
sudo service nginx start
默认情况下,NodeBB在port上运行4567
。为避免输入http://example.com:4567
,我们将Nginx配置为NodeBB应用程序的反向代理。port 80
或443
(如果使用SSL)上的每个请求都将转发到port 4567
。
运行sudo vim /usr/local/etc/nginx/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
使用您的域名/主机名更新指令。
保存文件并使用:+ W+ 退出Q。
现在我们需要包含nodebb.conf
在主nginx.conf
文件中。
运行sudo vim /usr/local/etc/nginx/nginx.conf
并将以下行添加到http {}
块中。
include nodebb.conf;
检查配置。
sudo nginx -t
重新加载Nginx。
sudo service nginx reload
不需要使用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 ~
检查版本。
/etc/letsencrypt/acme.sh --version
# v2.8.1
获得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 service nginx reload" --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 service nginx reload" --keylength ec-256
运行上述命令后,您的证书和密钥将位于:
/etc/letsencrypt/forum.example.com
。/etc/letsencrypt/forum.example.com_ecc
。从“加密”获取证书后,我们需要配置Nginx来使用它们。
sudo vim /usr/local/etc/nginx/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 service nginx reload
创建一个文档根目录。
sudo mkdir -p /usr/local/www/nodebb
将/usr/local/www/nodebb
目录的所有权更改为johndoe
。
sudo chown -R johndoe:johndoe /usr/local/www/nodebb
导航到文档根文件夹。
cd /usr/local/www/nodebb
将最新的NodeBB克隆到文档根文件夹中。
git clone -b v1.11.x https://github.com/NodeBB/NodeBB.git .
运行NodeBB setup命令,并在出现提示时回答每个问题。
./nodebb setup
NodeBB设置完成后,运行./nodebb start
以手动启动NodeBB服务器。
./nodebb start
执行此命令后,您将能够在Web浏览器中访问NodeBB论坛实例。
当通过启动时./nodebb start
,NodeBB将不会在系统重新启动时自动再次启动。为避免这种情况,我们需要将NodeBB设置为系统服务。
如果正在运行,请停止NodeBB。
./nodebb stop
全局安装PM2。
sudo npm install pm2 -g
检查版本。
pm2 -v
# 3.5.0
导航到NodeBB文档根目录。
cd /usr/local/www/nodebb
通过PM2启动NodeBB。
pm2 start app.js
列出NodeBB进程。
pm2 ls
检测可用的初始化系统。
pm2 startup
在CLI中复制并粘贴此命令的输出以设置启动挂钩。
保存您的进程列表。
pm2 save
而已。您的NodeBB实例现已启动并正在运行。
Vultrs BGP功能使您可以拥有自己的IP空间并在我们的任何位置使用它,而OpenBSD实例则不需要其他软件!
简介FreeBSD是一种类似于Unix的开源操作系统,用于为现代服务器,台式机和嵌入式平台提供动力。Netflix,雅虎等巨人!
本文中的信息涉及修改磁盘,分区和文件系统,因此在执行任何示例之前,应先完全理解它们,因为它们会导致数据丢失或丢失。
使用其他系统?Omeka Classic 2.4 CMS是一个免费的开源数字发布平台和用于共享数字内容的内容管理系统(CMS)
在Linux和Unix系统管理员中,使用sudo用户访问服务器并在root级执行命令是一种非常普遍的做法。使用泡沫
使用其他系统?osTicket是一个开放源代码的客户支持票务系统。osTicket源代码公开托管在Github上。在本教程中
使用其他系统?Dolibarr是面向企业的开源企业资源计划(ERP)和客户关系管理(CRM)。多利巴尔
Ghost是与WordPress竞争的最新,最大的暴发户。主题开发既快速又容易学习,因为Ghost开发人员决定同时使用
使用其他系统?Monica是一个开源的个人关系管理系统。可以将其视为CRM(销售团队使用的一种流行工具
使用其他系统?Couch CMS是一个简单,灵活,免费和开源的内容管理系统(CMS),可让Web设计人员进行设计
使用其他系统?LimeSurvey是一个用PHP编写的开源调查软件。LimeSurvey源代码托管在GitHub上。本指南将向您展示
使用其他系统?TLS 1.3是传输层安全性(TLS)协议的版本,该协议于2018年作为RFC 8446中的建议标准发布
使用其他系统?MyBB是一个免费,开放源代码,直观且可扩展的论坛程序。MyBB源代码托管在GitHub上。本指南将
尽管ejabberd非常普遍,但最近有一个竞争对手-Prosody。本教程将向您展示如何在FreeBS上设置Prosody
从9.2版开始,FreeBSD引入了一个新工具来替换旧的pkg _ *-命令-pkg,也称为pkgng。它非常类似于Debians apt o
使用其他系统?Matomo(以前称为Piwik)是一个开源分析平台,是Google Analytics(分析)的一种开放替代方案。Matomo源托管o
使用其他系统?ProcessWire CMS 3.0是一个简单,灵活,功能强大,免费和开源的内容管理系统(CMS)。ProcessWire CMS 3。
使用其他系统?TLS 1.3是传输层安全性(TLS)协议的版本,该协议于2018年作为RFC 8446中的建议标准发布
使用其他系统?Redaxscript 3.2 CMS是一款现代,超轻量级,免费和开源的内容管理系统(CMS),具有火箭fas
使用其他系统?简介BookStack是一个简单的,自托管的易于使用的平台,用于组织和存储信息。BookStack已满
在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 機器變磚。閱讀這篇文章以了解更多信息