Rocket.Chat安装 日志 备份

2020-11-17 10:08:51

参考地址 Rocket.Chat 团队合作聊天工具安装配置试用

Rocket.Chat 是特性最丰富的 Slack 开源替代品之一。
主要功能:群组聊天,直接通信,私聊群,桌面通知,媒体嵌入,链接预览,文件上传,语音/视频 聊天,截图等等。

1. Rocket.chat 服务端安装与维护

服务器环境:Ubuntu 16.04

1.1. 安装snap

apt install snap snapd

1.2. 安装 rocketchat server

sudo snap install rocketchat-server

浏览 localhost:3000 进行系统设置

1.3. 检查运行状态

sudo systemctl status snap.rocketchat-server.rocketchat-server.service

1.4. SSL设置

Caddy 可以使用 Let’s Encrypt 来自动添加 SSL 加密通讯。

如果是自行手工安装,也可以通过 certbot, acme.sh等进行设置正式的ssl证书。

https://github.com/Neilpang/acme.sh/wiki/%E8%AF%B4%E6%98%8E

https://coolshell.cn/articles/18094.html

官方还没有提供基于snap和Caddy的ssl证书认证过程文档。

1.4.1. 设置 Caddy

产生配置文件

sudo rocketchat-server.initcaddy

如果是Debian 或者其他发布版,则运行

sudo snap run rocketchat-server.initcaddy

编辑Caddy文件: /var/snap/rocketchat-server/current/Caddyfile

http://:8080proxy / localhost:3000 {
  websocket
  transparent}

替换 http://:8080 为你的网站,如  chat.bclearning.top

https://chat.bclearning.top:8080tls self_signed
proxy / localhost:3000 {
  websocket
  transparent}

或者加上http到https的重定向

chat.bclearning.top:8080 {
tls self_signed
 proxy / localhost:3000 {
   websocket
   transparent
 }
}

加反向代理

chat.bclearning.top:8080 {
        proxy / 127.0.0.1:3000 {
                proxy_header X-Forwarded-Proto {scheme}
                proxy_header X-Forwarded-For {host}
                proxy_header Host {host}
                websocket
        }
}

注: 记得将域名指向到这个服务器ip地址。

1.4.2. 重启caddy

sudo systemctl restart snap.rocketchat-server.rocketchat-caddy
sudo systemctl status snap.rocketchat-server.rocketchat-caddy

1.4.3. 访问

https://chat.bclearning.top:8080

1.5. Rocketchat Server 维护

1.5.1. 升级到最新版

sudo snap refresh rocketchat-server

1.5.2. 查看日志

Server运行日志

sudo journalctl -u snap.rocketchat-server.rocketchat-server

数据库日志

sudo journalctl -u snap.rocketchat-server.rocketchat-mongo

1.5.3. 重启rocketchat

sudo systemctl restart snap.rocketchat-server.rocketchat-server

1.5.4. 备份snap数据

  1. 运行备份:

sudo snap run rocketchat-server.backupdb
  1. 查看备份文件

ls /var/snap/rocketchat-server/<version>/backup.tgz
  1. 复制 backup.tgz 到其他安全的地方

rsync -vauz  /var/snap/rocketchat-server/1248/backup.tgz ~/bak
# 加上日期标示
cp ~/bak/backup.tgz ~/bak/backup`date +%Y%m%d_%H%M`.tgz
# 仅保留近3天的备份,其余删除
find ~/bak -type f -mtime +3 | xargs rm -f

注:一般是复制到其他机器上。

1.5.5. 恢复备份的snap数据

  1. 将备份数据解压

cd ~
mkdir backup_data
cd backup_data
tar zxvf ~/bak/backup.tgz

创建了如下目录和文件: ~/backup_data/var/snap/rocketchat-server/<version>/dump/parties

  1. Confirm your database name
    The snap database name should be parties, but just to be safe:

sudo /snap/rocketchat-server/current/bin/mongo
(...)
> show dbs
local    0.000GB
parties  0.004GB
> exit
  1. 停掉 Rocket.Chat

sudo service snap.rocketchat-server.rocketchat-server stop
  1. 恢复数据库数据
    Use mongorestore to restore your backup data back into your snap database
    Important: before proceeding, consult https://docs.mongodb.com/manual/reference/program/mongorestore/ to learn about additional options and the non-overwriting behavior of mongorestore when the target database already exists.
    Please note: at the time of writing, mongorestore required openssl version 1.0.2 specifically. If you see an error like this - (...) version 'OPENSSL_1.0.2' not found (required by /snap/rocketchat-server/current/bin/mongorestore) - simply install the required openssl version to continue.
    When you are ready, run the following command (replacing <version> with the appropriate directory name):

sudo /snap/rocketchat-server/current/bin/mongorestore --db parties \~/backup_data/var/snap/rocketchat-server/<version>/dump/parties/
  1. 重启数据库,server,caddy服务

sudo service snap.rocketchat-server.rocketchat-mongo  restart
sudo service snap.rocketchat-server.rocketchat-server restart
sudo service snap.rocketchat-server.rocketchat-caddy  restart

sudo service snap.rocketchat-server.rocketchat-mongo  stop
sudo service snap.rocketchat-server.rocketchat-server stop
sudo service snap.rocketchat-server.rocketchat-caddy  stop

2. Rocket.chat 客户端安装使用

