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"
  ]
}
相关推荐
云动课堂5 分钟前
【运维实战】MySQL 8.0 数据库 · 一键自动化部署方案 (适配银河麒麟 V10 / 龙蜥 8 / Rocky Linux 8 / CentOS 8)
linux·运维·数据库
cui_ruicheng6 分钟前
Linux进程间通信(一):管道与IPC基础
linux·运维·服务器
liao__ran6 分钟前
Kubernetes攻防 攻击 lxcfs
云原生·容器·kubernetes
一叶龙洲34 分钟前
Ubuntu开机无法用向日葵远程控制
linux·运维·ubuntu
计算机安禾1 小时前
【Linux从入门到镜头】第29篇:文本处理三剑客(下)——awk 数据处理神器
linux·运维·服务器
流年似水~1 小时前
Docker/Kubernetes 实战:从入门到生产级部署
人工智能·程序人生·docker·语言模型·ai编程
网络安全许木1 小时前
自学渗透测试第28天(协议补漏与FTP抓包)
运维·服务器·网络安全·渗透测试·php
东北甜妹1 小时前
K8s -探针
云原生·容器·kubernetes
从负无穷开始的三次元代码生活1 小时前
Docker生产环境实战从0-1学习基础指南——快速掌握
学习·docker·容器·云技术
郑寿昌1 小时前
K8s中GPU智能体扩缩容的显存碎片优化
云原生·容器·kubernetes