故障排除
复制一个包含安装步骤和本插件的完整 Markdown 指南的配置提示。
解决在使用 Capgo Cloud Build 构建原生应用时遇到的常见问题。
构建失败
标题:构建失败“上传失败”或“连接超时”
标题:“上传失败”或“连接超时”症状:
- 项目上传过程中发生构建失败
- 超时错误在 60 秒后
解决方案:
-
检查您的互联网连接
终端窗口 # Test connection to Capgocurl -I https://api.capgo.app -
减少项目大小
- 确保
node_modules/正在上传(应自动排除) - 检查项目中的大型文件:
终端窗口 find . -type f -size +10M - 确保
-
检查上传 URL 过期
- 上传 URL 在 1 小时后失效
- 如果您收到过期 URL 错误,请重新运行构建命令
”Build timeout after 10 minutes”
Section titled “”Build timeout after 10 minutes””Symptoms:
- Build exceeds maximum allowed time
- Status shows
timeout
解决方案:
-
优化依赖项
- 移除未使用的npm包
- 使用
npm prune --production在构建之前
-
在构建过程中检查网络问题
- 某些依赖项可能在构建过程中下载大文件
- 考虑使用锁文件进行预缓存
-
检查本机依赖项
终端窗口 # iOS - check Podfile for heavy dependenciescat ios/App/Podfile# Android - check build.gradlecat android/app/build.gradle -
联系支持
- 如果您的应用程序合法地需要更多时间
- 我们可以根据具体用例调整限制
身份验证问题
标题:身份验证问题”API key invalid” or “Unauthorized”
Section titled “”API key invalid” or “Unauthorized””症状:
- 构建立即以身份验证错误失败
- 401 或 403 错误
解决方案:
-
Verify API key is correct
终端窗口 # Test with a simple commandbunx @capgo/cli@latest app list -
检查API密钥权限
- 密钥必须有
write或all权限 - 检查Capgo控制台下API密钥
- 密钥必须有
-
确保API密钥正在被读取
终端窗口 # Check environment variableecho $CAPGO_TOKEN# Or check your saved credentials filecat ~/.capgo-credentials/credentials.json # globalcat .capgo-credentials.json # local (--local) -
重新验证
终端窗口 bunx @capgo/cli@latest login
”App not found” or “No permission for this app”
Section titled “”App not found” or “No permission for this app””Symptoms:
- Authentication works but app-specific error
Solutions:
-
Verify app is registered
Terminal window bunx @capgo/cli@latest app list -
Check app ID matches
- Verify
capacitor.config.jsonappId - Ensure command uses correct app ID
- Verify
-
验证组织访问
- 检查您是否在正确的组织中
- API 必须具有对应用程序组织的访问权限
iOS 构建问题
iOS 构建问题Code 签名失败
Code 签名失败症状:
- 构建过程中code签名阶段失败
- Xcode 错误关于证书或配置文件
解决方案:
-
验证证书类型与构建类型匹配
- 开发构建需要开发证书
- App Store构建需要分发证书
-
检查证书和配置文件匹配
终端窗口 # Decode and inspect your certificateecho $BUILD_CERTIFICATE_BASE64 | base64 -d > cert.p12openssl pkcs12 -in cert.p12 -nokeys -passin pass:$P12_PASSWORD | openssl x509 -noout -subject -
确保配置文件有效
- 检查过期日期
- 验证它包含您的App ID
- 确认它包含证书
-
重新生成凭据
- 删除旧证书/配置文件
- 在Apple Developer门户中创建新证书/配置文件
- 重新编码和更新环境变量
“”未包含签名证书的配置文件””
标题:“”未包含签名证书的配置文件””症状:
- Xcode无法在配置文件中找到证书
解决方案:
-
从Apple下载最新配置文件
- 前往Apple Developer → 证书、ID 和配置文件
- 下载配置文件
- 确保配置文件包含您的证书
-
验证证书是否在配置文件中
终端窗口 # Extract profileecho $BUILD_PROVISION_PROFILE_BASE64 | base64 -d > profile.mobileprovision# View profile contentssecurity cms -D -i profile.mobileprovision -
重建使用正确证书的配置文件
- 在 Apple 开发者门户中编辑配置文件
- 确保您选择了分发证书
- 下载并重新编码
App Store Connect 认证失败
App Store Connect 认证失败症状:
- 向 TestFlight 上传失败
- API 键错误
解决方案:
-
验证 API 键凭证
- 检查 APPLE_KEY_ID(应为 10 位数字)
- 检查 APPLE_ISSUER_ID(应为 UUID 格式)
- 验证 APPLE_KEY_CONTENT 是否正确 base64 编码
-
测试 API 本地密钥
终端窗口 # Decode keyecho $APPLE_KEY_CONTENT | base64 -d > AuthKey.p8# Test with fastlane (if installed)fastlane pilot list -
检查 API 密钥权限
- 密钥需要“开发者”角色或更高
- 在 App Store Connect → 用户和访问 → 密钥中验证
-
确保密钥未被撤销
- 在 App Store Connect 中检查
- 如果需要,请生成新密钥
”Pod 安装失败”
Section titled “”Pod 安装失败””症状:
- CocoaPods 安装过程中构建失败
- Podfile 错误
解决方案:
-
验证 Podfile.lock 已提交
终端窗口 git status ios/App/Podfile.lock -
测试本地 pod 安装
终端窗口 cd ios/Apppod install -
检查不兼容的 Pods
- 检查 Podfile 中的版本冲突
- 确保所有 Pods 支持您的 iOS 部署目标
-
清除 Pod 缓存
终端窗口 cd ios/Apprm -rf Podsrm Podfile.lockpod install# Then commit new Podfile.lock
Android 构建问题
Android 构建问题“密钥库密码错误”
密钥库密码错误症状:
- 签名过程中构建失败
- Gradle 错误关于 keystore
解决方案:
-
验证 keystore 密码
终端窗口 # Test keystore locallykeytool -list -keystore my-release-key.keystore# Enter password when prompted -
检查环境变量
终端窗口 # Ensure no extra spaces or special charactersecho "$KEYSTORE_STORE_PASSWORD" | cat -Aecho "$KEYSTORE_KEY_PASSWORD" | cat -A -
验证 base64 编码
终端窗口 # Decode and testecho $ANDROID_KEYSTORE_FILE | base64 -d > test.keystorekeytool -list -keystore test.keystore
”Key alias not found”
Section titled “”未找到密钥别名””症状:
- 使用别名错误时签名失败
解决方案:
-
列出密钥库别名
终端窗口 keytool -list -keystore my-release-key.keystore -
确认别名完全匹配
- 别名区分大小写
- 检查KEYSTORE_KEY_ALIAS中是否有拼写错误
-
使用密钥库中的正确别名
终端窗口 # Update environment variable to matchexport KEYSTORE_KEY_ALIAS="the-exact-alias-name"
”Gradle build failed”
Gradle build failed症状:
- 常规Gradle错误
- 编译或依赖问题
解决方案:
-
先在本地测试构建
终端窗口 cd android./gradlew clean./gradlew assembleRelease -
检查缺失的依赖项
- 检查build.gradle文件
- 确保所有插件都列在依赖项中
-
验证Gradle版本兼容性
终端窗口 # Check gradle versioncat android/gradle/wrapper/gradle-wrapper.properties -
清除Gradle缓存
终端窗口 cd android./gradlew cleanrm -rf .gradle build
“Play Store上传失败”
标题:“Play Store上传失败”症状:
- 构建成功但上传失败
- 服务账户错误
解决方案:
-
验证服务账户 JSON
终端窗口 # Decode and check formatecho $PLAY_CONFIG_JSON | base64 -d | jq . -
检查服务账户权限
- 前往 Play Console → 设置 → API 访问
- 确保服务账户有权访问您的应用
- 授予“发布到测试轨道”权限
-
验证应用已在 Play Console 中设置
- 应用必须在 Play Console 中首先创建
- 至少需要手动上传一个 APK
-
检查 API 是否已启用
- Google Play Developer API 必须启用
- 检查 Google Cloud Console
常见问题
常见问题”Job not found” or “Build status unavailable”
Section titled “”Job not found” or “Build status unavailable””症状:
- 无法检查构建状态
- 无法找到作业 ID
解决方案:
-
稍等一下,重新尝试
- 构建作业可能需要几秒钟才能初始化
-
检查工作 ID 是否正确
- 从初始构建响应中验证工作 ID
-
检查构建未过期
- 构建数据可用 24 小时
”Project sync failed”
Section titled “”Project sync failed””症状:
- 构建在编译开始之前失败
- 缺少文件错误
解决方案:
-
运行 Capacitor 本地同步
终端窗口 bunx cap sync -
确保所有本地文件都已提交
终端窗口 git status ios/ android/ -
检查被 Git 忽略的本地文件
- 查看 .gitignore
- 确保重要的配置文件未被忽略
”我看到“成功构建”但没有输出”
构建成功但我看不到输出症状:
- 构建显示成功但没有下载链接
解决方案:
-
检查构建配置
- 可能未配置的存储
- 如果构建无法访问存储,请联系支持
-
用于 iOS TestFlight 提交
- 检查 App Store Connect
- 上传后处理可能需要 5-30 分钟
-
用于 Android Play Store
- 检查 Play Console → Testing → Internal testing
- 处理可能需要几分钟
CI/CD 特定问题
CI/CD 特定问题GitHub 动作:“命令未找到”
GitHub Actions: “命令未找到””症状:
bunx @capgo/cli@latest …在 CI 中失败,提示“命令未找到”
解决方案:
-
首先设置 Bun 所以
bunx可用:- uses: oven-sh/setup-bun@v2 -
然后运行 CLI —
bunx按需获取它,不需要全局安装:- run: bunx @capgo/cli@latest build request com.example.app --platform android
GitHub Actions: “密钥未找到”
GitHub 动作: “找不到密钥””症状:
- 构建环境变量为空
解决方案:
-
验证密钥是否已设置
- 前往仓库设置 → 秘密和变量 → 动作
- 添加所有必需的密钥
-
使用正确的语法
env:CAPGO_TOKEN: ${{ secrets.CAPGO_TOKEN }} -
检查密钥名称是否匹配
- 名称区分大小写
- 密钥引用中无错误
获取更多帮助
获取更多帮助启用详细日志
启用详细日志# Add debug flag (when available)bunx @capgo/cli@latest build request com.example.app --verbose收集构建信息
收集构建信息联系支持时,请包含:
-
构建命令
终端窗口 bunx @capgo/cli@latest build request com.example.app --platform ios -
错误信息 (全输出)
-
作业 ID (从构建输出)
-
构建日志 (复制全终端输出)
-
环境信息
终端窗口 node --versionnpm --versionbunx @capgo/cli@latest --version
联系支持
标题“联系支持”- Discord: 加入我们的社区
- 邮箱: 支持@capgo.app
- 文档: Capgo 文档
已知限制
标题:已知限制当前限制:
- 最大构建时间:10分钟
- 最大上传大小:约500MB
- iOS构建需要24小时Mac租赁,构建在Mac上会排队以确保最佳使用
- 构建工件下载可用性取决于构建目的地和工件存储配置
这些限制可能根据反馈进行调整。