crewAI CLI 与项目结构:从原型到生产的工程化规范

news2026/3/24 9:13:18
crewAI CLI 与项目结构从原型到生产的工程化规范本文基于 crewAI v1.11.0系统介绍 crewAI 项目的标准工程结构、CLI 工具链和生产环境配置规范。一、原型与生产的鸿沟很多 crewAI 项目都死在从原型到生产的过渡阶段。原型阶段的代码通常是这样的# prototype.py别笑你写过fromcrewaiimportAgent,Task,Crew agentAgent(role研究员,goal...,backstory...)taskTask(description研究crewAI,expected_output...,agentagent)crewCrew(agents[agent],tasks[task])resultcrew.kickoff()print(result.raw)这段代码能跑但它有一堆生产问题Agent/Task 配置硬编码无法多环境切换没有依赖管理换个机器就可能跑不起来没有错误处理一报错整个程序崩溃没有日志出问题不知道哪里出了问题API Key 散落在代码各处虽然我们假设你不会这么做crewAI 提供了一套完整的工程化工具链来解决这些问题。二、使用 UV 安装 crewAIcrewAI 官方推荐使用uv作为包管理工具相比 pip/Poetry速度快 10-100 倍# 安装 uv如果还没有curl-LsSfhttps://astral.sh/uv/install.sh|sh# macOS/Linux# Windows:# powershell -c irm https://astral.sh/uv/install.ps1 | iex# 安装 crewAI带工具集uv pipinstallcrewai[tools]# 验证安装crewai--version# crewAI, version 1.11.0三、crewAI CLI快速创建标准项目3.1 创建新项目crewai create crew my_research_crew执行后crewAI 会在当前目录创建标准项目结构my_research_crew/ ├── pyproject.toml ─ 项目元数据和依赖配置 ├── .env ─ 环境变量不要提交到 Git ├── .gitignore ─ Git 忽略文件 ├── README.md ─ 项目说明 └── src/ └── my_research_crew/ ├── __init__.py ├── main.py ─ 程序入口 ├── crew.py ─ Crew 定义核心文件 ├── tools/ │ ├── __init__.py │ └── custom_tool.py ─ 自定义工具 └── config/ ├── agents.yaml ─ Agent 配置推荐在此定义 Agent └── tasks.yaml ─ Task 配置推荐在此定义 Task3.2 标准文件解析pyproject.toml项目配置文件[tool.poetry] name my-research-crew version 0.1.0 description 基于 crewAI 的技术研究自动化系统 authors [Your Name youexample.com] [tool.poetry.dependencies] python 3.10,3.13 crewai {extras [tools], version 1.11.0,2.0.0} [tool.poetry.scripts] my_research_crew my_research_crew.main:run # crewai run 的入口 [build-system] requires [poetry-core] build-backend poetry.core.masonry.apimain.py程序入口#!/usr/bin/env python# src/my_research_crew/main.pyimportsysfrommy_research_crew.crewimportMyResearchCrewdefrun():标准入口函数供 crewai run 调用inputs{topic:AI在企业知识管理中的应用,current_year:2026}try:resultMyResearchCrew().crew().kickoff(inputsinputs)print(\n*60)print(执行结果)print(*60)print(result.raw)exceptExceptionase:print(f执行失败{e},filesys.stderr)sys.exit(1)deftrain():用于训练/微调场景高级用法inputs{topic:AI研究,n_iterations:5,filename:training_data.pkl}MyResearchCrew().crew().train(**inputs)defreplay():重放指定任务调试用task_idsys.argv[1]iflen(sys.argv)1elseNoneifnottask_id:print(使用方式crewai replay task_id)sys.exit(1)MyResearchCrew().crew().replay(task_idtask_id)if__name____main__:run()crew.pyCrew 核心定义# src/my_research_crew/crew.pyfromcrewaiimportAgent,Crew,Process,Taskfromcrewai.projectimportCrewBase,agent,crew,taskfromcrewai_toolsimportSerperDevTool,ScrapeWebsiteToolCrewBaseclassMyResearchCrew:技术研究 Crew 定义agents_configconfig/agents.yamltasks_configconfig/tasks.yaml# ── 工具初始化 ──────────────────────────────────────def__init__(self):self.search_toolSerperDevTool()self.scrape_toolScrapeWebsiteTool()# ── Agent 定义 ──────────────────────────────────────agentdefresearcher(self)-Agent:returnAgent(configself.agents_config[researcher],tools[self.search_tool,self.scrape_tool],verboseTrue)agentdefanalyst(self)-Agent:returnAgent(configself.agents_config[analyst],verboseTrue)agentdefwriter(self)-Agent:returnAgent(configself.agents_config[writer],verboseTrue)# ── Task 定义 ───────────────────────────────────────taskdefresearch_task(self)-Task:returnTask(configself.tasks_config[research_task])taskdefanalysis_task(self)-Task:returnTask(configself.tasks_config[analysis_task])taskdefwriting_task(self)-Task:returnTask(configself.tasks_config[writing_task],output_filereport.md# 自动将输出保存到文件)# ── Crew 组装 ───────────────────────────────────────crewdefcrew(self)-Crew:returnCrew(agentsself.agents,# 自动收集所有 agent 装饰的方法tasksself.tasks,# 自动收集所有 task 装饰的方法processProcess.sequential,verboseTrue)四、YAML 配置生产环境的标准范式4.1 agents.yaml# src/my_research_crew/config/agents.yamlresearcher:role:高级技术研究员goal:对 {topic} 进行深度技术研究 识别 {current_year} 年最具价值的技术趋势和实践案例backstory:你是一位资深技术研究员有着10年的技术调研经验。 你擅长从海量信息中提炼关键洞见 你的调研报告以严谨、深度和实用性著称。 你永远不会引用未经验证的信息。memory:trueverbose:truemax_iter:15analyst:role:技术战略分析师goal:基于研究成果从商业价值和实施可行性角度进行深度分析backstory:你在麦肯锡数字化转型团队工作了8年 帮助超过50家企业制定AI战略。 你的分析总是聚焦商业价值而不是技术本身。memory:truewriter:role:技术写作专家goal:将复杂的技术分析转化为高管和技术团队都能看懂的报告backstory:你是前《哈佛商业评论》技术专栏作家 擅长用简洁的语言解释复杂的技术概念。 你的文章总是有清晰的结构和令人信服的论点。4.2 tasks.yaml# src/my_research_crew/config/tasks.yamlresearch_task:description:对 {topic} 进行全面的技术研究。研究维度 1.{current_year}年的主要技术突破 2. 领先企业的实践案例至少5个 3. 主要的开源项目和工具 4. 技术成熟度评估 5. 主要挑战和限制expected_output:结构化的研究报告Markdown格式包含 - 技术概述200-300字 - 关键技术突破列表每项含简短评述 - 企业案例表格公司名、行业、应用场景、规模 - 主要开源项目含GitHub链接 - 技术挑战总结agent:researcheranalysis_task:description:基于研究报告从商业价值角度进行深度分析 1. 市场规模和增长潜力附数据来源 2. 技术壁垒评估0-10分并说明理由 3. 主要应用场景的ROI分析 4. 实施路径建议expected_output:投资价值分析报告Markdown格式包含 - 市场机会评估 - 技术壁垒分析表格形式 - 典型场景ROI估算 - 推荐的实施优先级agent:analystcontext:-research_taskwriting_task:description:将研究报告和分析报告整合为面向技术决策者的综合报告。 报告应该既有深度技术人员看完能落地又有高度高管看完能决策。 字数2000-3000字。expected_output:完整的综合报告Markdown格式结构 # 执行摘要300字以内 ## 技术背景 ## 关键发现 ## 商业价值分析 ## 实施建议 ## 结论agent:writercontext:-research_task-analysis_task五、环境管理与多环境配置5.1 .env 文件配置# .env本地开发OPENAI_API_KEYsk-...SERPER_API_KEY...ANTHROPIC_API_KEYsk-ant-...# 多环境配置ENVIRONMENTdevelopment# 可选指定模型DEFAULT_LLM_MODELgpt-4oMANAGER_LLM_MODELgpt-4o# 可选日志级别LOG_LEVELINFO5.2 多环境切换# src/my_research_crew/config.pyimportosfromdotenvimportload_dotenv# 根据 ENVIRONMENT 加载不同的配置文件envos.getenv(ENVIRONMENT,development)load_dotenv(f.env.{env},overrideTrue)load_dotenv(.env)# 通用配置# 类型安全的配置类frompydanticimportBaseSettingsclassSettings(BaseSettings):openai_api_key:strserper_api_key:strdefault_llm_model:strgpt-4olog_level:strINFOenvironment:strdevelopmentclassConfig:env_file.envsettingsSettings()六、CLI 命令速查# 创建新项目crewai create crew my_crew# 运行 Crewcrewai run# 在特定目录运行cdmy_crewcrewai run# 查看帮助crewai--help# 安装依赖等同于 poetry installcrewaiinstall# 测试/重放特定任务调试用crewai replaytask_id# 查看版本crewai--version七、类型安全Pydantic v2 在 crewAI 中的应用crewAI 内部大量使用 Pydantic v2 进行数据校验开发者也应该在自定义部分保持类型安全frompydanticimportBaseModel,Field,validatorfromtypingimportList,OptionalfromenumimportEnumclassResearchDepth(str,Enum):QUICKquick# 快速调研1-2小时STANDARDstandard# 标准调研半天DEEPdeep# 深度调研1-2天classResearchRequest(BaseModel):topic:strField(min_length5,max_length200)depth:ResearchDepthResearchDepth.STANDARD focus_areas:List[str]Field(default_factorylist,max_items5)exclude_sources:List[str]Field(default_factorylist)output_language:strField(defaultzh,pattern^(zh|en)$)validator(topic)deftopic_must_be_specific(cls,v):ifany(wordinv.lower()forwordin[all,everything,general]):raiseValueError(主题过于宽泛请指定具体方向)returnv# 在 main.py 中使用类型校验defrun():try:# 验证输入参数requestResearchRequest(topiccrewAI多智能体框架在企业知识管理中的应用,depthResearchDepth.STANDARD,focus_areas[技术实现,成本效益],output_languagezh)inputsrequest.model_dump()resultMyResearchCrew().crew().kickoff(inputsinputs)exceptValidationErrorase:print(f输入参数无效{e},filesys.stderr)sys.exit(1)八、小结工程化是 crewAI 项目从能跑到能用的关键跨越项目结构标准化crewai create crew一键生成标准目录避免每个人一套结构的混乱YAML 配置优先Agent/Task 的定义从代码里分离出来便于维护和非技术人员参与环境变量管理密钥永远不进代码库多环境配置一套体系类型安全Pydantic v2 保护关键数据的合法性这些工程实践不是过度设计而是让项目在生产环境中活得更久的基本保障。系列导航上一篇crewAI 外部触发器与 API 集成Gmail/Slack/Salesforce 事件驱动下一篇crewAI 可观测性体系Langfuse/Phoenix 集成与执行链路追踪基于 crewAI v1.11.0 官方文档撰写于 2026 年 3 月

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

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

