【ai_agent】从零写一个agent框架(四)用rust制作一个python的虚拟运行环境。

前言

为了增加框架的扩展性和适用性,我们要能够在流程节点中运行python脚本。

这个时候需要考虑几个问题:

1 为什么是python?

思考:老实说我并不喜欢python,我更倾向于lua这种短小轻快的脚本。在我之前写的规则引擎rush里,就用的lua脚本写规则。并且我对比过多个脚本的性能,lua可以甩python几条街。

但是,python是大众的选择,被更多的人接受,没得选,只能是它。

这里有屌大的就要说了,为啥不用js,不用wasm,它们用的人也很多。不管是从应用的角度看,还是从平台的角度讲,长远来看这哥俩也是要支持的。

2 能在业务pod里面执行python吗?

肯定是不能,一般在服务端运行的脚本都要有个沙盒环境。

  • 一是为了避免不同本地环境造成的版本差异,包的差异等等。
  • 二是为了打造一个安全封闭的运行环境,避免和其他服务相互影响。

3 用类似cmd这种命令执行python脚本可以吗?

当然是不可以,因为这会失去对脚本的约束。

4 运行python文件还是运行python文本?

在表现形式上,文本能力必须要支持。绝大多数的agent编辑平台提供的都是python文本的编辑能力,运行能力,可能它们对于python脚本的定义仅用来实现一些简单功能。

但是我做的agent越多就越难受,因为一个稍微复杂的功能,我要在这个文档框里写大几千行,实难维护。

这些平台提供的编辑视图,都极为垃圾,我们很难在浏览器上做到vscode或者pycharm这种专业编辑器的舒适度

更重要的是一些复杂功能需要多个文件来编写,如果仅支持文本就自废武功了。

实现

思路如下:

用rust包装一个python的运行时,然后做成docker ,对外提供一个rpc的接口。

代码仓库传送门

python运行时实现

  • 我这里用的pyo3完成rust和python的绑定。
  • python的入口必须是一个函数,但函数可以指定
  • 支持指定syspath,这样就可以加载python文件。文件可以通过k8s的pv挂载,或者as3挂载。
  • 这里安全相关的模块我懒的做了,工程链路里是必须要做的。

代码如下:

