# 《分布式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
1
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)知识星球,解锁完整技术文章、小册、视频与完整代码