微信扫码
添加专属顾问
我要投稿
用Dify结合k8s API打造轻量级Aiops智能体,从简单入手逐步构建强大运维助手。 核心内容: 1. 基于Dify工作流和k8s API的智能体架构设计 2. 关键配置步骤:变量设置、LLM意图解析和HTTP请求构造 3. 通过自然语言指令实现k8s集群运维的完整流程
做Aiops智能体,一开始我们可以先从最简单、最容易落地的入手,然后一点一点增加新的功能,从而让智能体更强大。一上来就搞得太复杂,很有可能你因为某个功能无法实现而半途而废。
今天这个智能体案例就是使用dify的http节点,来请求k8s的api,从而去控制和维护k8s集群。
user-service”)。PATCH /apis/apps/v1/namespaces/production/deployments/user-service),并附上认证信息。在 Dify 控制台创建一个新的空白工作流应用。
在工作流的“开始”节点,添加变量,例如:
k8s_api_url : 字符串类型,默认值可以是 http://<你的proxy-ip>:8001k8s_token: 字符串类型,粘贴上一步获取的 Token。user_query: 字符串类型,用于接收用户输入。
添加一个 LLM 节点(如 GPT-4),连接“开始”节点。
你是一个 Kubernetes 运维助手。你的任务是解析用户的指令,并提取出关键信息,然后以 JSON 格式输出。用户可能想查询 Pod 状态、重启 Deployment 或查看日志。请从用户的指令中提取以下信息(如果存在):- "action": 操作类型,只能是 "get_pod_status", "restart_deployment", "get_pod_logs" 中的一个。- "namespace": K8s 命名空间。- "resource_name": 资源名称,如 Pod 或 Deployment 的名称。如果信息不全,特别是 "namespace" 和 "resource_name",请询问用户。示例输入: "帮我重启一下生产环境的 user-service"示例输出: {"action": "restart_deployment", "namespace": "production", "resource_name": "user-service"}示例输入: "default 命名空间里 my-app-pod 这个 pod 怎么样了"示例输出: {"action": "get_pod_status", "namespace": "default", "resource_name": "my-app-pod"}
这是核心。添加一个“HTTP 请求”节点,连接 LLM 节点的输出。
URL: 这里需要根据 LLM 解析出的 action 动态构造。我们可以使用一个“代码”节点或“条件判断”节点来处理。为了简化示例,我们先以一个固定动作(如查询 Pod)为例。比如:{{k8s_api_url}}/api/v1/namespaces/{{#LLM.output#namespace}}/pods/{{#LLM.output#resource_name}} 注意:{{#LLM.output#namespace}} 的语法是引用上一个节点输出的 JSON 字段。
Method: GET
Headers: Authorization: Bearer {{k8s_token}}
再添加一个 LLM 节点,连接 HTTP 请求节点的输出。
你是一个 Kubernetes 运维助手。你收到了一个关于 Pod 状态的 JSON 数据。请将以下 JSON 信息转换成易于理解的中文自然语言描述,并报告 Pod 的状态、IP、节点以及最近的事件(如果有)。
{{#HTTP请求节点.text#}} (引用 HTTP 节点的 body 文本输出)default 命名空间下 my-nginx 这个 Pod 还活着吗?"staging 环境的 payment-api 重启一下"{"action": "restart_deployment", "namespace": "staging", "resource_name": "payment-api"}。PATCH 其 spec.template.metadata.annotations,添加一个带时间戳的注解来触发滚动更新。HTTP 节点配置: Method: PATCH URL: {{k8s_api_url}}/apis/apps/v1/namespaces/{{#LLM.output#namespace}}/deployments/{{#LLM.output#resource_name}} Headers: Authorization: Bearer {{k8s_token}}, Content-Type: application/strategic-merge-patch+json Body: { "spec": { "template": { "metadata": { "annotations": { "kubectl.kubernetes.io/restartedAt": "{{sys_date}}" } } } }}payment-api Deployment 发送重启指令,正在执行滚动更新。”user-service 最近响应很慢,帮我看看日志,如果 CPU 高就帮我扩容"/api/v1/namespaces/default/pods/<pod-name>/log。/apis/metrics.k8s.io/v1beta1/namespaces/default/pods/<pod-name> 获取 CPU/内存使用率。53AI,企业落地大模型首选服务商
产品:场景落地咨询+大模型应用平台+行业解决方案
承诺:免费POC验证,效果达标后再合作。零风险落地应用大模型,已交付160+中大型企业
2025-10-24
阿里夸克AI眼镜开售:叠加补贴后3699元,它能打破AI眼镜的魔咒吗?
2025-10-23
Dify平台集成阿里云AI安全护栏,构建AI Runtime安全防线
2025-10-13
Dify + 飞书组合拳:企业级 AI 安全大脑落地全指南,助力安管效率提升 300%
2025-09-23
专访Plaud中国区CEO:我们只做“必须做”和“不做要死”的事
2025-09-21
一款随时心理陪伴的AI硬件
2025-09-20
硬件不行,AI失灵,AI硬件创业者的第一道生死关
2025-09-19
刚刚,港版 iPhone 17 Air 抢空!eSIM+系统级AI,国行果粉实名羡慕
2025-09-15
钉钉AI硬件DingTalk A1,开会摸鱼的神
2025-09-19
2025-09-02
2025-10-13
2025-09-02
2025-08-25
2025-09-05
2025-09-02
2025-08-22
2025-08-28
2025-09-11