【跨世纪】手把手教你搭建一个雨云同款论坛

前言

雨云论坛使用的源码是 Discourse 打开官网后,你可以找到大大的收费标准


不要紧张,这是在 Discourse 官方提供的服务器上托管自己的网站所需的每月费用,自己搭建是完全免费的,但及其复杂,小白别想了,不然就是sha bi

搭建环境

首先需要拥有一台 VPS ,任意支持 Docker持的 Linux 系统均可,这里建议 Debian12 并且有 Docker 环境

懒人方法:去 https://www.rainyun.com/wp-admin_ 购买一台 2 核 2G 的云服务器,系统选择按照下方所示即可(选择 Debian 12,预装 Docker)

等待其安装完成后连接 SSH ,切记用客户端连接,而不是网页端提供的 VNC

使用 root 用户连接 SSH 后,执行(非 root 用户先 sudo -s)

apt update

之后会更新软件包列表,稍等 1 分钟左右
然后安装 Git 和 vim 编辑器:

apt install git vim -y

随后执行

git clone https://github.com/discourse/discourse_docker.git /var/discourse

上方的命令可以将 git 库 clone 到/var/discourse目录下,修改相关字段即可更改目录,如果不填写即默认为 clone 至当前目录

之后进入源码目录

cd /var/discourse

更改containers文件夹的权限

chmod 700 containers

使用ls -lah查看当前目录文件(夹)的详细信息

image

之后需要准备一个邮箱 SMTP 账号,这里以 QQ 邮箱为例

SMTP_Server: smtp.qq.com
SMTP_Port: 587
SMTP_Username: your email(like xxx@qq.com)
SMTP_Password: 授权码

申请好一个授权码后,我们要先划拉一个 Swap 空间

fallocate -l 4G /swapfile

注意,上方命令会创建一个 4GiB 大小的 Swapfile,你可以根据服务器所剩空间灵活调整,推荐设置固定4GiB或者8GiB的swapfile,因为雨云大多数机子均为NVME SSD,速度极快

设置swapfile权限

chmod 600 /swapfile

转换文件为Swap格式

mkswap /swapfile

启用这个swapfile作为swap

swapon /swapfile

设置开机自动添加这个swapfile作为swap空间

echo '/swapfile none swap sw 0 0' | sudo tee -a /etc/fstab

之后需要配置swap积极性(又称活跃性,英文Swappiness)
vm.swappiness 的默认值通常是 60,但此处需要进行设置,因为其默认值为 0,如果你内存小的可怜(1G),那么建议将其改为 90 来更积极的使用swap,防止炸内存

vim /etc/sysctl.conf

vm.swappiness=<value>
<value> 替换为您希望设置的交换活跃性的值。vm.swappiness 的值范围是 0 到 100,具有以下含义:

  • 0:表示尽量减少使用交换空间,只在极端情况下才使用(马上要炸内存的时候,通常已经快来不及了)
  • 100:表示尽量多地使用交换空间

通常,将交换活跃性设置为介于 0 和 100 之间的值,根据系统的需求和性能优化进行调整。例如此处将值设定为75

i进入编辑模式

按下End将光标定位至行末,修改值

image

按下Esc,输入:wq保存并退出

image

之后使其生效

sysctl -p

检查开启的swap位置

swapon --show

image

之后使用iptables放通端口(你也可以装一个ufw简化配置)
放通80

iptables -A INPUT -p tcp --dport 80 -j ACCEPT

放通443

iptables -A INPUT -p tcp --dport 443 -j ACCEPT

保存

iptables-save | sudo tee /etc/iptables/rules.v4

规则持久化

apt install iptables-persistent -y

让它加载一次确保规则生效

sudo iptables-restore < /etc/iptables/rules.v4

再重启一下iptables万无一失

sudo systemctl start netfilter-persistent

出现下方提示后按两次回车

随后执行配置程序

./discourse-setup

第一个问题,你的域名是什么
image

没域名就去白嫖一个

第二个问题,管理员账户的邮箱是什么(请确保能收到邮件),可以有多个,用英文半角逗号分隔
image

第三个问题,SMTP 服务器地址是什么
image

由于以 QQ 邮箱为例,所以 SMTP 配置写的都是 QQ 邮箱的

之后问你 SMTP 端口是什么,账号是什么,密码是什么,通知地址(就是发件人,和 SMTP 写一样的就行)

image

这里问你你的Let’s Encrypt邮箱是什么,用于申请ssl的,如果直接回车可以跳过申请,避免麻烦,我选择跳过(它会送你一个SSL)

