前言
首先必须介绍下Matrix。Matrix是一个开源、可交互、去中心化的实时通信服务框架。使用Matrix可以搭建安全的通信服务器,配合支持 Matrix 的客户端可以实现个人、团队间的实时聊天交互。
与常见的QQ、微信、钉钉相比,Matrix的特点就是开源,可私有化部署,保证通信的安全和隐私。与Rocket.chat、MatterMost相比,matrix的特点还要再加上去中心化。每个运行Matrix的服务器都是一个节点,用户可以选择在任意节点注册、连接,同一个节点内的用户可以任意通信。同时,节点与节点之间也可以通过联锁(Federation)机制进行通信,实现不同节点的用户之间进行通信。
因为Matrix只是个框架,可以有很多实现,本文使用的synapse就是其中一个服务端实现。
除了安装服务端,本文还有安装element web端的步骤。
搭一个demo并不耗资源,加上postgresql数据库才用了200MB内存不到,如果用默认的sqlite数据库会更省内存。
大致效果:
安装服务端
- 先拉取docker镜像
docker pull matrixdotorg/synapse:latest
- 生成配置文件。注意根据实际修改宿主机挂载目录路径和matrix的host
docker run -it --rm -v /home/admin/apps/synapse/data:/data -e SYNAPSE_SERVER_NAME=matrix.demo.com -e SYNAPSE_REPORT_STATS=yes matrixdotorg/synapse:latest generate
- 在postgresql中创建用户和数据库(默认使用sqlite,只是体验的话可以跳过)
# 创建用户, 按提示指定用户密码 createuser --pwprompt synapse_user # 创建数据库 createdb --encoding=UTF8 --locale=C --template=template0 --owner=synapse_user synapse
- 修改配置文件
/home/admin/apps/synapse/data/homeserver.yaml
(默认用的sqlite,只是体验的话可以跳过)
database: name: psycopg2 args: user: synapse_user password: <pass> database: synapse host: <host> cp_min: 5 cp_max: 10
- 编写docker-compose.yaml
version: "3" services: synapse: image: matrixdotorg/synapse:latest container_name: matrix-synapse ports: - 8008:8008 volumes: - /home/admin/apps/synapse/data:/data restart: on-failure:3 environments: - "TZ:=Asia/Shanghai"
- 创建容器
docker-compose up -d
- 配置nginx反向代理http或https(略过)
- 创建用户(默认禁止公开注册)
# 根据提示输入用户名、密码、是否设置为管理员 register_new_matrix_user -c /data/homeserver.yaml <your matrix server host>
安装element web客户端
- 访问github下载release包 https://github.com/vector-im/element-web/releases
- 解压后,创建配置文件
cp config.sample.json config.json
- 编辑
config.json
,设置default_server_config.m.homeserver.base_url
为自己的matrix服务端地址 - 配置nginx指向解压后的目录
- 访问自建的element web客户端测试
补充
允许公开注册
- 修改synapse的
homeserver.yaml
文件,设置以下参数
enable_registration: True
- 重启synapse
Element的Windows客户端指定默认服务器地址
- 在资源管理器中打开目录
%AppData\Roaming\Element%
- 新建文件
config.json
,输入以下内容
{ "default_server_config": { "m.homeserver": { "base_url": "<your matrix server host>" } } }