资讯专栏INFORMATION COLUMN

nodebb搭建,维护,discuz!数据迁移至mongo

Charlie_Jade / 2634人阅读

摘要:原文链接为什么选择了我也不知道官方中文论坛官方文档中文文档安装此处的方式是安装部署不用考虑环境配置问题,但是相应的也会有一些弊端比如文件的修改等变得麻烦下方为镜像的为了修改文件方便,加了一个文件夹方便和宿主机文件交换同步上传的

原文链接

为什么选择了NodeBB?
我也不知道~~~

NodeBB官方Github

NodeBB中文论坛

NodeBB官方文档

NodeBB中文文档

安装
此处的方式是Docker安装部署(https://hub.docker.com/r/node...
不用考虑环境配置问题,但是相应的也会有一些弊端
比如文件的修改等变得麻烦

下方为nodebb镜像的YAML

cumt:
  image: index.docker.io/nodebb/docker:v1.9.3
  privileged: false
  restart: always
  ports:
  - 4567:4567
  volumes:
  - /bbs/:/usr/src/app/config #为了修改文件方便,加了一个文件夹方便和宿主机文件交换
  - /bbs/public/uploads:/usr/src/app/public/uploads #同步上传的文件到宿主机

同时关于docker的管理推荐使用中国的容器管理平台,镜像会直接拉取国内复制来的镜像
工作室目前用的是https://www.daocloud.io/

拉取nodebb镜像并生成容器后,再拉取一个mongodb镜像作为数据库容器
为了维护方便,多带带使用一个容器,以后的nodebb论坛的升级可以直接拉取新的版本镜像
安装新版本的时候填写数据库容器内网地址就行啦~

在成功生成mongodb容器后,要首先进入容器创建我们需要的数据库名字和此数据库相应的用户密码
官方也有介绍

下面是mongo镜像的YAML,我们通过数据卷可以同步更新数据到宿主机

mongodb:
  image: library/mongo:3.4.15
  privileged: false
  restart: always
  ports:
  - 27017:27017
  volumes:
  - /var/lib/docker/volumes/mongoconfig/_data:/data/configdb
  - /var/lib/docker/volumes/mongodata/_data:/data/db

一般国内服务器会配置安全组,为了方便你也可以暂时开放mongodb容器外网端口
在本机远程连接进行配置,这里推荐一款windows可视化工具Robo 3T

然后我们通过nginx代理设置我们需要的域名就行了~

这样安装之后你就可以配置自己的bbs了,这样的方式会给我们省去很多环境配置的麻烦
可能遇到的问题

论坛一直显示断开连接

这时候你需要修改容器config.json里面的url为你的自定义域名

版本升级
nodebb并不好升级,按照官方文档的操作我们需要首先备份数据库和用户上传文件
但是我们使用了docker几句可以避免这些问题
然后我们要做的就是更新docker镜像并重新生成容器,配置相应的数据库就行了

需要注意的是我们生成新的容器后要停用一切插件以防nodebb系统直接崩溃

./nodebb reset -a
数据库维护和备份
定时备份数据库并迁移到其他机器是件很重要的事情数据库备份

由于我们使用的是docker容器,备份命令就需要连接我们相应的内网地址

mongodump -h 172.22.0.12:27017 -u 用户名 -p 密码 --authenticationDatabase=数据库名 -d 数据库名

我们需要注意的是如果定时执行的脚本在宿主机,我们需要在宿主机安装mongo以支持mongodump命令

同时这个定时备份脚本的成功输出语句并不能正确的反应是否成功备份

我们还是最好定期检查一下

如果你要恢复数据库文件,我们可以通过我们保存的备份文件上传到新的mongodb外置的数据卷
即比如:
把备份文件放到宿主机的 /var/lib/docker/volumes/mongodata/_data
容器中直接打开 /data/db
然后解压之后(tar -zxvf xxx.tar.gz)
运行
mongorestore -u nodebb -p yourpassword --authenticationDatabase=nodebb -d nodebb --drop dump/nodebb
即可
discuz!数据迁移到nodebb
旧的论坛数据库是Mysql,完全不同的数据库类型,也是不可能一样的数据库字段
但是论坛的性质使得他们数据字段部分是相同的,我们只需要过滤筛选我们所需要的数据,然后通过NodeBB接口插件导入我们要用的信息就行了
其实这个过程并不具有技术难度,只是比较复杂和麻烦
我们首先需要熟悉Dz和nodebb数据库各个字段 DZ数据库字典
对于用户的筛选
我们都知道Mysql数据库外键很方便我们联表或者关联查询,通过这种方式把我们需要的用户信息组成json
通过NodeBB接口post到mongodb(如果不使用api直接导入到mongo,我们还要自己组合mongo字段)

由于nodebb-api用户新建只支持用户名和密码,邮箱的POST,我们可以新建成功后,记录下新建成功的用户uid,然后通过update用户信息来更新用户资料

关于用户的头像,论坛等cms一般都有自己的用户头像文件命名规则
对于dz论坛自己获取头像的的代码如下,我们可以通过模仿流程来获取头像文件夹的路径
function get_avatar($uid, $size = "middle", $type = "") {
    $size = in_array($size, array("big", "middle", "small")) ? $size : "middle";
    $uid = abs(intval($uid));
    $uid = sprintf("%09d", $uid);
    $dir1 = substr($uid, 0, 3);
    $dir2 = substr($uid, 3, 2);
    $dir3 = substr($uid, 5, 2);
    $typeadd = $type == "real" ? "_real" : "";
    return $dir1."/".$dir2."/".$dir3."/".substr($uid, -2).$typeadd."_avatar_$size.jpg";
}

===============================================
# python模仿流程
def get_avatar(uid):
    uid = str(abs(int(uid)))
    uid_length = len(uid)
    if uid_length < 9:
        uid = "0"*(9-uid_length)+uid
    dir1 = uid[0:3]
    dir2 = uid[3:5]
    dir3 = uid[5:7]
    dir4 = uid[7:9]
    old_avatar = os.path.join(
        basedir, "avatar/"+dir1+"/"+dir2+"/"+dir3+"/"+dir4+"_avatar_middle.jpg")
    return old_avatar

...

if avatarstatus != 0:
    old_avatar = get_avatar(uid)
    new_avatar_address = "/assets/uploads/profile/%a-profileavatar.jpg" % adduser_uid
    new_avatar = os.path.join(basedir, "profile/%a-profileavatar.jpg" % adduser_uid)
    shutil.copy(old_avatar, new_avatar)
    update_data["picture"] = new_avatar_address
    update_data["uploadedpicture"] = new_avatar_address
对于帖子和回复的迁移
理论和以上一样
我们需要先研究清楚DZ数据库字典,比如这样的字典
我们根据相应数据字段来组合我们需要的mongodb字典
我们需要注意的是,在这个表段的组合之后我们也需要update相应的帖子资料
更新帖子的发表时间,以及发表作者(我的脚本里只更新了帖子的作者,没有更新帖子发表字段,因此造成用户没有记录帖子发表数,但是帖子详情页作者显示正确)

如果导入HTMLParser报错,可以参考下面的文件更新到python相应的Lib/site-packages文件夹中 HTMLParser报错文件参考

如果requests失败,就增加time.sleep减少发送频率

dz是s级别的时间戳,而nodebb是13位的毫秒级,转换公式 reply_dateline = int(round(reply_dateline*1000))

迁移脚本完整部分(供参考)

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/19303.html

相关文章

  • Centos7下宝塔面板使用redis部署NodeBB论坛程序

    摘要:使用默认配置,请按回车。数据库选择,填写,还会要求填写管理员账号密码等。如果是在下使用数据库,那么整个过程也差不多,只是需要配置下数据库,其他都一样。1、简介项目:https://github.com/NodeBB/NodeBB 官网:https://nodebb.org/ 文档:https://docs.nodebb.org/ 演示:https://try.nodebb.org/2、准备宝...

    Tecode 评论0 收藏0
  • 零基础入门—网站建站教程(新手必备)

    摘要:自行建站服务器购买网站搭建网站维护全程自主,弹性灵活。网站部署常见网站类型有以下几种个人博客常用于搭建个人博客网站,尤其适用于首次使用阿里云进行建站的新用户。若您需要在阿里云服务器上部署站点环境安装应用程序,可点此查看网站基础环境搭建服务。相信很多新用户会有这样的疑惑,我要做个网站,到底要使用什么产品,如何能快速完成网站建站呢?搭建网站有两种选择,一种是直接购买建站模板,另一种则是自行建站。...

    booster 评论0 收藏0
  • 零基础入门—网站建站教程(新手必备)

    摘要:自行建站服务器购买网站搭建网站维护全程自主,弹性灵活。网站部署常见网站类型有以下几种个人博客常用于搭建个人博客网站,尤其适用于首次使用阿里云进行建站的新用户。若您需要在阿里云服务器上部署站点环境安装应用程序,可点此查看网站基础环境搭建服务。前言相信很多新用户会有这样的疑惑,我要做个网站,到底要使用什么产品,如何能快速完成网站建站呢?搭建网站有两种选择,一种是直接购买建站模板,另一种则是自行建...

    wemall 评论0 收藏0
  • MongoDB 资源、库、工具、应用程序精选列表中文版

    摘要:推荐阅读资源库工具应用程序精选列表中文版有哪些鲜为人知,但是很有意思的网站一份攻城狮笔记每天搜集上优秀的项目一些有趣的民间故事超好用的谷歌浏览器油猴插件合集目录资源文档文章图书会谈教程更多库工具管理数据部署桌面发展监控应用资源文档介绍文档教 推荐阅读 MongoDB 资源、库、工具、应用程序精选列表中文版 有哪些鲜为人知,但是很有意思的网站? 一份攻城狮笔记 每天搜集 Github ...

    e10101 评论0 收藏0
  • MongoDB2.4升级到3.0的详细步骤

    摘要:于是就有了这次的版本升级任务。如果返回的值小于,那么则需要用在库里具有权限的用户连上的库然后执行用户认证格式转换。参考文档及软件下载链接升级官方指南升级官方指南警告的解决方案下载下载 最近为了长远考虑想把项目MongoDB里存放的400多万数据迁移到云服务厂商提供的MongoDB服务上,省去自己去维护的时间,但是看了下云服务对MongoDB数据迁移上云的要求是自建MongoDB数据库的...

    whatsns 评论0 收藏0

发表评论

0条评论

Charlie_Jade

|高级讲师

TA的文章

阅读更多
最新活动
阅读需要支付1元查看
<