当前位置: 首页 > article >正文

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

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 月

相关文章:

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

crewAI CLI 与项目结构:从原型到生产的工程化规范 本文基于 crewAI v1.11.0,系统介绍 crewAI 项目的标准工程结构、CLI 工具链和生产环境配置规范。 一、原型与生产的鸿沟 很多 crewAI 项目都死在从原型到生产的过渡阶段。原型阶段的代码通常是这样的&a…...

一、安装Redis(win11环境下)

1.windows安装Redis 1.1下载redis https://github.com/tporadowski/redis/releases 图1-1 网页Redis版本选择 1.2解压redis 图1-2 redis目录下 1.3启动redis 在解压成功后,进入到redis文件下(如上图1-2),右键打开命令窗口&am…...

Comsol声子晶体能带计算,包含六角晶格不同原胞的选取以及简约布里渊区高对称点选择

Comsol声子晶体能带计算,包含六角晶格不同原胞的选取以及简约布里渊区高对称点选择。 核心在于区分三角晶格和六角晶格区别最近在研究Comsol声子晶体的能带计算,发现六角晶格的原胞选取和简约布里渊区高对称点的选择真是个大坑。尤其是三角晶格和六角晶格…...

从Tacotron到智能语音:端到端语音合成的原理、应用与未来

从Tacotron到智能语音:端到端语音合成的原理、应用与未来 引言 你是否曾好奇智能音箱里流畅自然的语音是如何“凭空”产生的?这背后,端到端语音合成技术正扮演着核心角色。本文将深入解析这一领域的里程碑式模型——Tacotron。我们将从其颠覆…...

保姆级教程:手把手复现攻防世界shrine靶场(Flask+Jinja2 SSTI)

从零构建Flask SSTI靶场:绕过黑名单获取FLAG的实战指南 第一次接触CTF中的SSTI漏洞时,我完全被那些奇怪的{{}}符号和魔术方法搞晕了。直到亲手搭建环境复现漏洞,才真正理解模板注入的精妙之处。本文将带你从零开始,完整复现攻防世…...

Arduino Uno引脚全解析:从电源管理到PWM调光,新手必看的实战指南

Arduino Uno引脚深度实战:从电源配置到智能控制的全能指南 当你第一次拿起Arduino Uno开发板时,那些密密麻麻的金属引脚可能会让你感到困惑。这块小小的蓝色板子如何通过这些引脚与外部世界对话?本文将带你超越简单的引脚定义,深入…...

基于Docker和Orthanc构建高效医学影像存储系统的实践指南

1. 为什么选择DockerOrthanc搭建医学影像系统 在医院信息化建设中,医学影像存储一直是个让人头疼的问题。传统的PACS系统往往价格昂贵、部署复杂,而且扩展性差。我去年帮一家社区医院做系统升级时,他们原有的影像系统已经用了8年,…...

NXP i.MX8M Plus Cortex-M7多核通信与实时控制开发实战

1. 认识i.MX8M Plus的异构多核架构 第一次拿到NXP i.MX8M Plus开发板时,最让我惊讶的是它独特的"大小核"设计。这颗芯片内部其实藏着两个完全不同的世界:一边是四核Cortex-A53组成的"大脑",主频高达1.6GHz,能…...

计算机毕设 java基于微信小程序点餐系统的设计与实现 微信小程序智能点餐平台开发 基于 SpringBoot 的餐饮在线点餐系统设计

计算机毕设 java基于微信小程序点餐系统的设计与实现pmz399(配套有源码 程序 mysql 数据库 论文)本套源码可以先看具体功能演示视频领取,文末有联 xi 可分享随着移动互联网的普及和微信小程序的广泛应用,“互联网 餐饮” 成为行业…...

LeetCode 48 1886.矩阵旋转与判断

LeetCode 48 & 1886.矩阵旋转与判断 题目概览 [LeetCode 48] 旋转图像 给定一个 n n 的二维矩阵 matrix 表示一个图像,请你将图像顺时针旋转 90 度,必须原地旋转。 [LeetCode 1886] 判断矩阵经轮转后是否一致 给定两个 n n 的矩阵 mat 和 target&a…...

