开源项目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容器化部署就完成了。

相关推荐
Coding君9 小时前
每日一Go-28、Go语言进阶-深入Go运行时:内存管理与GC
go
echo本尊472189 小时前
如何设计一个简单易用的定时任务模块
go
ursazoo9 小时前
写了一份 7000字指南,让 AI 帮我消化每天的信息流
人工智能·开源·github
冬奇Lab16 小时前
一天一个开源项目(第37篇):awesome-selfhosted - 自托管软件资源集合
开源·自动化运维·资讯
冬奇Lab1 天前
一天一个开源项目(第36篇):EverMemOS - 跨 LLM 与平台的长时记忆 OS,让 Agent 会记忆更会推理
人工智能·开源·资讯
冬奇Lab1 天前
OpenClaw 源码深度解析(一):Gateway——为什么需要一个"中枢"
人工智能·开源·源码阅读
Bigger1 天前
告别版本焦虑:如何为 Hugo 项目定制专属构建环境
前端·架构·go
HelloGitHub2 天前
《HelloGitHub》第 119 期
开源·github
刀法如飞2 天前
一款Go语言Gin框架MVC脚手架,满足大部分场景
go·mvc·gin