Influxdb-cluster使用docker部署

基础环境

  • docker版本说明
bash 复制代码
注意:从 Docker CE 版本开始,docker compose(注意中间没有横线)作为官方插件集成,
安装 Docker 时一并安装;

# 安装 Docker Compose 插件
sudo yum install -y docker-compose-plugin

# 验证安装(注意命令格式为 docker compose,无横线)
docker compose version
  • docker-compose

软件安装

  • 编写docker-compose.yml集群配置文件
bash 复制代码
name: "influxdb-cluster"

services:

  influxdb-meta-01:
    image: chengshiwen/influxdb:1.8.11-c1.2.0-meta
    container_name: influxdb-meta-01
    hostname: influxdb-meta-01
    restart: unless-stopped
    volumes:
      - ./meta/meta-01/data:/var/lib/influxdb
    networks:
      influxdb-cluster:
        ipv4_address: 172.18.0.10

  influxdb-meta-02:
    image: chengshiwen/influxdb:1.8.11-c1.2.0-meta
    container_name: influxdb-meta-02
    hostname: influxdb-meta-02
    restart: unless-stopped
    volumes:
      - ./meta/meta-02/data:/var/lib/influxdb
    networks:
      influxdb-cluster:
        ipv4_address: 172.18.0.11

  influxdb-meta-03:
    image: chengshiwen/influxdb:1.8.11-c1.2.0-meta
    container_name: influxdb-meta-03
    hostname: influxdb-meta-03
    restart: unless-stopped
    volumes:
      - ./meta/meta-03/data:/var/lib/influxdb
    networks:
      influxdb-cluster:
        ipv4_address: 172.18.0.12

  influxdb-data-01:
    image: chengshiwen/influxdb:1.8.11-c1.2.0-data
    container_name: influxdb-data-01
    hostname: influxdb-data-01
    ports:
      - 8186:8086
    restart: unless-stopped
    volumes:
      - ./data/data-01/data:/var/lib/influxdb
      - ./data/data-01/conf/influxdb.conf:/etc/influxdb/influxdb.conf
    networks:
      influxdb-cluster:
        ipv4_address: 172.18.0.13

  influxdb-data-02:
    image: chengshiwen/influxdb:1.8.11-c1.2.0-data
    container_name: influxdb-data-02
    hostname: influxdb-data-02
    ports:
      - 8286:8086
    restart: unless-stopped
    volumes:
      - ./data/data-02/data:/var/lib/influxdb
      - ./data/data-02/conf/influxdb.conf:/etc/influxdb/influxdb.conf
    networks:
      influxdb-cluster:
        ipv4_address: 172.18.0.14

  nginx:
    image: nginx:latest
    container_name: influxdb-nginx
    restart: unless-stopped
    ports:
      - "8086:8086"   # 对外暴露 8086 端口
    volumes:
      - ./nginx/nginx.conf:/etc/nginx/conf.d/influxdb.conf:ro
    networks:
      influxdb-cluster:
        ipv4_address: 172.18.0.15       
    depends_on:
      - influxdb-data-01
      - influxdb-data-02

networks:
  influxdb-cluster:
    driver: bridge                         
    ipam:                  
      config:
        - subnet: 172.18.0.0/24 
  1. 切换至docker-compose.yml文件所在目录;执行docker compose up -d 运行命令执行镜像拉取并创建容器。。

注意:要持久化容器中的数据,请务必挂载所有 Meta 和 Data 节点的 /etc/influxdb 和 /var/lib/influxdb 目录。

bash 复制代码
#启动容器
docker-compose up -d

# 关闭集群
docker-compose down

# 关闭集群,并清除数据
docker-compose down -v
初始化集群
bash 复制代码
使用 docker exec 进入任意一个 **meta容器(必须是 meta 容器,不能使用 data 容器)**中执行
如下命令即可。

1.添加初始化meta节点
influxd-ctl add-meta influxdb-meta-01:8091
influxd-ctl add-meta influxdb-meta-02:8091
influxd-ctl add-meta influxdb-meta-03:8091

2.添加初始化data节点
influxd-ctl add-data influxdb-data-01:8088
influxd-ctl add-data influxdb-data-02:8088

3.查看集群信息
influxd-ctl show

常见问题汇总

  1. 拉取镜像出现失败,在运行docker compose 时出现

需要重新配置docker镜像加速器,切换至目录:/etc/docker,然后修改daemon.json文件

清除registry-mirrors节点下的配置信息,重新填写;Docker会优先从国内镜像源拉取,失败时才回退到官方源,从而有效缓解超时问题。

bash 复制代码
{
  "registry-mirrors": [
    "https://docker.xuanyuan.me",
    "https://dockerpull.org",
    "https://docker.1panel.live"
  ]
}
相关推荐
wqfhenanxc2 小时前
AirFlow安装和使用
运维
阿凤213 小时前
nginx部署如何配置ssl证书
运维·nginx·ssl
安审若无3 小时前
Windows系统常用的运维终端安全基线设置方法
运维·安全
橙露3 小时前
Linux 驱动入门:字符设备驱动框架与编写流程
linux·运维·服务器
仙俊红3 小时前
关于ssh免密登录
运维·ssh
斯普信云原生组4 小时前
Docker 开源软件应急处理方案及操作手册——安全漏洞与权限问题
运维·docker·容器
国冶机电安装4 小时前
粉尘输送管道工程:工业粉体输送系统设计、安装与运维全解析
运维
MonkeyKing_sunyuhua4 小时前
阿里云ECS安装docker compose
阿里云·docker·云计算
南境十里·墨染春水4 小时前
Linux学习进展 进程管理命令 及文件压缩解压
linux·运维·笔记·学习