FastGPTFastGPT
应用构建/技能

初始化脚本

了解如何在技能包中配置和执行初始化脚本,准备技能运行环境。

技能初始化脚本是技能开发者提供的一个前置脚本。当应用成功部署并解压了您开发的技能后,系统在实际执行 AI 任务前,会在独立的虚拟机环境中自动运行该脚本。

通过初始化脚本,您可以在技能代码执行前,自动安装技能特有的第三方依赖,或进行必要的配置预处理。


1. 技能脚本配置与执行时机

要为您的技能添加初始化脚本,只需在技能压缩包的根目录下放置一个名为 entrypoint.sh 的 Shell 脚本。

技能初始化脚本示例

执行时机

  1. 技能包部署与解压:当用户运行引用了该技能的应用时,系统会首先将技能包部署并解压到虚拟机的 ./projects/<versionId>/ 目录下。
  2. 执行初始化脚本:系统会在虚拟机中执行该技能根目录下的 entrypoint.sh 脚本。

2. 智能去重机制

为了避免在多次对话中重复运行环境初始化脚本(例如重复执行依赖包安装会导致每次对话产生严重的延迟),系统为技能脚本设计了去重机制。

去重状态记录在虚拟机内的 ~/.fastgpt/agent-skill-entrypoints/state.json 状态文件中。

  • 版本 ID 去重:由于同一个技能版本(versionId)的代码和脚本内容在发布后是不可变的,系统会记录当前虚拟机中已成功运行过的技能 versionId
  • 跳过执行:当同一个虚拟机实例在后续对话中被复用时,只要对应的 versionId 已经成功执行过,系统就会直接跳过该脚本的运行,实现秒级热启动。
  • 新版本触发:只要技能发布了新版本,无论是在旧的对话窗口还是新的对话窗口,在下一次对话触发时,系统都将在重新部署该技能后自动运行该版本的初始化脚本。

3. 执行约束与容错机制

为保障 AI 流程的流畅运行,技能初始化脚本需要遵循与应用启动脚本一致的执行限制与容错规则:

  • 执行约束与非阻断容错:技能入口脚本的超时时间限制(默认 30 秒)、非阻塞设计(执行报错或超时不阻断主流程)以及 8KB 日志输出截断规则,均与应用启动脚本保持一致。具体细节指标请参考 应用启动脚本的执行限制
  • 调试预览限制:在技能的编辑模式下,虚拟机不会自动执行技能的 entrypoint.sh 脚本。如果需要验证脚本效果,技能开发者可以直接在侧边栏调试区的控制台终端(Workspace Terminal)中手动执行相关命令。