# 《分布式IM系统》环境搭建-第04节:分布式IM即时通讯系统搭建并优化多节点Minio分布式文件系统
作者:冰河
星球:http://m6z.cn/6aeFbs (opens new window)
博客:https://binghe.gitcode.host (opens new window)
文章汇总:https://binghe.gitcode.host/md/all/all.html (opens new window)
源码获取地址:https://t.zsxq.com/0dhvFs5oR (opens new window)
课程视频:https://t.zsxq.com/15G8ZLxlB (opens new window)
沉淀,成长,突破,帮助他人,成就自我。
- 本章难度:★★☆☆☆
- 本章重点:基于Docker搭建Minio分布式文件系统,统一管理分布式IM即时通讯系统中发送的图片,掌握Minio分布式文件系统搭建的方法和步骤,并能够将其灵活应用到自身实际项目中。
- 课程视频:https://t.zsxq.com/15G8ZLxlB (opens new window)
大家好,我是冰河~~
Minio是一个开源的高性能对象存储服务器,适用于构建分布式存储系统。它具有高可用性、可扩展性和数据保护机制,兼容Amazon S3 API,使其与现有的S3生态系统和工具集成无缝。Minio在大数据、云计算和容器化环境中广泛应用,为应用程序提供了可靠、高效的对象存储服务。
# 一、前言
分布式IM即时通讯系统提供了单聊和群聊的功能,在消息的发送和接收上需要支持文本、表情、图片、文件、语音和视频等等。那在消息的发送过程中,图片、文件、语音等要存放在哪里呢?一种非常有效的存储方式,就是将其存储到一款高性能的分布式文件系统中。
对比其他的分布式文件系统后,我们最终选择了Minio来存储消息的图片、文件和语音等资源。主要是考虑到Minio文件系统具备高性能、高可扩展性、安装和操作简单、具备纠删码等特性。具体的特性大家可自行上网了解,这里不再赘述。
# 二、本节诉求
为分布式IM即时通讯系统搭建Minio分布式文件系统环境,存储消息发送过程中附带的图片、文件、语音等资源。了解Minio分布式文件系统的搭建方式,并能够将其灵活应用到自身实际项目中。
# 三、环境说明
- 服务器版本:CentOS7
- 主机名:binghe102
- IP地址:192.168.106.102
- Minio镜像:minio/minio
- Nginx镜像:nginx:1.19.2-alpine
# 四、docker-compose说明
这里,我们基于docker-compose来安装Minio文件系统,docker-compose的安装方式,大家可以到环境搭建篇的《第01节:分布式IM即时通讯系统研发环境搭建 (opens new window)》一文中进行查看,这里不再赘述。
另外,大家可能由于网络的问题,在搭建安装docker-compose的过程中,docker-compose下载的很慢,这里,我也将docker-compose下载下来,放到了本节源码分支的environment/docker-compose
目录下,大家自行获取即可。
# 五、编写配置文件
这里,我们安装并启动四个Minio容器,由Nginx统一对外提供访问图片或者文件等资源的地址。所以,我们除了要编写基于docker-compose安装Minio容器的配置,还需要编写基于docker-compose安装Nginx的配置,另外,也需要对nginx.conf文件进行配置。
# 5.1 编写容器配置
无论是Minio文件系统,还是Nginx,我们都是基于docker-compose安装的。所以,在编写容器配置时,我们将这Minio容器和Nginx容器的安装写到同一个配置文件中,并将其命名为:docker-compose-minio.yml。
源码详见:environment/docker-compose-minio.yml。
version: '3.2'
# 所有容器通用的设置和配置
x-minio-common: &minio-common
image: minio/minio
command: server --console-address ":9001" http://minio{1...4}/data
expose:
- "9000"
environment:
MINIO_ROOT_USER: binghe
MINIO_ROOT_PASSWORD: binghe123
healthcheck:
test: ["CMD", "curl", "-f", "http://localhost:9000/minio/health/live"]
interval: 30s
timeout: 20s
retries: 3
# 启动4个docker容器运行minio服务器实例
# 使用nginx反向代理9000端口,负载均衡
# 可以通过9001、9002、9003、9004端口访问它们的web console
services:
minio1:
<<: *minio-common
hostname: minio1
ports:
- "9001:9001"
volumes:
- ./data/data1:/data
minio2:
<<: *minio-common
hostname: minio2
ports:
- "9002:9001"
volumes:
- ./data/data2:/data
minio3:
<<: *minio-common
hostname: minio3
ports:
- "9003:9001"
volumes:
- ./data/data3:/data
minio4:
<<: *minio-common
hostname: minio4
ports:
- "9004:9001"
volumes:
- ./data/data4:/data
nginx:
image: nginx:1.19.2-alpine
hostname: nginx
volumes:
- ./config/minio/nginx/nginx.conf:/etc/nginx/nginx.conf:ro
ports:
- "9000:9000"
depends_on:
- minio1
- minio2
- minio3
- minio4
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
需要注意的是,我们在上述配置中,将Minio后台管理端的账号配置成了binghe,密码配置成了binghe123。
# 查看完整文章
加入冰河技术 (opens new window)知识星球,解锁完整技术文章、小册、视频与完整代码