pub  fn eval_function(&self, function_name: &str, args: Value) -> PyResult<Value> {wd_log::log_debug_ln!("eval_function -> {:?} args:{:?}", self, args);let  Self {src,module_name,file_name,sys_path,} = self;let file_name = file_name.clone().unwrap_or(format!("{}.py", module_name));Python::with_gil(move |py| {//设置系统pathif  let  Some(path) = sys_path {let syspath: &PyList = py.import_bound("sys") ? .getattr("path") ? .extract() ? ;syspath.insert(0, &path) ? ;}//加载模型let module = match src {ScriptSrc::ScriptCode(script) => PyModule::from_code_bound(py,script.as_str(),file_name.as_str(),module_name.as_str(),) ? ,ScriptSrc::ModuleName => PyModule::import_bound(py, module_name.as_str()) ? ,};//加载函数let function = module.getattr(function_name) ? ;//拼接输入let input_obj = Self::value_to_py_object(py, args) ? ;let input_class = FunctionInput { data: input_obj };//调起函数let output_obj = function.call((input_class,), None) ? .extract::<PyObject>() ? ;//输出转格式let value = Self::py_object_to_value(output_obj, py) ? ;Ok(value)})
}

入参的绑定

  • 入参绑定为python的class,如下代码,真正的入参是这个class里面的data
  • 包装class的目的是为py提供一些外部方法,可以操作rust里面的内容,或者获取一些不可变更参数,当然懒惰的我没实现任何方法。
#[pyclass]
pub  struct FunctionInput {#[pyo3(get, set)]data: PyObject,
}

对外接口

对外我们还是提供grpc接口,proto文件如下:

  • 这里我们指明入参类型是google/protobuf/struct,它最终会转化为python的dict传给py脚本。
  • grpc的实现我这里就不贴了,主要用的tonic框架。
  • tonic的client需要我们自己实现连接池,我用的wd_tools::pool:ObjPool
syntax = "proto3";package proto;import "google/api/annotations.proto";
import "google/protobuf/struct.proto";service PythonRuntimeService{rpc CallFunction(CallFunctionRequest)returns (CallFunctionResponse){option (google.api.http) = {post: "/api/v1/function/{function_name}"body: "*"};};
}enum  SrcType {SRC_TYPE_SCRIPT = 0;SRC_TYPE_MODULE = 1;
}
message CallFunctionRequest{SrcType src = 1;// if src == SRC_TYPE_SCRIPT, script_code must have a python code.
optional string script_code = 2;string module_name = 3;//default: file_name = module_name.py
optional string file_name = 4;optional string sys_path = 5;string function_name = 6;google.protobuf.Struct function_input = 7;}
message CallFunctionResponse{// 0:success
int32 code = 1;string msg = 2;optional google.protobuf.Struct output = 3;
}

docker构建

因为我们用的pyo3,它依赖libpython和rust环境,所以我们需要对rust的官方镜像做亿点小小的改造。

  • 首先rust的官方镜像就很有问题,用它镜像打出来的包里面的依赖都不完整。比如用rust:1.78-alpine打包就一直提示缺着缺那。
  • rust的alpine的镜像使用musl编译,按理说我静态编译后,它应该更容易被用起来。万万没想到在相同版本的alpine镜像中竟然跑不起来。
  • pyo3在编译的时候,会内置一些py信息,即便的相同的版本,不同的运行系统也无法编译。也就是说我们很难跨平台编译。

当然还有一堆堆的坑,所幸我已经爬完了,并且把镜像放到了hub上。

  • 构建镜像:wdshihaoren/python_rt:build-1.75-240527 ,你也可以用它编译自己的任意rust项目。
  • 运行镜像:wdshihaoren/python_rt:16896997,非常的精简小巧,只有30M,如下图:

image.png

测试

首先启动测试用例,在python_rt目录下如下命令启动

  • 先装一下psutil库
cargo test tests::run_server -- --nocapture

先测试一下文件执行,py文件内容地址,用grpc请求结果如下:

请求:
{"src": 1,"module_name": "sys_info","sys_path":"./custom_plugin","function_name": "get_system_info","function_input": {"fields": {"hello": {"kind": "world"}}}
}
响应:
{"code": 0,"msg": "success","output": {"fields": {"cpu_count": {"numberValue": 12,"kind": "numberValue"},"cpu_percent": {"numberValue": 16.7,"kind": "numberValue"},"disk_free": {"numberValue": 141.9490623474121,"kind": "numberValue"},"disk_total": {"numberValue": 465.62699127197266,"kind": "numberValue"},"disk_used": {"numberValue": 23.568099975585938,"kind": "numberValue"},"memory_available": {"numberValue": 11853.76171875,"kind": "numberValue"},"memory_total": {"numberValue": 32768,"kind": "numberValue"},"os_release": {"stringValue": "21.3.0","kind": "stringValue"},"os_type": {"stringValue": "Darwin","kind": "stringValue"}}}
}

再测试一下参数输入:正确给出结果

输入:
{"src": 1,"module_name": "sys_info","sys_path": "custom_plugin","function_name": "generate_system_report","function_input": {"fields": {"cpu_count": {"numberValue": 12,"kind": "numberValue"},...//和上面的内容一样,粘下来就可以了}}
}
输出:
{"code": 0,"msg": ""\n系统报告:\n\n操作系统类型: Darwin\n操作系统版本: 21.3.0\nCPU逻辑核心数: 12.0\nCPU使用率: 23.5%\n内存总量: 32768.0 MB\n可用内存: 13596.53515625 MB\n磁盘总量: 465.62699127197266 GB\n磁盘已使用: 23.568099975585938 GB\n磁盘剩余: 159.18515014648438 GB\n    "","output": {"fields": {}}
}

测试一下文本脚本能力,我们按照 【ai_agent】从零写一个agent框架(一)打造最强开放agent编辑框架,拳打dify,脚踩coze 中的实例依次启动服务。

然后如图创建三个节点,点击debug执行,可以看到python执行的结果。

image.png

尾语

做的事情很简单,但是坑很多,重点是很多事情需要权衡和思考。如果你有不一样的想法欢迎留言讨论。

如何学习大模型

现在社会上大模型越来越普及了,已经有很多人都想往这里面扎,但是却找不到适合的方法去学习。

作为一名资深码农,初入大模型时也吃了很多亏,踩了无数坑。现在我想把我的经验和知识分享给你们,帮助你们学习AI大模型,能够解决你们学习中的困难。

我已将重要的AI大模型资料包括市面上AI大模型各大白皮书、AGI大模型系统学习路线、AI大模型视频教程、实战学习,等录播视频免费分享出来,需要的小伙伴可以扫取。

一、AGI大模型系统学习路线

很多人学习大模型的时候没有方向,东学一点西学一点,像只无头苍蝇乱撞,我下面分享的这个学习路线希望能够帮助到你们学习AI大模型。

在这里插入图片描述

二、AI大模型视频教程

在这里插入图片描述

三、AI大模型各大学习书籍

在这里插入图片描述

四、AI大模型各大场景实战案例

在这里插入图片描述

五、结束语

学习AI大模型是当前科技发展的趋势,它不仅能够为我们提供更多的机会和挑战,还能够让我们更好地理解和应用人工智能技术。通过学习AI大模型,我们可以深入了解深度学习、神经网络等核心概念,并将其应用于自然语言处理、计算机视觉、语音识别等领域。同时,掌握AI大模型还能够为我们的职业发展增添竞争力,成为未来技术领域的领导者。

再者,学习AI大模型也能为我们自己创造更多的价值,提供更多的岗位以及副业创收,让自己的生活更上一层楼。

因此,学习AI大模型是一项有前景且值得投入的时间和精力的重要选择。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/pingmian/44106.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【黑龙江等保测评流程——医院篇】

黑龙江作为东北地区的重要城市&#xff0c;随着我国医疗产业信息化水平的不断提高&#xff0c;医院等保评估工作也越来越重要。等保测试就是根据国家有关的法律、法规、标准&#xff0c;对医院信息系统所做的一次全面的安全检测和评价。以下将对黑龙江医院的等保测评程序进行具…

三品PLM管理系统软件:制造企业工程变更管理的革新者

在当今快速变化的市场环境中&#xff0c;制造企业面临着前所未有的挑战。客户需求的不断变化、供应链的波动、设计过程中的不确定性以及产品生命周期的缩短&#xff0c;都要求企业能够迅速响应并适应这些变化。工程变更管理作为企业响应市场变化、提升产品竞争力的关键环节&…

RSA加密算法因N强度不足破解实例

已知如下RSA密文和公钥信息&#xff0c;要求解密得到明文。 ----------------------- ciphertext&#xff08;HEX&#xff09; 94808F954A8AF9B9 N&#xff08;HEX&#xff09; C6EAD137492B4631 e&#xff08;HEX&#xff09; 10001 ------------------------ 分析过…

Docker-搭建部署Jenkins(保姆篇)

文章目录 Jenkins部署拉取镜像启动容器查看初始密码关闭CSRF Jenkins页面使用解决插件下载缓慢访问jenkins页面推荐插件安装创建一个管理员账号实例配置页面展示 更多相关内容可查看 Jenkins部署 拉取镜像 如果想拉取对应版本请指明版本号 docker pull jenkins/jenkins:lts-…

springboot轻松音乐-计算机毕业设计源码48092

目 录 摘要 1 绪论 1.1研究背景与意义 1.2研究现状 1.3论文结构与章节安排 2 基于微信小程序的轻松音乐系统分析 2.1 可行性分析 2.1.1 技术可行性分析 2.1.2 经济可行性分析 2.1.3 法律可行性分析 2.2 系统功能分析 2.2.1 功能性分析 2.3 系统用例分析 2.4 系统…

持久化存储与设备环境查询的最佳实践

ArkUI框架中的PersistentStorage和Environment 在ArkUI框架中&#xff0c;持久化存储和设备环境查询是应用开发中不可或缺的两个重要功能。在本文中&#xff0c;我们将深入了解框架提供的PersistentStorage和Environment&#xff0c;它们的用途、限制条件以及在应用开发中的使…

Linux 防火墙配置指南:firewalld不同服务管理的应用案例(十个)

&#x1f3e1;作者主页&#xff1a;点击&#xff01; &#x1f427;Linux基础知识(初学)&#xff1a;点击&#xff01; &#x1f427;Linux高级管理专栏&#xff1a;点击&#xff01; &#x1f510;Linux中firewalld防火墙&#xff1a;点击&#xff01; ⏰️创作时间&…

云手机批量操作使用场景,从Amazon、TK等软件分析

云手机目前所具备的群控&#xff0c;批量操作&#xff0c;自动化等功能&#xff0c;对于电商&#xff0c;软测&#xff0c;办公&#xff0c;直播&#xff0c;营销等行业有很好的减负作用。 针对于具体的海外APP&#xff0c;云手机具体可以做哪些事情来帮助我们减轻压力&#x…

又一款代码神器,效率直接翻倍!免费的还是香啊!

在现代软件开发的世界里&#xff0c;工具的选择可以极大地影响开发者的效率和体验。而现在&#xff0c;有一款专为“懒人”开发者设计的一站式开发神器横空出世&#xff0c;它就是——MemFire Cloud。这款神器不仅能大幅提升开发效率&#xff0c;而且是免费的。让我们一起来看看…

IEC62056标准体系简介-3.IEC62056-62接口类(IC)

IEC62056-62接口类将IEC 62056-61对象标识系统中的数据项进行分类、归整&#xff0c;采用对象建模的方法构造了计量仪表通信的接口模型&#xff0c;规定了计量仪表的功能、数据显示和数据交换方式等&#xff0c;是COSEM核心组成部分。COSEM把计量仪表看成是公共事业部门商业过程…

vmware 虚拟机扩容 centos 硬盘扩容 kylinos v10扩容

1. 虚拟机先扩容 1.1 关机&#xff0c;并点击系统&#xff0c;让他是点选状态&#xff0c;但是没开机 1.2 右击&#xff0c;点击最下方设置&#xff0c;点击硬盘 1.3 点击扩展磁盘 1.4 选择你需要扩容的大小&#xff0c;数字为总大小 完成提示&#xff1a; 磁盘已成功扩展。您…

李良济“小儿推拿妈妈班”圆满结课,以中医智慧守护儿童健康成长!

孩子生场病&#xff0c;妈妈半条命&#xff01;作为妈妈最害怕的就是孩子生病&#xff0c;自己又无能为力&#xff01; 为了帮助妈妈们&#xff0c;正确应对孩子健康问题&#xff0c;日常生活中科学帮助孩子提升体质少生病&#xff01; 参加此次课程的&#xff0c;不仅有妈妈&a…

软件缺陷简介

缺陷种类 遗漏&#xff0c;指规定或预期的需求为体现在产品种错误&#xff0c;需求是明确的&#xff0c;在实现阶段未将需求的功能正确实现冗余&#xff0c;需求说明文档中未涉及的需求被实现了不满意&#xff0c;用户对产品的实现不满意也成为缺陷 缺陷等级划分 致命&#…

LeetCode刷题之HOT100之最长递增子序列

2024/7/10 晴&#xff0c;睡眠质量良好&#xff0c;到实验室时间9.18。知了在窗外聒噪&#xff0c;似乎让我安心&#xff0c;静下来。做题吧 1、题目描述 2、算法分析 给一个整数数组&#xff0c;要求出里面最长严格递增子序列的长度。遇到这种问题&#xff0c;想到的就是DP算…

基于JavaSpringBoot+Vue+uniapp微信小程序校园宿舍管理系统设计与实现(论文7000字参考+源码+LW+部署讲解)

博主介绍&#xff1a;硕士研究生&#xff0c;专注于信息化技术领域开发与管理&#xff0c;会使用java、标准c/c等开发语言&#xff0c;以及毕业项目实战✌ 从事基于java BS架构、CS架构、c/c 编程工作近16年&#xff0c;拥有近12年的管理工作经验&#xff0c;拥有较丰富的技术架…

多个单元运算符合用???:::

string a "a";string b "b";string c "c";string r a "a" ? b "b" ? c"c" ? "b" : "cc" : "33":"44";string rr a "a"? b "b" ?(c …

突破AI性能瓶颈 揭秘LLaMA-MoE模型的高效分配策略

获取本文论文原文PDF&#xff0c;请在公众号【AI论文解读】留言&#xff1a;论文解读 本文介绍了一种名为“LLaMA-MoE”的方法&#xff0c;通过将现有的大型语言模型&#xff08;LLMs&#xff09;转化为混合专家网络&#xff08;MoE&#xff09;&#xff0c;从而解决了训练MoE…

4. kvm存储虚拟化

kvm存储虚拟化 一、命令行工具管理虚拟磁盘1、查看虚拟磁盘2、添加磁盘3、删除磁盘 二、qcow2格式的磁盘文件1、创建磁盘文件2、差量镜像/快速创建虚机2.1 创建差量镜像2.2 准备配置文件2.3 创建虚拟机2.4 批量部署虚拟机 三、存储池 storage pool1、类型2、在线迁移2.1 规划后…

DNF手游攻略:云手机辅助刷副本!内置辅助工具!

DNF手游是一款备受玩家喜爱的角色扮演类游戏&#xff0c;以其独特的地下城探险和多样化的装备系统而闻名。玩家需要通过不断的挑战和升级&#xff0c;逐步增强自己的角色实力&#xff0c;最终完成各种高难度的副本任务。游戏的核心玩法包括打怪、刷装备、升级技能等。 游戏辅助…

LeetCode热题100刷题10:46. 全排列、78. 子集、17. 电话号码的字母组合、39. 组合总和、138. 随机链表的复制

回溯问题 46. 全排列 全排列问题&#xff1a; path 递归终止条件&#xff1a;path中是否已存储所有元素&#xff1b; for循环处理节点集合&#xff1a;used0未被使用的元素 class Solution { public:vector<int> path;vector<vector<int>> res;void backt…