常见问题(FAQ)¶
一般问题¶
AutoShip 会上传我的代码吗?¶
不会。默认情况下,所有核心处理(清理、验证、提交信息生成)都在本地完成。只有当你显式配置外部模型后端(如 OpenAI)或上传目标(PyPI、Docker Registry)时,才会向对应服务发送必要数据。详见 隐私政策。
使用 AutoShip 需要联网吗?¶
核心命令(init、clean、commit、verify)可在完全离线环境下运行。需要联网的功能包括:
upload到 PyPI / Docker / GitHubweb-search插件的联网搜索plugin install从 PyPI 或远程 registry 安装插件- 使用云端模型后端
AutoShip 支持哪些操作系统?¶
AutoShip 在 Linux、macOS 和 Windows 上均可运行。CI 也针对这三个平台构建二进制可执行文件。推荐 Python 版本为 3.10 及以上。
安装与升级¶
如何安装 AutoShip?¶
推荐方式:
或使用 uv:
开发者可克隆仓库后使用 uv sync --all-extras --dev 安装。
如何升级到最新版本?¶
autoship 命令找不到怎么办?¶
- 确认安装成功:
pipx list或pip show autoship。 - 检查 PATH 是否包含 pipx / Python scripts 目录。
- 如果使用虚拟环境,确保已激活环境。
模型与 AI¶
可以使用 OpenAI / Claude / Azure 等云端模型吗?¶
可以。在 .autoship.toml 的 [model.backends] 中配置对应 provider,例如 openai、azure_openai、openrouter。API key 建议通过环境变量注入,避免写入配置文件。
[[model.backends]]
provider = "openai"
base_url = "https://api.openai.com/v1"
model = "gpt-4o-mini"
api_key = "${OPENAI_API_KEY}"
本地模型推荐用什么?¶
详见 模型配置。
模型后端连接失败怎么办?¶
- 运行
autoship doctor检查模型后端状态。 - 确认后端服务已启动且
base_url正确。 - 检查防火墙或代理设置。
- 查看日志:
autoship --verbose <command>。
配置¶
配置文件放在哪里?¶
项目级配置:.autoship.toml(项目根目录)。
团队级配置:.autoship.team.toml(项目根目录,可被项目配置覆盖)。
全局配置:
- Linux/macOS:
~/.config/autoship/config.toml - Windows:
%APPDATA%\autoship\config.toml
如何禁用遥测?¶
遥测默认已关闭。如需显式确认:
如何切换语言?¶
插件¶
如何安装第三方插件?¶
安装后默认为 community 信任等级。审阅源码后可提升为 verified:
如何开发自己的插件?¶
参考 插件开发指南 与示例插件 examples/custom-plugin。
插件可以执行系统命令吗?¶
可以,但需要在 permissions 中声明 shell = true,并经过用户确认。建议遵循最小权限原则。
安全与审计¶
AutoShip 如何保护我的凭证?¶
- 审计日志与错误日志默认脱敏 API key、token、密码等敏感信息。
- 建议通过环境变量注入密钥,避免写入配置文件。
- 配置文件权限由系统自动设置为仅所有者可读写。
审计日志保留多久?¶
默认保留 30 天。可通过 .autoship.toml 配置:
手动清理:
发现安全漏洞如何报告?¶
请通过邮件 security@autoship.dev 私下报告,不要公开创建 issue。详见 安全策略。
故障排查¶
autoship verify 失败但测试本身没问题?¶
verify 命令会先运行你指定的测试/检查命令,再运行 AutoShip 的验证流程。请检查:
- 被调用的测试命令本身是否通过。
- 是否有插件在
pre_verify/post_verify阶段失败。 - 使用
--verbose查看详细日志。
autoship commit 生成的消息不满意?¶
可以使用 --edit 进入编辑器修改生成的消息,或在配置中调整 commit.max_tokens 与 conventional_commits。
如何重置 AutoShip 配置?¶
删除项目根目录的 .autoship.toml 并重新运行 autoship init。