这里问你你的GeoIP库的高级版密钥是什么,如果直接回车会使用免费的GeoLite库,我买不起,所以直接回车

image

敲回车确认当前配置,敲n重新配置,按ctrl c取消配置

image

之后等着就行,可以尝试如下动作防止中通报错:

574973ac3ee8ca356884b354903d97b9

中间可能会有几次都是看起来卡住不动了,稍等片刻即可,如果你意外断开了SSH或者耐不住了想让他重新来一次,那么应该使用./launcher rebuild app

之后访问域名即可

之后注册管理账号

之后检查你的邮箱

会发现并没有收到邮件,这是因为官方的配置器存在错误,我们需要手动编辑containers/app.yml

vim containers/app.yml

image

加上- "587:587"

在这里添加 DISCOURSE_SMTP_AUTHENTICATION: login
image

在我光标所在行的地方,去掉前面的“#”,并且将后面的邮箱修改为你的 SMTP 邮箱账号

按esc,输入:wq保存退出
如果只修改SMTP相关问题,那么无需重建应用,只使用下列命令即可

./launcher destroy app
./launcher start app

如果您尝试了上述方法依然无法收到邮件,那么使用命令行强行跳过初次邮件验证:

cd /var/discourse
./launcher enter app

在回车后输入

rake admin:create

输入邮箱、如果提示

输入n

如果提示
image
输入y
之后输入两次密码即可(密码不会回显)
之后输入exit回到原来的终端

访问域名

登录后左侧找到“Admin”,选择“Settings”

更改语言后点击绿色对勾,刷新页面后即可

通过此方式搭建的论坛还支持在线聊天(也可能是雨云关了?或者懒得更新)

3 个赞

好好好,直接离谱起来了

1 个赞

麻烦死了:full_moon_with_face:

感谢分享!
discourse的部署确实很复杂,但是部署完了之后很好用。
而且对网络环境要求很高,国内很难部署,建议使用海外服务器。

3 个赞

哇呜,来自林总的肯定 :+1:

给个提示:安装DC论坛千万不能装面板(比如1P和宝塔),研究一个早上才想明白,原来我80端口被没有开SSL的宝塔占了,443端口还没有申请SSL证书,通讯不上
如果装了面板,记得 修改container/app.yml 文件中的expose部分,调整为任意未占用的端口正常这样就没错了

1p可以,不会占用端口

错误:产生该误解的原因可能是宝塔安装好默认提醒用户安装Nginx导致Nginx占用端口。

根据我失败14次的经验,Dc论坛不能够安装于非80端口,这会导致SSL与域名重定向问题,表现为访问提示重定向次数过多或连接不安全(无效响应)(即使使用Nginx反向代理+host也无效)。

另外对于个人搭建,不建议dc,超难配置(用户注册问题也难解决),建议nodebb或Discuz

安装完成后无法访问,重定向次数过多.

查看一下设置问题,比如说如果套了cdn,源站使用的是80(没开启SSL证书)但是CDN开了SSL证书(HTTPS【443】)
这是我曾经使用WP博客程序曾经出现的情况,可以尝试向这个方面加以思考解决
仅供参考,希望有所帮助

谢谢。检查后是cloudflare的设置问题,已经解决了。

检查一下网络
大陆可能docker被墙
可以尝试换源

请教大神 怎么换?可有相关教程?

vi /etc/docker/deamon.json

添加如下内容


{
    "registry-mirrors": [
        "https://mirrors.tuna.tsinghua.edu.cn",
    ]
}

保存, sudo systemctl daemon-reload&&sudo systemctl restart docker即可

ENTER to continue, 'n' to try again, Ctrl+C to exit: 
letsencrypt.ssl.template.yml enabled


Configuration file at containers/app.yml updated successfully!

Updates successful. Rebuilding in 5 seconds.
Building app
x86_64 arch detected.
Ensuring launcher is up to date
Fetching origin
fatal: unable to access 'https://github.com/discourse/discourse_docker.git/': GnuTLS recv error (-110): The TLS connection was non-properly terminated.
error: Could not fetch origin

到这步时会出现这个问题

你这个不是docker的问题,是github

我在主机的hosts中添加了相关的host了的,但是在docker中好像没有生效

docker≈虚拟机,要进docker操作

我是使用./discourse-setup 进行 Discourse 安装的 报错了 docker ps 里面没有任何容器在运行

那就只能看运气了