版本目标定位
复制一个包含安装步骤和此插件的完整Markdown指南的设置提示。
本指南解释了如何自动将最新兼容的捆绑包交付给用户,基于他们的本机应用程序版本, 类似于 Ionic AppFlow 的方法。 这确保了简化的更新管理和更快的发布,同时防止兼容性问题。
,以获取迁移步骤的说明。
概述Capgo的版本目标系统允许您:
- 自动向用户提供兼容的更新 基于用户的原生应用程序版本
- 防止不兼容的应用程序版本接收破坏性更改 管理多个应用程序版本
- 同时无需复杂的逻辑 无缝地向特定用户段发布更新
- 为什么版本目标化很重要(尤其是AppFlow用户) 标题:为什么版本目标化很重要(尤其是AppFlow用户)
__CAPGO_KEEP_0__的版本目标系统允许您: ionic AppFlow您知道确保用户只接收兼容更新是多么重要吗?AppFlow会自动匹配实时更新包到原生应用版本,防止向较旧的原生code传递不兼容的JavaScript。
Capgo提供相同的安全保证, with additional features:
- 更细致的版本匹配控制
- 多种策略(通道、语义版本号、原生约束)
- 更好的版本分布可见性
- API和CLI控制与仪表盘管理
这种方法在以下情况下尤其有用
- 您有不同主版本的用户(例如v1.x、v2.x、v3.x)
- 您需要维持向后兼容性,同时推出破坏性更改
- 您想防止新版本的包破坏较旧的原生code
- 您正在逐渐从一个版本迁移到另一个版本
- 您正在从 AppFlow 迁移 并且希望保持相同的更新安全性
如何工作
标题:如何工作Capgo 使用多层次的方法来匹配用户与兼容的更新:
- 原生版本约束:防止不兼容的原生版本接收捆绑包
- 通道路由:将不同应用程序版本路由到不同的更新通道
- 语义版本控制:自动阻止跨主版本/次版本/修订版本的更新
- 设备级别覆盖:针对特定设备或用户组
版本匹配流程
标题:版本匹配流程graph TD A[User Opens App] --> B{Check Device Override} B -->|Override Set| C[Use Override Channel] B -->|No Override| D{Check local plugin channel} D -->|setChannel value| E[Use local setChannel channel] D -->|No local channel| F{Check defaultChannel in App} F -->|Has defaultChannel| G[Use App's defaultChannel] F -->|No defaultChannel| H[Use Cloud Default Channel] C --> I{Check Version Constraints} E --> I G --> I H --> I I -->|Compatible| J[Deliver Update] I -->|Incompatible| K[Skip Update]策略 1:基于渠道的版本路由
标题:策略 1:基于渠道的版本路由这是 推荐方法 用于管理破坏性更改和主要版本更新。它与 AppFlow 的交付模型类似。
示例场景
标题:示例场景- App v1.x (100,000用户) →
production渠道 - App v2.x (50,000用户且有重大变更) →
v2渠道 - App v3.x (10,000 beta用户) →
v3渠道
实施
实施部分第 1 步:为每个主要版本配置渠道
步骤 1:为每个主要版本配置通道// capacitor.config.ts for version 1.x buildsimport { CapacitorConfig } from '@capacitor/cli';
const config: CapacitorConfig = { appId: 'com.example.app', appName: 'Example App', plugins: { CapacitorUpdater: { autoUpdate: 'atBackground', defaultChannel: 'production', // or omit for default } }};
export default config;// capacitor.config.ts for version 2.x buildsconst config: CapacitorConfig = { appId: 'com.example.app', appName: 'Example App', plugins: { CapacitorUpdater: { autoUpdate: 'atBackground', defaultChannel: 'v2', // Routes v2 users automatically } }};// capacitor.config.ts for version 3.x buildsconst config: CapacitorConfig = { appId: 'com.example.app', appName: 'Example App', plugins: { CapacitorUpdater: { autoUpdate: 'atBackground', defaultChannel: 'v3', // Routes v3 users automatically } }};步骤 2:创建通道
步骤 2:创建通道# Create channels for each major versionnpx @capgo/cli channel create productionnpx @capgo/cli channel create v2npx @capgo/cli channel create v3
# Enable self-assignment so apps can switch channelsnpx @capgo/cli channel set production --self-assignnpx @capgo/cli channel set v2 --self-assignnpx @capgo/cli channel set v3 --self-assign步骤 3:上传版本特定包
步骤 3:上传版本特定包# For v1.x users (from v1-maintenance branch)git checkout v1-maintenancenpm run buildnpx @capgo/cli bundle upload --channel production
# For v2.x users (from v2-maintenance or main branch)git checkout mainnpm run buildnpx @capgo/cli bundle upload --channel v2
# For v3.x users (from beta/v3 branch)git checkout betanpm run buildnpx @capgo/cli bundle upload --channel v3好处
零代码修改- Zero code changes - 每个版本都有自己的更新管道
- - 可以灵活地针对特定版本组推送更新 __CAPGO_KEEP_0__
- __CAPGO_KEEP_0__ __CAPGO_KEEP_0__
- 安全发布 - 不兼容版本的Breaking changes不会到达
策略2:语义版本控制
策略2:语义版本控制使用Capgo内置的 语义版本控制 以防止跨版本边界的更新
禁用重大版本之间的自动更新
终端窗口# Create a channel that blocks major version updatesnpx @capgo/cli channel create stable --disable-auto-update major这意味着:
- app版本用户 1.2.3 将收到版本号至 1.9.9
- 用户将 不会 收到版本号 2.0.0 自动
- 防止更新破坏原生code
- 比较使用原生基线发送的
version_build
细粒度控制选项
标题为“细粒度控制选项”# Block target bundles outside the native major.minor line (1.2.x won't get 1.3.0)npx @capgo/cli channel set stable --disable-auto-update minor
# Block target bundles outside the exact native MAJOR.MINOR.PATCH core (1.2.3 won't get 1.2.4)npx @capgo/cli channel set stable --disable-auto-update patch
# Allow all updatesnpx @capgo/cli channel set stable --disable-auto-update noneUsing nativeVersion Delay Condition
使用 nativeVersion 延迟条件在上传捆绑包时,您可以指定最低原生版本:
__CAPGO_KEEP_0__
__CAPGO_KEEP_0____CAPGO_KEEP_0__
# This bundle requires native version 2.0.0 or highernpx @capgo/cli bundle upload \ --channel production \ --native-version "2.0.0"使用场景
使用场景-
需要新本机插件
终端窗口 # Bundle needs Camera plugin added in v2.0.0npx @capgo/cli bundle upload --native-version "2.0.0" -
本机API更改
终端窗口 # Bundle uses new Capacitor 6 APIsnpx @capgo/cli bundle upload --native-version "3.0.0" -
渐进式迁移
终端窗口 # Test bundle only on latest native versionnpx @capgo/cli bundle upload \--channel beta \--native-version "2.5.0"
策略 4:自动降级防护
标题:策略 4:自动降级防护防止用户接收比他们当前本地版本更旧的捆绑包。
在频道设置中启用
标题:在频道设置中启用在Capgo控制台中:
- 前往 频道 → 选择您的频道
- 启用 “在原生下禁用自动降级”
- 保存更改
或通过 CLI:
npx @capgo/cli channel set production --disable-downgrade示例
标题:示例- 用户设备:原生版本 1.2.5
- 频道包:版本 1.2.3
- 结果: 升级被阻止(将会降级)
这在以下情况下很有用:
- 用户手动从应用商店安装了更新的版本
- 您需要确保用户始终有最新的安全补丁
- 您想防止回归错误
策略 5:设备级别目标
标题:策略 5:设备级别目标为特定设备或用户组覆盖渠道分配
强制特定版本进行测试
标题:强制特定版本进行测试import { CapacitorUpdater } from '@capgo/capacitor-updater'
// Force beta testers to use v3 channelasync function assignBetaTesters() { const deviceId = await CapacitorUpdater.getDeviceId()
// Check if user is beta tester if (isBetaTester(userId)) { await CapacitorUpdater.setChannel({ channel: 'v3' }) }}设备控制台 - 覆盖
仪表盘设备覆盖在Capgo仪表盘中:
- 前往 设备 → 查找设备
- 点击 设置频道 或 设置版本
- 覆盖特定频道或捆绑包版本
- 设备将从覆盖源接收更新
完成AppFlow样式工作流
标题为“完成AppFlow样式工作流”以下是所有策略的完整示例:
1.初始设置(App v1.0.0)
标题为“1.初始设置(App v1.0.0)”# Create production channel with semver controlsnpx @capgo/cli channel create production \ --disable-auto-update major \ --disable-downgradeconst config: CapacitorConfig = { plugins: { CapacitorUpdater: { autoUpdate: 'atBackground', defaultChannel: 'production', } }};2.发布破坏性更改(App v2.0.0)
Section titled “2. Release Breaking Change (App v2.0.0)”# Create v2 channel for new versionnpx @capgo/cli channel create v2 \ --disable-auto-update major \ --disable-downgrade \ --self-assign
# Create git branch for v1 maintenancegit checkout -b v1-maintenancegit push origin v1-maintenance// capacitor.config.ts for v2.0.0const config: CapacitorConfig = { plugins: { CapacitorUpdater: { autoUpdate: 'atBackground', defaultChannel: 'v2', // New users get v2 channel } }};3. 同时推送更新到两版本
Section titled “3. 同时推送更新到两版本”# Update v1.x users (bug fix)git checkout v1-maintenance# Make changesnpx @capgo/cli bundle upload \ --channel production \ --native-version "1.0.0"
# Update v2.x users (new feature)git checkout main# Make changesnpx @capgo/cli bundle upload \ --channel v2 \ --native-version "2.0.0"4. 监控版本分布
Section titled “4. 监控版本分布”使用Capgo控制台来跟踪:
- 有多少用户在v1和v2上
- 版本采用率
- 每个版本的错误或崩溃率
5. 废弃旧版本
标题:5. 废弃旧版本当v1使用率低于阈值时:
# Stop uploading to production channel# Optional: Delete v1 maintenance branchgit branch -d v1-maintenance
# Move all remaining users to default# (They'll need to update via app store)渠道顺序
标题:渠道顺序当存在多个渠道配置时,Capgo遵循以下顺序:
- 设备覆盖 (控制台或API) - 优先级最高,且可在设备覆盖UI中查看
- 本地插件通道 通过
setChannel()- 只在设备上存储,不在设备覆盖 UI 中显示 - 默认通道 在 capacitor.config.ts 中
- 默认通道 (Cloud 设置) - 优先级最低
最佳实践
标题:最佳实践1. 总是为主要版本设置 defaultChannel
标题:1. 总是为主要版本设置 defaultChannel// ✅ Good: Each major version has explicit channel// v1.x → production// v2.x → v2// v3.x → v3
// ❌ Bad: Relying on dynamic channel switching// All versions → production, switch manually2. 使用语义版本
标题:2. 使用语义版本# ✅ Good1.0.0 → 1.0.1 → 1.1.0 → 2.0.0
# ❌ Bad1.0 → 1.1 → 2 → 2.53. 保持分支独立
Section titled “3. 保持分支独立”# ✅ Good: Separate branches per major versionmain (v3.x)v2-maintenance (v2.x)v1-maintenance (v1.x)
# ❌ Bad: Single branch for all versions4. 在发布前进行测试
Section titled “4. 在发布前进行测试”# Test on beta channel firstnpx @capgo/cli bundle upload --channel beta
# Monitor for issues, then promote to productionnpx @capgo/cli bundle upload --channel production5. 监控版本分布
Section titled “5. 监控版本分布”定期检查您的仪表板:
- 用户是否正在升级到新版本的原生版本?
- 老版本是否仍然获得高流量?
- 是否应该弃用旧的渠道?
与Ionic AppFlow的比较
与Ionic AppFlow的比较从Ionic AppFlow迁移的团队,请参见__CAPGO_KEEP_0__版本目标的比较: 功能, here’s how Capgo’s version targeting compares:
| __CAPGO_KEEP_0__ | 基于版本的路由 | Capgo |
|---|---|---|
| Should you deprecate old channels? | For teams migrating from | 自动化 defaultChannel + 多种策略 |
| 语义版本 | 基本支持 | 高级 --disable-auto-update (主版本/次版本/修订版本) |
| 原生版本约束 | 在 AppFlow 控制台中手动配置 | 内置 --native-version 标志在 CLI 中 |
| 频道管理 | Web UI + CLI | Web UI + CLI + API |
| 设备覆盖 | 受限设备级控制 | Full control via Dashboard/API |
| 防止自动降级 | 是 | 是通过 --disable-downgrade |
| 多版本维护 | 手动分支/频道管理 | 自动使用频道优先级 |
| 自主托管 | 否 | 是 (完全控制) |
| 版本分析 | 基本 | 详细的每个版本指标 |
故障排除
标题为“故障排除”的部分用户未接收更新
用户未接收更新检查以下内容:
-
频道分配: 确认设备位于正确频道
const channel = await CapacitorUpdater.getChannel()console.log('Current channel:', channel) -
版本约束: 检查捆绑包是否有本机版本要求
- 仪表板 → 捆绑包 → 检查“本机版本”列
-
语义版本设置: 确认频道的
disable-auto-update设置终端窗口 npx @capgo/cli channel list -
设备覆盖: 检查设备是否有手动覆盖
- 仪表板 → 设备 → 搜索设备 → 检查频道/版本
捆绑包传递到错误版本
标题为“捆绑包传递到错误版本”- 查看defaultChannel: 确保频道正确
capacitor.config.ts - 检查捆绑包上传: 验证捆绑包上传到预期频道
- 检查原生版本: 确认
--native-version旗帜被正确使用
影响旧版本的重大变更
标题:影响旧版本的重大变更- 紧急修复: 将受影响的设备设置为安全捆绑
- 仪表盘 → 设备 → 批量选择 → 设置版本
- 长期修复: 创建版本化通道并维护单独的分支
- 预防: 在发布之前始终在代表性设备上测试更新
从Ionic AppFlow迁移
标题:从Ionic AppFlow迁移如果您正在从 Ionic AppFlow, version targeting works very similarly in Capgo, with improved flexibility:
版本目标功能在 __CAPGO_KEEP_0__ 中与原有功能非常相似,但功能更加灵活:
概念映射| 标题:概念映射 | Capgo Equivalent | __CAPGO_KEEP_0__ 等价 |
|---|---|---|
| 注意 | Capgo Channel | __CAPGO_KEEP_0__ 频道 |
| 相同概念,功能更强大 | --native-version flag | 更细致的控制 |
| 渠道优先级 | 渠道优先级(覆盖 → 云 → 默认) | 更透明的优先级 |
| 部署目标 | 渠道 + semver 控制 | 可用多种策略 |
| 生产渠道 | production 渠道(或任意名称) | 灵活的命名 |
| 基于 Git 的部署 | CLI 分支上传 | 相同的工作流程 |
| 自动版本匹配 | defaultChannel +版本约束 | 多种策略增强 |
AppFlow 用户的关键差异
AppFlow 用户的关键差异- 更多控制: Capgo 给您多种策略(通道、semver、native 版本)可组合
- 更好的可见性: 版本分布和兼容性问题的仪表盘
- API 访问: 全程控制版本目标
- : 自建主机: 自建更新服务器,同样支持版本逻辑
: 升级步骤
: 升级步骤- : 将 AppFlow 通道映射到 __CAPGO_KEEP_0__ 通道(通常 1:1) to Capgo channels (usually 1:1)
- : 在
defaultChannel: 为每个主要版本capacitor.config.ts: 配置 semver 规则 - : 如果要在版本边界处自动阻止 : 配置 semver 规则
- 版本特定包上传 使用
--native-version标志 - 版本分布监控 在Capgo控制台中
高级模式
标题为“高级模式”逐步版本发布
按版本逐步发布// Gradually migrate v1 users to v2async function migrateUsers() { const deviceId = await CapacitorUpdater.getDeviceId() const rolloutPercentage = 10 // Start with 10%
// Hash device ID to get deterministic percentage const hash = hashCode(deviceId) % 100
if (hash < rolloutPercentage) { // User is in rollout group - migrate to v2 await CapacitorUpdater.setChannel({ channel: 'v2' }) }}按版本的特性标志
按版本特性标志// Enable features based on native versionasync function checkFeatureAvailability() { const info = await CapacitorUpdater.getDeviceId() const nativeVersion = info.nativeVersion
if (compareVersions(nativeVersion, '2.0.0') >= 0) { // Enable features requiring v2.0.0+ enableNewCameraFeature() }}不同版本之间的A/B测试
不同版本之间的A/B测试// Run A/B tests within same native versionasync function assignABTest() { const nativeVersion = await getNativeVersion()
if (nativeVersion.startsWith('2.')) { // Only A/B test on v2 users const variant = Math.random() < 0.5 ? 'v2-test-a' : 'v2-test-b' await CapacitorUpdater.setChannel({ channel: variant }) }}Capgo provides multiple strategies for version-specific update delivery:
- 按版本逐步发布: 自动版本分离 via
defaultChannel - Semantic Versioning: 防止更新跨越主/次/修订版本边界
- Native Version Constraints: 为捆绑包要求最低的原生版本
- Auto-Downgrade Prevention: 永远不向新版原生版本交付旧捆绑包
- Device Overrides: 手动控制测试和目标
通过结合这些策略,您可以实现AppFlow样式的自动更新交付,具有更大的灵活性和控制。 选择最适合您的应用程序版本和部署工作流程的方法。
有关具体功能的更多详细信息:
- Breaking Changes Guide - Channel 版本控制策略详细
- Channel 管理 - Channel 配置参考
- 更新行为 - 原生版本延迟和条件
从版本目标继续
标题:从版本目标继续如果您正在使用 版本目标 来规划渠道路由和分阶段发布,连接它与 渠道 来获取渠道实施细节 频道 关于频道的实现细节 频道 关于频道的实现细节 Beta 测试解决方案 用于 Beta 测试解决方案的产品工作流程 版本目标解决方案 用于版本目标解决方案的产品工作流程