Discourse 轻论坛的图文搭建教程
Discourse 是 Stack Overflow 的联合创始人 Jeff Atwood 推出的一个新的开源论坛项目,其目的是为了改变十年未变的论坛软件。
Discourse 摒弃了传统论坛的话题讨论形式,它拥有自学习系统、全Web应用同时适用于桌面和移动终端。
Discourse 基于 Ruby on Rails 和 Ember.js 开发,数据库使用 PostgreSQL 和 Redis
Discourse 论坛的界面,官方的示例 Demo,先有一个直观的感受,如下图:
Discourse 是一个免费、开源的轻论坛,一个全新的论坛模式,具备传统论坛的话题讨论,又有了流行的问答风格,独有的会员关系网络和话题关联机制,让用户的交流和快速高效的寻找问题答案,优秀的用户体验获得了众多站长的青睐。
米扑博客前一篇,已经详细介绍了,详见米扑博客:Discourse 轻论坛的详细介绍
Discourse 官网:http://www.discoursecn.org
Discourse 中文网:http://www.discoursecn.org
Discourse 源码:https://github.com/discourse/discourse (开源、免费)
Discourse 是由 Stack Overflow 创始人之一的 Jeff Atwood 主导的开源论坛项目,使用时能感受到和 Stack Overflow 的关联性,比如为鼓励有效的技术讨论、控制人身攻击等做了很多努力,页面的布局方式也有相似之处。Discourse 提供了非常丰富的配置方式,也支持插件扩展,是值得学习的论坛类开源项目。
本文主要介绍通过 Docker 镜像的方式在公有云环境中部署 Discourse 环境,公有云选为阿里云,操作系统为 Ubuntu 16.04。
1. 准备工作,配置服务器
1.1 阿里云环境准备
Discourse 官方文档中推荐的最低配置是 1 核 2G,这里就选用了最低配:ecs.n4.small
对于没有很高访问量的站点,这个配置也足够用了。
服务器购买完成后,记得要更新一下系统,最新的系统修复了不少 bug:
sudo apt update sudo apt upgrade -y
1.2 邮箱配置
Discourse 比较依赖邮箱系统,需要根据邮箱来进行注册和消息通知,所以一定要有一个可用的邮件服务系统
Discourse 推荐使用第三方的邮件系统,其实自己搭建也是完全可行的,但邮件系统搭建也要花费一定的精力,而且也有一定的难度
本文使用的邮箱系统是 ElastishMail,具体的注册方式就不详细描述了。
1.3 注册域名
使用 IP 访问当然也是没有问题的,不过总归是不方便,建议还是为接下来要搭建的 Discourse 站点注册一个域名
阿里云收购了万网,所以域名注册在阿里云的网站内就可以搞定了。
2. 基础安装,配置 Discourse
Discourse 本身是挺复杂的,看安装过程的耗时和输出信息就知道了。
幸运的是,Discourse 提供了自动化安装的脚本,较低了部署的难度。
Discourse 依赖的软件并不多,主要是 git(用来拉取 Discourse 的代码)、docker(因为要使用 Docker 部署) 和 ruby(原因是 Discourse 是用 ruby 编写的)以及 ruby 的包管理工具 gem。
安装 git
# install git $ sudo apt install git
安装 docker
# install docker $ sudo wget -qO- https://get.docker.com/ | sh
配置 docker 使用国内的镜像
# Configure docker to use Chinese mirrors $ sudo vim /etc/docker/daemon.json { "registry-mirrors": ["https://registry.docker-cn.com", "http://hub.c.163.com"] } $ sudo systemctl restart docker.service
安装 discourse
# install discourse $ sudo -s $ mkdir /var/discourse $ git clone https://github.com/discourse/discourse_docker.git /var/discourse $ cd /var/discourse $ ./discourse-setup
运行 discourse-setup 脚本后,会提示输入一些安装信息,以此输入之前注册的域名和邮箱信息,即可。
Hostname for your Discourse? [discourse.example.com]: Email address for admin account(s)? [me@example.com,you@example.com]: SMTP server address? [smtp.example.com]: SMTP port? [587]: SMTP user name? [user@example.com]: SMTP password? [pa$$word]: Let's Encrypt account email? (ENTER to skip) [me@example.com]:
配置完成后,需要进行很久的编译,稍安勿燥,半小时之内都是正常的。
等待脚本 discourse-setup 脚本执行结束,就可以访问刚刚配置好的 discourse 网站了!
Disourse 欢迎界面
PS:Discourse 在国内云环境中部署,因为众所周知的原因,软件包的下载可能会遇到问题,本文所参考的一篇资料中谈到了gem 的连接问题,不过在写作本文的过程中并没有遇到该问题,如果遇到网络原因造成的安装失败,大家就需要各现神通了。
3. 进阶配置
3.1 设置自动备份
为了网站的信息安全,当然要对数据定期进行备份,配置备份的界面如下:
上图中,配置的是每天备份一次,保留最近的七个备份。
但这依然有问题,原因是备份文件是存储在 docker 内部的,万一 docker 崩溃了,备份文件也一样拿不回来
更为保险的方式是将备份文件再上传到第三方的存储系统中,discourse 也支持这样的配置,但因为 discourse 的作者生活在美帝,用的都是 S3、Dropbox、Box 和 Google Drive,我等国内“大局域网”只有看着流口水的份,所以完全不可用。
目前,解决方式是 crontab 启动定时任务,然后用 python 上传备份文件到内部的 Ceph 集群里,因为没有通用性,就先不把这种方式的详细步骤放上来了,如果有需要的话,我可以考虑把上传到 OSS 公有云的方法补充上。
另外自己写 Discourse 的插件也是可行的,只是我对 Ruby 完全不了解,所以没有采用这种方式。
3.2 设置 https
对于 HTTPS 的支持,discourse 也提供了自动化脚本,只需修改配置文件,并重新编译即可。
修改配置文件:需要在 /var/discourse/containers/app.yml 的 templates 段中增加一个行:
$ cat /var/discourse/containers/app.yml ... templates: ... - "templates/web.letsencrypt.ssl.template.yml" ...
然后执行以下命令:
$ /var/discourse/launcher rebuild app
脚本运行结束后即完成了 https 的配置,但这个执行时间依旧不短,大概在十到二十分钟。
4. 参考资料
Discourse cloud installation guide
Stuck for a step for long time during installation
Discourse plugins page on github
Discourse 优化改进
Discourse 提供了一键设置CDN,CSS、JS、图片等静态文件都可以使用CDN来加速,对于国外的空间架设Discourse而使用国内的七牛CDN加速的效果是非常好的。Discourse有导入和导出备份,网站搬家的话就可以用导入与导出了。
Discourse作为一个论坛,有时为了安全可以为Discourse设置Https连接,添加SSL证书,保证用户的隐私。
而Discourse作为一个论坛,也支持使用Google等第三方账号登录。
更多请参见:Discourse用CDN加速,搬家,换域名,SSL加密,插件和第三方账号登录设置
Discourse 搭建论坛的应用案例
1、Discourse 官方论坛示例
2、Atom China 论坛
3、MXNet / Gluon 论坛
还有一些 Discourse 做的论坛社区,都大同小异,不截图了,直接贴链接:
参考推荐:
四大编辑器对比:Sublime、Atom、VS Code、Notepad++
谷歌发布 Coarse Discourse:迄今为止最大的在线讨论标注数据集
NodeBB 论坛搭建 (CSDN)
Discourse搭建 (CSDN)
版权所有: 本文系米扑博客原创、转载、摘录,或修订后发表,最后更新于 2020-02-06 05:27:32
侵权处理: 本个人博客,不盈利,若侵犯了您的作品权,请联系博主删除,莫恶意,索钱财,感谢!