Comsol纳米摩擦发电机仿真计算模型探索

Comsol纳米摩擦发电机仿真计算模型,采用静电场对相反电极材料感应的表面电荷进行计算,可以得到不同电极距离下计算模型的电势、电场分布最近在研究Comsol纳米摩擦发电机仿真计算模型,感觉还挺有意思的,来和大家分享一下&#x1f6…...

计算机毕设 java 燐燐开花二手交易系统 Java 二手商品在线交易与管理平台开发 基于 SpringBoot 的二手交易商城系统实现

计算机毕设 java 燐燐开花二手交易系统 7rvj49(配套有源码 程序 mysql 数据库 论文)本套源码可以先看具体功能演示视频领取,文末有联 xi 可分享在互联网与共享经济的双重推动下,二手商品交易需求日益旺盛,但传统二手交…...

CAD二次开发实战:5分钟搞定TXT坐标转DWG图纸(C#代码详解)

CAD二次开发实战:5分钟实现TXT坐标转DWG图纸(C#代码精解) 在工程设计领域,数据格式转换是高频需求。许多传统测绘设备输出的坐标数据仍以TXT文本形式保存,而设计人员需要将这些数据可视化到DWG图纸中。手动输入不仅效率…...

vue+python人工智能AI问答时代个人计算机的安全防护科普系统

目录技术栈选择系统架构设计核心功能实现数据安全策略部署与测试用户教育内容持续维护计划项目技术支持源码获取详细视频演示 :文章底部获取博主联系方式!同行可合作技术栈选择 前端采用Vue 3框架,结合Element UI或Ant Design Vue组件库实现…...

腾讯云GPU实例上,用Isaac Sim 5.0和Isaac Lab搭建GR00T仿真环境,保姆级避坑指南

腾讯云GPU实例部署Isaac Sim 5.0全流程:从零搭建到稳定运行的深度实践 当我在腾讯云上第一次尝试部署Isaac Sim 5.0时,本以为按照官方文档就能轻松搞定,结果却遭遇了VNC黑屏、快捷键失效、密码重置卡住等一系列问题。这篇文章将分享我在腾讯云…...

保姆级教程:从下载到配置,手把手搞定CANoe车载测试环境(附CAN盒选购指南)

从零搭建CANoe车载测试环境:避坑指南与实战配置 第一次打开CANoe软件时,那个复杂的界面和密密麻麻的选项让我完全不知所措。作为汽车电子领域最主流的测试工具,CANoe的强大功能背后是陡峭的学习曲线。本文将分享我三年来从零开始搭建测试环境…...

vue+python产品售后服务跟踪系统的设计与实现6ffp13w7

目录系统架构设计功能模块划分技术实现细节数据库设计开发计划部署方案项目技术支持源码获取详细视频演示 :文章底部获取博主联系方式!同行可合作系统架构设计 采用前后端分离架构,前端使用Vue.js框架构建用户界面,后端使用Pytho…...

华为无线网络部署实战:基于RADIUS认证的企业级WLAN配置指南

1. 企业级WLAN部署的核心挑战 在中大型企业无线网络部署中,最头疼的问题莫过于如何平衡安全性和用户体验。我见过太多企业为了图省事直接使用预共享密钥(PSK)认证,结果要么因为密码泄露导致网络被蹭,要么每次有员工离职…...

Python实战:用中智集解决模糊决策问题(附完整代码)

Python实战:用中智集解决模糊决策问题(附完整代码) 在数据科学和机器学习领域,决策问题往往伴随着不确定性。传统的模糊集理论已经无法完全满足复杂场景下的需求,这时中智集(Neutrosophic Set)作…...

银监会G01报表填报避坑指南:最新251版与231版差异全解析

G01报表251版与231版差异解析:银行填报人员必知的12个关键点 每当季度报表报送季来临,银行填报人员总会面临版本更新带来的困扰。G01《资产负债项目统计表》作为银监会1104报表体系中最核心的报表之一,其251版与231版之间的差异直接影响着数据…...

实验室旧服务器(Ubuntu 18)无网环境,如何用Ollama+DeepSeek R1搭建本地AI助手(附Open WebUI白屏解决方案)

在Ubuntu 18无网环境中部署Ollama与DeepSeek R1的完整指南 老旧服务器往往面临系统版本过时、网络隔离等现实约束,但这并不妨碍我们挖掘其剩余价值。本文将手把手带您完成Ubuntu 18系统下的离线AI助手部署,重点解决无网环境带来的特殊挑战。 1. 环境准备…...

永磁同步电机PMSM参数辨识与SVPWM矢量控制仿真探索

永磁同步电机PMSM参数辨识svpwm矢量控制 初试速度恒定 Matlab/simulink仿真(2018a及以上版本),最近在搞永磁同步电机(PMSM)相关的研究,涉及到参数辨识以及SVPWM矢量控制,并且初试速度恒定,用的是Matlab/Sim…...

双向Buck-Boost变换器:电压外环与电流内环控制的平均电流管理技术,实现模式切换无过压过...

双向buck-boost变换器, 采用电压外环, 电流内环控制, 平均电流控制。 在buck模式与boost模式之前切换时,不会发生过压与过流。 该拓补可以用于储能中。双向buck-boost变换器最近在储能领域火得不行,这玩意儿既能当充电…...

从CMT2300A实战出发:Sub1G射频匹配电路设计要点与315MHz应用详解

1. CMT2300A芯片与Sub1G射频基础认知 第一次拿到CMT2300A这颗国产Sub1G射频芯片时,最吸引我的是它127MHz到1020MHz的超宽工作频段。这意味着一颗芯片就能覆盖智能家居、工业遥控等场景常用的315MHz/433MHz/868MHz等多个频点。不过实际调试中发现,射频匹配…...

Comsol 中光子晶体仿真:拓扑荷、偏振态及相关特性探索

comsol光子晶体仿真,拓扑荷,偏振态。 三维能带,三维Q,Q因子计算。 远场偏振计算。在光子晶体领域的研究中,Comsol 是一款极为强大的工具,它能帮助我们深入探究各种复杂的光学现象,今天咱们就聊聊…...

半波整流电路DIY实战:从零搭建一个简易电源(附波形实测对比)

半波整流电路DIY实战:从零搭建一个简易电源(附波形实测对比) 在电子制作的世界里,电源电路就像人体的心脏,为各种电子设备提供稳定的能量。而半波整流电路,则是电源设计中最基础也最经典的入门项目。不同于…...

Comsol 下复合绝缘子的仿真探索

Comsol 复合绝缘子仿真,包括污秽种类、污秽附着面积等对绝缘子电场分布、绝缘子污闪电压的影响。 绝缘子电-热-流耦合分析,电势分布线图。在电力系统领域,复合绝缘子的性能研究至关重要。今天咱们就来聊聊利用 Comsol 软件对复合绝缘子进行的…...

Comsol中光子晶体光纤相关特性计算漫谈

comsol光子晶体光纤有效折射率,模式色散,有效模式面积计算,在光子学领域,光子晶体光纤以其独特的光学特性备受关注。今天咱就唠唠在Comsol里计算光子晶体光纤的有效折射率、模式色散以及有效模式面积这几个关键参数。 有效折射率计…...

霍尔木兹海峡:帝国黄昏的祭坛?

【桥水基金创始人瑞达利欧3月16日发布一则可怕的警告:美国、以色列和伊朗之间的冲突将围绕霍尔木兹海峡展开决定性对抗,受其结果影响的将远不止石油价格。它将决定美国领导的全球秩序能否存续。】当达利欧将霍尔木兹海峡的波涛与1956年苏伊士运河的硝烟重…...

人-机交互是新文科与新理科融合的最佳窗口

人机交互(Human-Machine Interaction, HMI)作为一门交叉学科,本质上是技术与人文的深度融合,其发展过程中天然蕴含着“新文科”与“新理科”的双重基因。这里的“新文科”强调人文社科的创新性转型(如跨学科融合、技术…...