首发: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/

直接运行起来即可。

查看日志没有报错

这样部署就完成了。

相关推荐
悟空码字1 小时前
SpringBoot实现系统监控:给应用装上“健康手环”
java·后端·监控
葡萄成熟时 !1 小时前
快捷键idea
java
吃喝不愁霸王餐APP开发者1 小时前
外卖霸王餐灰度开关:基于Spring Cloud Config+Bus动态刷新踩坑
java
雨中飘荡的记忆1 小时前
Spring Security详解
java·spring
babywew11 小时前
探索弹道计算软件:Matlab GUI 背后的秘密
docker
小许学java1 小时前
网络编程套接字
java·网络·udp·socket·tcp·套接字
向葭奔赴♡1 小时前
Android AlertDialog实战:5种常用对话框实现
android·java·开发语言·贪心算法·gitee
坐不住的爱码1 小时前
静态资源映射-spring整合
java·spring·状态模式
大佐不会说日语~1 小时前
基于Spring AI Alibaba的AI聊天系统中,流式输出暂停时出现重复插入问题的分析与解决
java·人工智能·spring