客户端覆盖了大部分平台,可以从 http://rocket.chat下载,
下面只列出windows和android版的使用

2.1. pc端

浏览器访问  https://chat.bclearning.top:8080/
因为是自签名,提示不安全,但是继续点击访问即可。

或者下载windows版程序

2.2. 手机端

2.2.1. 直接下载使用

访问
https://github.com/RocketChat/Rocket.Chat.Cordova/releases/
下载 armv7版本到手机, x86版本apk 到平板。

配置服务器为  chat.bclearning.top:8080

2.2.2. 开发者编译安装

https://rocket.chat/docs/developer-guides/mobile-apps/

3. 试用情况说明

Pc端 和 浏览器版本基本正常。问题主要是出在了手机端,iOS未测试,android进行了测试。

因为手机和个人精力有限,并发量没有测试,仅仅测试2,3个用户。

3.1. 问题

3.1.1. 手机端不稳定

pc端访问正常,很遗憾的是,手机端始终访问不正常,即使采用官方的云服务 rocket.chat 部署的Server也无法访问, 可能原因包括被墙,ssl是自签名的非正式版本等等。

采用2.x 版本访问官方的云服务自建服务时,无法连接,出现空白。更别提自建的服务器了。
采用1.x版本访问官方的云服务自建服务时,消息不稳定,延时很厉害。连接自建服务还未充分测试。

而且上述现象似乎还与手机连的是办公wifi或者无wifi下又有不同。

3.1.2. 在阿里云上无法获取正式SSL证书

阿里云上部署的Server始终无法获取Let’s Encrypt 的 SSL 证书,无论是用 certbot 还是 acme.sh
换到国外的主机 vultr之后正常。

 ./acme.sh --issue -d domain.name --standalone

3.1.3. 官方文档和下载不统一

A. 安装步骤并不能都通过,包括手工的pc端安装

B 手机端:官方文档有点乱,同时提供了android客户端的google play商店的2个版本的下载,与github上的release版本也不同。这就造成了试用的混乱。

android 老版本下载: 1.0.13
android上的apk在google play无法下载,可通过通过如下网址,点击生成下载
https://apps.evozi.com/apk-downloader/?id=chat.rocket.android
可以连接官方的服务器  yishineihua.rocket.chat
消息在公共频道有时会有延时

android 2.5 版本下载
https://apps.evozi.com/apk-downloader/?id=com.konecty.rocket.chat

android 新版本 下载 2.4  未发布到google play.
https://github.com/RocketChat/Rocket.Chat.Cordova/releases/

3.2. 可能的解决方案

  • 为了避免国内墙或者云服务的问题和干扰,采用国外的主机安装,确保可以获取ssl证书,进而可以搭建自己的服务器能够被手机端访问。

  • 采用 googleplay的  1.x 版本的下载和试用。

  • 将问题充分反馈到github的issue上。

  • 搭建手机端的开发环境,编译下载最新版的,然后连接使用。

  • 采用其他开源软件如:MatterMost
    这是我写的介绍,安装配置与使用文章:
    团队合作聊天服务Mattermost在Ubuntu 16.04下的安装配置与试用

备注:
如果不采用snap的快速安装,采用手工安装,安装了mongodb-org 3.x
则mongodb的启动方式如下:
mongod --dbpath=/var/lib/mongodb --replSet "001-rs"



  • 2017-04-06 14:59:13

    PHP配置文件详解

    PHP是一个简单易学,功能强大的语言,尤其在Web开发,开发效率高,方便快捷。研究一下php.ini了解PHP相关配置会有好处的,对PHP有更加深入的了解。

  • 2017-04-06 15:00:46

    怎么实时查看mysql当前连接数

    今天有一台mysql服务器突然连接数暴增,并且等待进程全部被锁...因为问题解决不当,导致被骂...OTL 总结:以后要快速定位错误,布置解决方案

  • 2017-04-06 15:07:57

    PHP-FPM不完全指南

    fpm启动后会先读php.ini,然后再读相应的conf配置文件,conf配置可以覆盖php.ini的配置。 启动fpm之后,会创建一个master进程,监听9000端口(可配置),master进程又会根据fpm.conf/www.conf去创建若干子进程,子进程用于处理实际的业务。

  • 2017-04-06 15:11:03

    浅析php-fpm 和 mysql 之间的关系详解

    php-fpm 和 mysql 之间的关系估计不做底层开发应用的是不会去考虑分析它们了,如果是的话我们来看一篇关于php-fpm 和 mysql 之间的关系的教程。

  • 2017-04-06 15:15:16

    PHP-FPM配置及使用总结

    PHP-FPM配置及使用总结: PHP-FPM是一个PHP FastCGI的管理器,它实际上就是PHP源代码的补丁,旨在将FastCGI进程管理引进到PHP软件包中,我们必须将其patch到PHP源代码中,然后再行编译才能使用。而现在我们可以在PHP 5.3.2及更新版本中直接开启并使用即可,因为PHP从该版本已经将其收入到软件包中,所以其不再是补丁包的存在了。

  • 2017-04-07 23:18:29

    mac 安装composer

    当你下载了 composer.phar 后,可以将它放在目录中,但每次当你建立新目录时,你必須再复制一个副本到新目录中,这样比较麻烦。所以最佳做法是将它放到 usr/local/bin 目录中中,成为全域指令。