相关文章

SpringBoot-17-MyBatis动态SQL标签之常用标签

文章目录 1 代码1.1 实体User.java1.2 接口UserMapper.java1.3 映射UserMapper.xml1.3.1 标签if1.3.2 标签if和where1.3.3 标签choose和when和otherwise1.4 UserController.java2 常用动态SQL标签2.1 标签set2.1.1 UserMapper.java2.1.2 UserMapper.xml2.1.3 UserController.ja…

wordpress后台更新后 前端没变化的解决方法

使用siteground主机的wordpress网站,会出现更新了网站内容和修改了php模板文件、js文件、css文件、图片文件后,网站没有变化的情况。 不熟悉siteground主机的新手,遇到这个问题,就很抓狂,明明是哪都没操作错误&#x…

网络编程(Modbus进阶)

思维导图 Modbus RTU(先学一点理论) 概念 Modbus RTU 是工业自动化领域 最广泛应用的串行通信协议,由 Modicon 公司(现施耐德电气)于 1979 年推出。它以 高效率、强健性、易实现的特点成为工业控制系统的通信标准。 包…

UE5 学习系列(二)用户操作界面及介绍

这篇博客是 UE5 学习系列博客的第二篇,在第一篇的基础上展开这篇内容。博客参考的 B 站视频资料和第一篇的链接如下: 【Note】:如果你已经完成安装等操作,可以只执行第一篇博客中 2. 新建一个空白游戏项目 章节操作,重…

