自己动手实现一个简单的Linux AI Agent

大模型带我们来到了自然语言人机交互的时代

1、安装本地大模型进行推理

下载地址:
https://ollama.com/download

部署本地deepseek

bash 复制代码
ollama run deepseek-r1:7b

2、制定Linux操作接口指令规范

需要ai推理生成的json格式:

json 复制代码
[
    {
        "host": "10.1.1.10",
        "OS": "CentOS7.9",
        "user": "root",
        "ssh_port": 22,
        "command": "df -h"
    }
]

提示词:

复制代码
有如下json中的主机,请结合用户需求和OS类型给出准确的command命令替换"command"键值:
[
    {
        "host": "10.1.1.10",
        "OS": "CentOS7.9",
        "user": "root",
        "ssh_port": 22,
        "command": "df -h"
    }
]
其他key未说明情况下为默认,请根据用户需求返回json,仅回复json文本。

在page assist中测试提示词

命令最好是使用提示词都规范下:

3、编写大模型对话工具

python 复制代码
#!/usr/bin/python3
#coding: utf-8

import json
import requests

model = "llama3"

def chat(messages):
    r = requests.post(
        "http://localhost:11434/api/chat",
        json={"model": model, "messages": messages, "stream": True},
    )
    r.raise_for_status()
    output = ""
    for line in r.iter_lines():
        body = json.loads(line)
        if "error" in body:
            raise Exception(body["error"])
        if body.get("done") is False:
            message = body.get("message", "")
            content = message.get("content", "")
            output += content
            print(content, end="", flush=True)
        if body.get("done", False):
            message["content"] = output
            return message

def main():
    messages = []
    while True:
        user_input = input("Enter a prompt: ")
        if not user_input:
            exit()
        print()
        messages.append({"role": "user", "content": user_input})
        message = chat(messages)
        messages.append(message)
        print("\n\n")

if __name__ == "__main__":
    main()

4、运行AI Agent查看效果


未完待续

相关推荐
IT_陈寒1 小时前
JavaScript项目实战经验分享
前端·人工智能·后端
vanuan2 小时前
两个AI智能体第一次对话-A2A双Agent协作实战
人工智能
kfaino4 小时前
码农的AI翻身(四)你好,我叫 Attention
人工智能·后端
雨落Re6 小时前
如何设计一个高质量Skill
人工智能
Token炼金师6 小时前
大模型权重文件全指南:从格式选择到优化实战
人工智能
阿牛哥_GX7 小时前
CDP 浏览器操控原理:让脚本接管你的浏览器
人工智能
ThreeS7 小时前
手搓MiniVLA全实战教程-一步一步用pytorch解释原理与思路
人工智能·python
米小虾7 小时前
Loop Engineering —— 循环的设计与自主执行
人工智能·agent
米小虾8 小时前
Harness Engineering —— 系统的安全护栏
人工智能·agent
火山引擎开发者社区8 小时前
积分当钱花,火山引擎开发者激励计划首月消费双倍回馈
人工智能