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"
  ]
}
相关推荐
杨浦老苏8 小时前
家庭实验室监控仪表盘HomeLab-Monitor
运维·docker·监控·群晖
回忆2012初秋9 小时前
【Nginx】原理、配置与运维实战(2)
运维·nginx·策略模式
Urbano9 小时前
工装外套全制作流程、工序痛点及自动化设备升级方案
运维·自动化
映翰通朱工10 小时前
工业4G网关无公网IP远程运维实战(内网终端异地访问方案)
运维·服务器·网络·安全·智能路由器
洪晓露10 小时前
将 rke2 集群证书延长至 10 年
运维·服务器·数据库
谢平康10 小时前
解决用 rm 报bash: /usr/bin/rm: Argument list too long错
linux·运维·运维开发
IP老炮不瞎唠10 小时前
Python 价格监控如何实现?思路与实用方法分享
运维·服务器·网络
GIS数据转换器10 小时前
城市排水生命线安全运行监测平台深度解析
java·运维·人工智能·python·安全·数据挖掘·无人机
Tokai_Teio_111 小时前
第四届黄河流域 misc
运维·服务器
开发者联盟league12 小时前
使用k8s安装Sonarqube
云原生·容器·kubernetes