IDEA运行Tomcat出现乱码问题解决汇总

最近正值期末周,有很多同学在写期末Java web作业时,运行tomcat出现乱码问题,经过多次解决与研究,我做了如下整理: 原因: IDEA本身编码与tomcat的编码与Windows编码不同导致,Windows 系统控制台…

利用最小二乘法找圆心和半径

#include <iostream> #include <vector> #include <cmath> #include <Eigen/Dense> // 需安装Eigen库用于矩阵运算 // 定义点结构 struct Point { double x, y; Point(double x_, double y_) : x(x_), y(y_) {} }; // 最小二乘法求圆心和半径 …

使用docker在3台服务器上搭建基于redis 6.x的一主两从三台均是哨兵模式

一、环境及版本说明 如果服务器已经安装了docker,则忽略此步骤,如果没有安装,则可以按照一下方式安装: 1. 在线安装(有互联网环境): 请看我这篇文章 传送阵>> 点我查看 2. 离线安装(内网环境):请看我这篇文章 传送阵>> 点我查看 说明&#xff1a;假设每台服务器已…

XML Group端口详解

在XML数据映射过程中&#xff0c;经常需要对数据进行分组聚合操作。例如&#xff0c;当处理包含多个物料明细的XML文件时&#xff0c;可能需要将相同物料号的明细归为一组&#xff0c;或对相同物料号的数量进行求和计算。传统实现方式通常需要编写脚本代码&#xff0c;增加了开…

LBE-LEX系列工业语音播放器|预警播报器|喇叭蜂鸣器的上位机配置操作说明

