[学习笔记]Rocket.Chat业务数据备份
Rocket.Chat 的业务数据主要存储于mongodb数据库的rocketchat
库中,聊天中通过发送文件功能产生的文件储存于/app/uploads
中(文件方式设置为"FileSystem"
),因此在对Rocket.Chat做数据移动或备份主要分为两步,数据库备份和文件备份。
前提
已在本地或docker中部署完成Rocket.Chat服务,部署方法请查看[学习笔记] Rocket.Chat 安装与设置启动项。
使用docker-compose方式部署时
- 确保mongodb暴露了端口以供宿主机访问。
- 确保宿主机的目录映射至rocketchat服务的
/app/uploads
目录,此目录应在后台管理已正确设置
docker-compose.yml
文档中rocketchat和mongo部分的内容应如下
rocketchat:
...
volumes:
- ./uploads:/app/uploads
mongo:
...
volumes:
- ./data/db:/data/db
- ./data/dump:/dump
ports:
- 27017:27017
准备工作
我们可以在服务宿主机中执行备份(本地备份),或者在远程计算机中执行备份(异地备份)
安装 mongodb-org-tools
工具,我们要用的是数据库备份mongodump
和以及恢复mongorestore
工具
详情请查看官网或教程
cd /etc/yum.repos.d
nano mongodb-org-4.0.repo
[mongodb]
name=MongoDB Repository
baseurl=http://mirrors.aliyun.com/mongodb/yum/redhat/7Server/mongodb-org/4.0/x86_64/
gpgcheck=0
enabled=1
运行安装命令
yum install mongodb-org-tools
备份
数据库备份
运行下列命令进行备份
mongodump -d="rocketchat" --gzip -o "/home/xamarin/dump"
等待备份完成,打印如下
2023-02-21T03:07:23.140+0000 writing rocketchat.users to
2023-02-21T03:07:23.140+0000 writing rocketchat.rocketchat_statistics to
2023-02-21T03:07:23.141+0000 writing rocketchat.rocketchat_cron_history to
2023-02-21T03:07:23.141+0000 writing rocketchat.rocketchat_message to
2023-02-21T03:07:24.980+0000 [........................] rocketchat.users 101/10594 (1.0%)
2023-02-21T03:07:24.980+0000 [#.......................] rocketchat.rocketchat_statistics 101/1791 (5.6%)
2023-02-21T03:07:24.980+0000 [#.......................] rocketchat.rocketchat_message 101/1363 (7.4%)
2023-02-21T03:07:24.980+0000 [#.......................] rocketchat.rocketchat_cron_history 101/1549 (6.5%)
2023-02-21T03:07:24.980+0000
2023-02-21T03:07:25.059+0000 [########################] rocketchat.rocketchat_message 1363/1363 (100.0%)
2023-02-21T03:07:25.059+0000 done dumping rocketchat.rocketchat_message (1363 documents)
此时备份文件将在/home/xamarin/dump
目录下
在异地备份时可以使用-h
和 -port
指定服务器地址
mongodump -h="<数据库服务器地址>" --port="27017" -d="rocketchat" --gzip -o "/home/xamarin/dump"
文件备份
前往已映射到宿主机的uploads
所在目录,此处以/home/xamarin
为例
cd /home/xamarin
添加压缩文件和快照文件,并保存在/home/xamarin/backups
下
tar -g /home/xamarin/uploads-snapshot -zcvf /home/xamarin/uploads-full.tar.gz /home/xamarin/backups/uploads/
还原
数据库还原
运行如下命令进行mongodb数据库还原
mongorestore --gzip --drop --dir="/home/xamarin/backups/mongodb/dump/gzip/"
在异地还原时可以使用 -h
和 -port
指定服务器地址
mongorestore -h="<数据库服务器地址>" --port="27017" --gzip --drop --dir="/home/xamarin/backups/mongodb/dump/gzip/"
文件还原
前往uploads-full.tar.gz
备份文件所在目录
cd /home/xamarin/backups/uploads/
运行解压缩文件
tar -g uploads-snapshot -zxvf uploads-full.tar.gz -C /home/xamarin
打开Web端,观察到业务数据已悉数恢复
Troubleshooting
在还原过程中若出现Unrecognized field 'snapshot'
字样如下
2023-02-21T14:06:07.022+0800 Failed: error writing data for collection `rocketchat.users` to disk: error reading collection: Failed to parse: { find: "users", skip: 0, snapshot: true, $readPreference: { mode: "secondaryPreferred" }, $db: "rocketchat" }. Unrecognized field 'snapshot'.
请确保备份和还原的工具版本一致,使用--version
参数查看 mongodump
或 mongorestore
版本
mongodump --version
[学习笔记]Rocket.Chat业务数据备份的更多相关文章
- SQL学习笔记六之MySQL数据备份和pymysql模块
mysql六:数据备份.pymysql模块 阅读目录 一 IDE工具介绍 二 MySQL数据备份 三 pymysql模块 一 IDE工具介绍 生产环境还是推荐使用mysql命令行,但为了方便我们测 ...
- Sharepoint2013搜索学习笔记之设置业务数据内容源(六)
Sharepoint搜索爬网组件支持爬Business Data Connectivity Service 承载的外部数据,关于Business Data Connectivity Service设置 ...
- R学习笔记(4): 使用外部数据
来源于:R学习笔记(4): 使用外部数据 博客:心内求法 鉴于内存的非持久性和容量限制,一个有效的数据处理工具必须能够使用外部数据:能够从外部获取大量的数据,也能够将处理结果保存.R中提供了一系列的函 ...
- .NET MVC 学习笔记(六)— 数据导入
.NET MVC 学习笔记(六)—— 数据导入 在程序使用过程中,有时候需要新增大量数据,这样一条条数据去Add明显不是很友好,这时候最好就是有一个导入功能,导入所需要的数据,下面我们就一起来看一下导 ...
- Kotlin学习笔记(9)- 数据类
系列文章全部为本人的学习笔记,若有任何不妥之处,随时欢迎拍砖指正.如果你觉得我的文章对你有用,欢迎关注我,我们一起学习进步! Kotlin学习笔记(1)- 环境配置 Kotlin学习笔记(2)- 空安 ...
- openresty 学习笔记二:获取请求数据
openresty 学习笔记二:获取请求数据 openresty 获取POST或者GET的请求参数.这个是要用openresty 做接口必须要做的事情.这里分几种类型:GET,POST(urlenco ...
- MySQL学习笔记十二:数据备份与恢复
数据备份 1.物理备份与逻辑备份 物理备份 物理备份就是将数据库的数据文件,配置文件,日志文件等复制一份到其他路径上,这种备份速度一般较快,因为只有I/O操作.进行物理备份时,一般都需要关闭mysql ...
- MyCat 学习笔记 第十篇.数据分片 之 ER分片
1 应用场景 这篇来说下mycat中自带的er关系分片,所谓er关系分片即可以理解为有关联关系表之间数据分片.类似于订单主表与订单详情表间的分片存储规则. 本文所说的er分片分为两种: a. 依据主键 ...
- MyCat 学习笔记 第八篇.数据分片 之 求摸运算分片
1 应用场景 Mycat 自带了多套数据分片的机制,其实根据数值取摸应该是最简单的一种. 优点:数据离散概率较为平均,可以有效的提高应用的数据吞吐. 缺点:比较明显,后期数据运维与迁移比较困难.好在M ...
- MyCat 学习笔记 第七篇.数据分片 之 按数据范围分片
1 应用场景 Mycat 其实自带了2个数据范围分片的方案,一个是纯数据范围的分片,比如 1至 10000 号的数据放到分片1 ,10001 至 20000号数据放到分片2里. 另一个是数据常量形式的 ...
随机推荐
- TienChin 渠道管理-渠道页面完善
最后附上渠道管理的数据 install SQL 语句: INSERT INTO TienChin.tienchin_channel (channel_id, channel_name, status, ...
- 【四】AI Studio 项目详解【VisualDL工具、环境使用说明、脚本任务、(四)图形化任务、在线部署及预测】PARL
相关文章 [一]-环境配置+python入门教学 [二]-Parl基础命令 [三]-Notebook.&pdb.ipdb 调试 [四]-强化学习入门简介 [五]-Sarsa&Qlear ...
- 21.12 Python 实现网站服务器
Web服务器本质上是一个提供Web服务的应用程序,运行在服务器上,用于处理HTTP请求和响应.它接收来自客户端(通常是浏览器)的HTTP请求,根据请求的URL.参数等信息生成HTTP响应,并将响应返回 ...
- Flask 框架:实现简单API测试接口
通过使用Python中Flask框架实现一个简单的API接口程序,用户可发送JSON格式的请求,服务器响应请求,并以JSON格式将数据返回给用户,此处代码是一个模板可以测试接口时使用. Flask代码 ...
- a标签download属性跨域问题
1.如果是加载了非同源的内容,该属性将失效,等于导航功能 2.在服务端设置Content-Disposition,使用HTTP响应头Content-disposition进行处理 3.先下载数据文件, ...
- uniapp面试题
.markdown-body { line-height: 1.75; font-weight: 400; font-size: 16px; overflow-x: hidden; color: rg ...
- Golang中make和new的区别
1. 相同点 都是内建函数,都是在堆上分配内存,都需要传递类型参数 2. 不同点 传递的参数不一样,new函数只接收一个参数,make函数可以接收一个以上的参数 package main import ...
- Hive-分区取TOP N问题
问题背景 设想你对用户在不同品类上的行为打分聚合后得到这样一个表 user_cate_score uid cate score 1 1 0.3 2 2 0.5 8 3 0.9 现在,你想将每个品类的T ...
- 【framework】TaskStack简介
1 前言 TaskStack 用于管理 app,一般一个应用程序对应一个 TaskStack,其父容器为 TaskStackContainers(DisplayContent 的子容器),子容器为 ...
- Vue+SpringBoot+ElementUI实战学生管理系统-4.后端API编写
1.章节介绍 前一篇介绍了项目的表结构设计,这一篇编写后端API,需要的朋友可以拿去自己定制.:) 2.获取源码 源码是捐赠方式获取,详细请QQ联系我 :)! 3.项目截图 登录页 列表操作 动态图 ...