开源项目one-api的k8s容器化部署(下)-- 部署至k8s

一、接着上文

本文讲述如何把上文制作好的docker镜像部署到K8S,会涉及以下部分:

  • 健康检测
  • 应用程序的配置
  • 应用程序的端口
  • 日志路径

二、健康检测

1、健康状态

从官方的docker-compose.yml可以得知其健康检测方法

bash 复制代码
curl http://localhost:5175/api/status
{"data":{"chat_link":"","display_in_currency":true,"email_verification":false,"footer_html":"","github_client_id":"","github_oauth":false,"lark_client_id":"","logo":"","quota_per_unit":500000,"server_address":"http://localhost:3000","start_time":1712719277,"system_name":"One API","top_up_link":"","turnstile_check":false,"turnstile_site_key":"","version":"","wechat_login":false,"wechat_qrcode":""},"message":"","success":true}

2、deployment.yaml 增加探针

这里的{{ PORT }} 是你应用监听的端口号。

bash 复制代码
 #########################################
          readinessProbe:
            exec:
              command: ["sh", "-c", "wget -q -O - http://127.0.0.1:{{ PORT }}/api/status | grep -o '\"success\":\\s*true' | awk -F: '{print $2}'"]
            initialDelaySeconds: 5
            periodSeconds: 10
            successThreshold: 1
            timeoutSeconds: 3
            failureThreshold: 3
          startupProbe:
            exec:
              command: ["sh", "-c", "wget -q -O - http://127.0.0.1:{{ PORT }}/api/status | grep -o '\"success\":\\s*true' | awk -F: '{print $2}'"]
            initialDelaySeconds: 15
            periodSeconds: 10
            successThreshold: 1
            timeoutSeconds: 3
            failureThreshold: 22
#########################################

三、应用程序的配置

当然,你可以直接在环境变量里配置明文,但不建议!

1、新建Secret(保密字典)

  • mysql数据库连接地址SQL_DSN
  • redis连接地址REDIS_CONN_STRING
  • session密钥SESSION_SECRET

2、deployment.yaml环境变量引用secret配置

bash 复制代码
# 修改前
          env:
            - name: SQL_DSN
              value: "oneapi:123456@tcp(db:3306)/one-api"
            - name: REDIS_CONN_STRING
              value: "redis://redis"
            - name: SESSION_SECRET
              value: "random_string"


# 修改后
          env:
            - name: SQL_DSN
              valueFrom:
                secretKeyRef:
                  name: one-api-conf
                  key: sql-dsn
            - name: REDIS_CONN_STRING
              valueFrom:
                secretKeyRef:
                  name: one-api-conf
                  key: redis-conn-string
            - name: SESSION_SECRET
              valueFrom:
                secretKeyRef:
                  name: one-api-conf
                  key: session-secret

四、应用程序的端口

one-api程序的默认端口是3000,一般我们都会需要进行变更。

不同的部署策略,则有不同的方案。

1、docker-compose部署

详见下面的command: --port 5175,指定程序启动的端口号为5175。

bash 复制代码
version: '3.4'
  
services:
  one-api:
    image: "xxx/one-api:1.0.0"
    container_name: one-api
    command: --port 5175

2、k8s deploymeng.yaml

通过args传入程序启动的端口号

bash 复制代码
      containers:
        - args:
            - '--port'
            - '5175'

五、日志路径

默认的存储路径:/data/logs

oneapi-20240410.log日志内容:

程序启动进程 one-api在根目录下:

六、总结

访问地址: http://{ip}:{port} (port就是上文指定的端口号)

至此,对开源项目one-api的k8s容器化部署就完成了。

相关推荐
HalvmånEver1 分钟前
Linux:线程互斥
java·linux·运维
skywalk816313 分钟前
快速安装一个本地开源邮件系统postfix+dovecot @Ubuntu22.40
开源·邮箱·postfix·dovecot
JY.yuyu37 分钟前
Docker常用命令——数据卷管理 / 端口映射 / 容器互联
运维·docker·容器
猫头虎44 分钟前
2026年AI产业13大趋势预测:Vibe Coding创作者经济元年到来,占冰强专家解读AIGC未来图景
人工智能·开源·prompt·aigc·ai编程·远程工作·agi
chian-ocean1 小时前
智能多模态助手实战:基于 `ops-transformer` 与开源 LLM 构建 LLaVA 风格推理引擎
深度学习·开源·transformer
lpruoyu1 小时前
【Docker进阶-06】docker-compose & docker swarm
运维·docker·容器
China_Yanhy2 小时前
入职 Web3 运维日记 · 第 8 日:黑暗森林 —— 对抗 MEV 机器人的“三明治攻击”
运维·机器人·web3
艾莉丝努力练剑2 小时前
hixl vs NCCL:昇腾生态通信库的独特优势分析
运维·c++·人工智能·cann
酉鬼女又兒2 小时前
每天一个Linux命令_printf
linux·运维·服务器
虾说羊2 小时前
docker容器化部署项目流程
运维·docker·容器