LBE-LEX系列工业语音播放器|预警播报器|喇叭蜂鸣器专为工业环境精心打造&#xff0c;完美适配AGV和无人叉车。同时&#xff0c;集成以太网与语音合成技术&#xff0c;为各类高级系统&#xff08;如MES、调度系统、库位管理、立库等&#xff09;提供高效便捷的语音交互体验。 L…

(LeetCode 每日一题) 3442. 奇偶频次间的最大差值 I (哈希、字符串)

题目&#xff1a;3442. 奇偶频次间的最大差值 I 思路 &#xff1a;哈希&#xff0c;时间复杂度0(n)。 用哈希表来记录每个字符串中字符的分布情况&#xff0c;哈希表这里用数组即可实现。 C版本&#xff1a; class Solution { public:int maxDifference(string s) {int a[26]…

【大模型RAG】拍照搜题技术架构速览:三层管道、两级检索、兜底大模型

摘要 拍照搜题系统采用“三层管道&#xff08;多模态 OCR → 语义检索 → 答案渲染&#xff09;、两级检索&#xff08;倒排 BM25 向量 HNSW&#xff09;并以大语言模型兜底”的整体框架&#xff1a; 多模态 OCR 层 将题目图片经过超分、去噪、倾斜校正后&#xff0c;分别用…

【Axure高保真原型】引导弹窗

今天和大家中分享引导弹窗的原型模板&#xff0c;载入页面后&#xff0c;会显示引导弹窗&#xff0c;适用于引导用户使用页面&#xff0c;点击完成后&#xff0c;会显示下一个引导弹窗&#xff0c;直至最后一个引导弹窗完成后进入首页。具体效果可以点击下方视频观看或打开下方…

接口测试中缓存处理策略

在接口测试中&#xff0c;缓存处理策略是一个关键环节&#xff0c;直接影响测试结果的准确性和可靠性。合理的缓存处理策略能够确保测试环境的一致性&#xff0c;避免因缓存数据导致的测试偏差。以下是接口测试中常见的缓存处理策略及其详细说明&#xff1a; 一、缓存处理的核…

龙虎榜——20250610

上证指数放量收阴线&#xff0c;个股多数下跌&#xff0c;盘中受消息影响大幅波动。 深证指数放量收阴线形成顶分型&#xff0c;指数短线有调整的需求&#xff0c;大概需要一两天。 2025年6月10日龙虎榜行业方向分析 1. 金融科技 代表标的&#xff1a;御银股份、雄帝科技 驱动…

观成科技:隐蔽隧道工具Ligolo-ng加密流量分析

1.工具介绍 Ligolo-ng是一款由go编写的高效隧道工具&#xff0c;该工具基于TUN接口实现其功能&#xff0c;利用反向TCP/TLS连接建立一条隐蔽的通信信道&#xff0c;支持使用Let’s Encrypt自动生成证书。Ligolo-ng的通信隐蔽性体现在其支持多种连接方式&#xff0c;适应复杂网…

铭豹扩展坞 USB转网口 突然无法识别解决方法

当 USB 转网口扩展坞在一台笔记本上无法识别,但在其他电脑上正常工作时,问题通常出在笔记本自身或其与扩展坞的兼容性上。以下是系统化的定位思路和排查步骤,帮助你快速找到故障原因: 背景: 一个M-pard(铭豹)扩展坞的网卡突然无法识别了,扩展出来的三个USB接口正常。…

未来机器人的大脑:如何用神经网络模拟器实现更智能的决策?

编辑&#xff1a;陈萍萍的公主一点人工一点智能 未来机器人的大脑&#xff1a;如何用神经网络模拟器实现更智能的决策&#xff1f;RWM通过双自回归机制有效解决了复合误差、部分可观测性和随机动力学等关键挑战&#xff0c;在不依赖领域特定归纳偏见的条件下实现了卓越的预测准…

Linux应用开发之网络套接字编程(实例篇)

服务端与客户端单连接 服务端代码 #include <sys/socket.h> #include <sys/types.h> #include <netinet/in.h> #include <stdio.h> #include <stdlib.h> #include <string.h> #include <arpa/inet.h> #include <pthread.h> …

华为云AI开发平台ModelArts

华为云ModelArts&#xff1a;重塑AI开发流程的“智能引擎”与“创新加速器”&#xff01; 在人工智能浪潮席卷全球的2025年&#xff0c;企业拥抱AI的意愿空前高涨&#xff0c;但技术门槛高、流程复杂、资源投入巨大的现实&#xff0c;却让许多创新构想止步于实验室。数据科学家…

深度学习在微纳光子学中的应用

深度学习在微纳光子学中的主要应用方向 深度学习与微纳光子学的结合主要集中在以下几个方向&#xff1a; 逆向设计 通过神经网络快速预测微纳结构的光学响应&#xff0c;替代传统耗时的数值模拟方法。例如设计超表面、光子晶体等结构。 特征提取与优化 从复杂的光学数据中自…