docker安装部署TDengine实现主从复制

引言

在物联网和大数据领域,时序数据库的重要性日益凸显。TDengine 作为一款高性能的开源时序数据库,以其出色的读写性能、低存储成本和便捷的集群管理能力,成为众多开发者的首选。本文将详细介绍如何通过 Docker 快速搭建 TDengine 集群,帮助你轻松实现数据的高效存储与管理。

准备工作

在开始部署之前,确保你的服务器满足以下条件:

  • 操作系统:支持 Docker 的 Linux 发行版(如 CentOS、Ubuntu 等)
  • Docker 已安装并正常运行
  • 服务器之间网络互通
  • 规划好主节点和从节点的 IP 地址

步骤一:主节点配置

  1. 在主节点创建TDengine所需文件夹

    mkdir /data/tdengine/config
    mkdir /data/tdengine/data
    mkdir /data/tdengine/log

  2. config文件夹下创建taos.cfg,并输入如下内容

    firstEp tdengine-node1:6030
    secondEp tdengine-node2:6030
    fqdn tdengine-node1
    serverPort 6030
    timezone Asia/Shanghai (CST, +0800)

  3. 在/data/tdengine目录下创建start-tdengine-node1.sh,并编辑脚本内容如下:

    docker run -d
    --hostname tdengine-node1
    --name tdengine-node1
    --privileged
    --network host
    -v /data/tdengine/data:/var/lib/taos
    -v /data/tdengine/logs:/var/log/taos
    -v /data/tdengine/config/taos.cfg:/etc/taos/taos.cfg
    --restart always
    tdengine/tdengine

  4. 编辑/etc/hosts文件

    主节点IP tdengine-node1
    从节点IP tdengine-node2

  5. 执行start-tdengine-node1.sh脚本

    sh start-tdengine-node1.sh

步骤二: 从节点配置

  1. 在从节点创建TDengine所需文件夹

    mkdir /data/tdengine/config
    mkdir /data/tdengine/data
    mkdir /data/tdengine/log

  2. config文件夹下创建taos.cfg,并输入如下内容

    firstEp tdengine-node1:6030
    secondEp tdengine-node2:6030
    fqdn tdengine-node2
    serverPort 6030
    timezone Asia/Shanghai (CST, +0800)

  3. 在/data/tdengine目录下创建start-tdengine-node1.sh,并编辑脚本内容如下:

    docker run -d
    --hostname tdengine-node2
    --name tdengine-node2
    --privileged
    --network host
    -v /data/tdengine/data:/var/lib/taos
    -v /data/tdengine/logs:/var/log/taos
    -v /data/tdengine/config/taos.cfg:/etc/taos/taos.cfg
    --restart always
    tdengine/tdengine

  4. 编辑/etc/hosts文件

    主节点ip tdengine-node1
    从节点ip tdengine-node2

  5. 执行start-tdengine-node1.sh脚本

    sh start-tdengine-node2.sh

步骤三:验证

  1. 登入主节点

    docker exec -it tdengine-node1 bash

    taos

  2. 添加节点

    create dnode "tdengine-node2:6030";

  • 查看节点信息

    常见问题及解决方法
    问题 1:从节点状态显示为 offline
    可能原因:
  • 网络问题,主从节点之间无法通信
  • 配置文件中 TAOS_CLUSTER_NAME、TAOS_FIRST_EP、TAOS_FQDN 等配置不一致或错误
  • TDengine 服务未正常启动

解决方法:

  • 检查主从节点之间的网络连通性,使用 ping 和 nc 命令测试端口是否可达
  • 仔细核对主从节点的配置文件和环境变量,确保配置一致且正确
  • 查看容器日志,确认 TDengine 服务是否正常启动,若未启动,根据日志错误提示进行修复

问题 2:创建数据库时出现 Invalid database options 错误

可能原因:

  • 设置的副本数超过集群中可用的数据节点数量
  • 数据保留策略、块大小等参数设置不合理

解决方法:

  • 确保副本数不超过数据节点数量
  • 检查创建数据库 SQL 语句中的参数设置,参考官方文档设置合理的参数值

总结

通过 Docker 部署 TDengine 集群,不仅简化了安装和配置过程,还能更好地实现资源隔离和管理。在实际应用中,你可以根据业务需求扩展集群节点数量,提升数据处理能力。希望本文能帮助你顺利完成 TDengine 集群的搭建,开启高效的数据管理之旅。如果在部署过程中遇到其他问题,欢迎在评论区留言交流!

相关推荐
我是谁??9 小时前
ubuntu22.04 通过docker部署vLLM(Qwen3-0.6B)大模型+New API+OpenWebUI
docker·容器·vllm
运维瓦工9 小时前
DevOps 生态介绍(十):Docker Compose 核心 YAML 配置详解与常用命令大全
spring cloud·docker·容器
云烟成雨TD9 小时前
Spring AI 1.x 系列【59】容器化开发支持:Docker Compose 与 Testcontainers
人工智能·spring·docker
Plastic garden10 小时前
K8s(10)NFS 的动态 PV 创建数据库给k8s的mysql和redis
docker·容器·kubernetes
与海boy10 小时前
docker compose minio
docker·容器·eureka
JimCarter11 小时前
使用Azure Devops Pipeline将Docker应用部署到你的Raspberry Pi上
docker·azure·树莓派·devops·orangepi·香橙派·raspberrypi
武子康11 小时前
调查研究-167 Docker Compose 详解:从单容器到多服务编排的工程化入口
运维·docker·云原生·容器·kubernetes·k8s·docker-compose
旅僧12 小时前
Ubantu docker环境配置(前置)
运维·docker·容器
“码”力全开12 小时前
解耦异构算力:基于 Docker 与边缘计算的 AI 视频管理平台,实现 GB28181/RTSP 统一接入与源码交付深度解析
人工智能·docker·边缘计算