首发:TDengine3.3.6版本使用K8S部署

环境

arm64架构银河麒麟v10系统,k8s采用1.21版本,在此基础上把TDengine数据库在k8s上完成部署并测试。

yaml

yaml 复制代码
# TDengine 3.3.6.0 (ARM64/麒麟) 部署配置
# 适配 K8s 1.21,解决 taosadapter 配置解析 panic 问题
apiVersion: apps/v1
kind: Deployment
metadata:
  name: tdengine
  namespace: default  # 可自定义命名空间(需提前创建:kubectl create ns tdengine)
  labels:
    app: tdengine
    version: "3.3.6.0"
    arch: aarch64
spec:
  replicas: 1  # 单实例(TDengine单机部署,集群需改配置)
  selector:
    matchLabels:
      app: tdengine
  strategy:
    type: Recreate  # 避免多实例冲突,重建式更新
  template:
    metadata:
      labels:
        app: tdengine
        version: "3.3.6.0"
        arch: aarch64
    spec:
      hostname: tdengine-server  # TDengine 节点标识(必填,影响集群通信)
      containers:
      - name: tdengine
        image: tdengine/tdengine-ee-aarch64:3.3.6.0  # ARM64 架构镜像
        imagePullPolicy: IfNotPresent  # 优先使用本地镜像,避免重复拉取
        ports:
        - containerPort: 6030  # TDengine 核心服务端口
        - containerPort: 6041  # taosadapter REST API 端口(关键)
        - containerPort: 6043  # TDengine 集群管理端口
        - containerPort: 6060  # TDengine Web 管理端口
        - containerPort: 6040  # TDengine 订阅端口
        # 环境变量(核心配置,避免默认值冲突)
        env:
        - name: TAOS_FQDN
          value: "tdengine-server"  # 必须与 hostname 一致
        - name: TZ
          value: "Asia/Shanghai"    # 时区配置
        - name: TAOS_ADAPTER_CONFIG
          value: "/etc/taos/taosadapter.toml"  # 指定合法配置文件路径
        # 持久化存储挂载(数据/日志/配置)
        volumeMounts:
        - name: tdengine-data
          mountPath: /var/lib/taos  # TDengine 数据目录(持久化核心)
        - name: tdengine-log
          mountPath: /var/log/taos  # 日志目录
        - name: tdengine-config
          mountPath: /etc/taos      # 配置目录(含修复后的 taosadapter.toml)
        # 健康检查(确保服务可用)
        resources:
          limits:
            cpu: "2"       # 最大CPU核心数
            memory: 4Gi    # 最大内存
          requests:
            cpu: "1"       # 最小CPU核心数
            memory: 2Gi    # 最小内存
        # 权限配置(解决目录读写权限问题)
        securityContext:
          runAsUser: 0     # 以 root 运行(TDengine 需读写系统目录)
          runAsGroup: 0
          privileged: false
      # 初始化容器:提前修复 taosadapter.toml 配置(核心!解决 panic 问题)
      initContainers:
      - name: fix-taosadapter-config
        image: tdengine/tdengine-ee-aarch64:3.3.6.0
        command: ["/bin/sh", "-c"]
        args:
        - |
          # 备份原有错误配置
          mv /etc/taos/taosadapter.toml /etc/taos/taosadapter.toml.bak 2>/dev/null;
          # 写入合法的 taosadapter 配置(无无效字符)
          cat > /etc/taos/taosadapter.toml << 'EOF'
          # TDengine taosadapter 3.3.6.0 合法配置
          [core]
          log-level = "info"
          log-dir = "/var/log/taos"
          [server]
          http-port = 6041
          bind-addr = "0.0.0.0"
          enable-https = false
          [taos]
          host = "127.0.0.1"
          port = 6030
          username = "root"
          password = "taosdata"
          EOF
          # 修复配置文件权限
          chmod 644 /etc/taos/taosadapter.toml;
          chown root:root /etc/taos/taosadapter.toml;
        volumeMounts:
        - name: tdengine-config
          mountPath: /etc/taos
      # 存储卷定义(hostPath 适合测试,生产建议替换为 PVC)
      volumes:
      - name: tdengine-data
        hostPath:
          path: /data/tdengine/data  # 宿主机数据目录(需提前创建)
          type: DirectoryOrCreate    # 不存在则自动创建
      - name: tdengine-log
        hostPath:
          path: /data/tdengine/log   # 宿主机日志目录
          type: DirectoryOrCreate
      - name: tdengine-config
        hostPath:
          path: /data/tdengine/config  # 宿主机配置目录
          type: DirectoryOrCreate
---
# TDengine Service:暴露端口供集群内/外访问
apiVersion: v1
kind: Service
metadata:
  name: tdengine-service
  namespace: default
  labels:
    app: tdengine
spec:
  type: NodePort  # 外网访问用 NodePort,生产可改 LoadBalancer
  selector:
    app: tdengine  # 匹配 Deployment 的 Pod 标签
  ports:
  - name: tdengine-core  # 6030 核心端口
    port: 6030
    targetPort: 6030
    nodePort: 30030      # 宿主机映射端口(30000-32767 范围内)
  - name: taosadapter-api  # 6041 REST API 端口
    port: 6041
    targetPort: 6041
    nodePort: 30041
  - name: tdengine-web  # 6060 Web 管理端口
    port: 6060
    targetPort: 6060
    nodePort: 30060
  - name: tdengine-cluster  # 6043 集群端口
    port: 6043
    targetPort: 6043
    nodePort: 30043

接着把宿主机的目录授权下

复制代码
chmod 777 -R /data/tdengine/

直接运行起来即可。

查看日志没有报错

这样部署就完成了。

相关推荐
zhixingheyi_tian12 小时前
Yarn 之 run job
java·开发语言·前端
特立独行的猫a12 小时前
PostgreSQL客户端工具介绍:从性能测试到跨平台管理
数据库·docker·postgresql·客户端·pgadmin4
2501_9167665412 小时前
【Java】代理模式---静态代理与动态代理
java·开发语言·代理模式
纸带12 小时前
USB CDC 配置描述符中对比两个CDC设备配置
java·网络·windows
AI视觉网奇12 小时前
audio2face docker方式
docker·ue5
缺点内向12 小时前
Java:轻松实现 Excel 文档属性添加
java·开发语言·excel
pangtao202512 小时前
【瑞萨RA × Zephyr评测】看门狗
java·后端·spring
HappyBoy_201913 小时前
MybatisPlus IPage分页查询工具类
java·开发语言
小徐Chao努力13 小时前
【Langchain4j-Java AI开发】10-框架集成(Spring Boot & Quarkus)
java·人工智能·spring boot
2501_9167665413 小时前
【Java】final关键字
java·开发语言