¿Alguna vez has deseado poder enviar un cambio directamente a un usuario para su revisión y retroalimentación inmediatas - sin pedirles que descarguen e instalen una nueva versión desde TestFlight o Google Play?
He tenido clientes que solicitaron mejoras que pude implementar rápidamente, pero obtener los resultados en sus manos para validar significaba enviar una actualización a todos los usuarios (riesgoso para un cambio experimental) o crear una versión única para el cliente (un trabajo para ambos).
Lo que faltaba era flexibilidad. Los desarrolladores querían poder servir actualizaciones diferentes a diferentes grupos de usuarios, como partes no técnicas, QA o la base de usuarios completa cuando fuera apropiado.
No había una forma de que una versión de producción cambiara a una versión en curso de trabajo, recopilar retroalimentación y luego regresar a la producción.
Eso es lo que cambiar de canal permite. Una aplicación instalada en un dispositivo del usuario puede cambiar los canales de actualización en tiempo de ejecución, convirtiendo una aplicación de producción en un espacio flexible para la revisión y la iteración en lugar de un punto final fijo. Esto es especialmente útil para partes no técnicas que trabajan con aplicaciones de producción, permitiéndoles probar cambios y dar retroalimentación directamente en la aplicación que ya tienen instalada.
Entendiendo los canales de actualización
Los canales de actualización son cómo Capgo dirige actualizaciones a versiones específicas. Cada versión está asociada con un canal, y ese canal determina qué actualizaciones recibirá.
Por ejemplo, puedes publicar actualizaciones en un preview canales sin afectar a los usuarios en productionHace tiempo, cambiar de canal requería instalar una compilación nativa diferente o cambiar manualmente las asignaciones de dispositivos a través de la consola.
Los canales en Capgo te permiten:
- Dirigirte a grupos de usuarios específicos con características diferentes
- Ejecutar pruebas A/B asignando a los usuarios a diferentes canales
- Implementar nuevas características de manera gradual
- Crear programas de pruebas beta
- Depurar problemas de producción con usuarios individuales
Si no estás familiarizado con los canales de actualización, la documentación de los canales de Capgo los cubre con más detalle.
¿Qué es el Surfado de Canales?
El surfado de canales permite a una aplicación instalada obtener actualizaciones de diferentes flujos sin tener que reinstalarla. Una aplicación instalada puede cambiar de canal de actualización en tiempo de ejecución y continuará recibiendo actualizaciones del canal seleccionado hasta que la aplicación sea desinstalada o cambiada a otro canal.
In la práctica, esto significa que un propietario de producto o un especialista en pruebas pueden cambiar una production construcción a, por ejemplo, un preview canal, probar las últimas modificaciones. Cuando terminen de probar, cambian de nuevo a production de nuevo. No hay necesidad de reinstalar o de una construcción de vista previa separada.
Bajo la capa, el cambio de canal funciona permitiendo que la aplicación le diga al cliente de actualizaciones qué canal usar. Esa elección se puede cambiar en tiempo de ejecución y permanece en efecto hasta que se elimina o se reemplaza.
Cómo Implementar el Cambio de Canal
Antes de que puedas probar el cambio de canal, tu proyecto debe estar configurado con Capgo Actualizaciones en vivo. Para configurarlo, sigue el guía rápida de Capgo.
The only setup required for channel surfing is enabling “Allow devices to self associate” on each channel you want to switch to in the Capgo dashboard. panel de control de code.
No hay cambios o modificaciones de configuración de API necesarias más allá de eso.
import { CapacitorUpdater } from '@capgo/capacitor-updater';
await CapacitorUpdater.setChannel({ channel: 'your-channel' });
En su núcleo, el cambio de canal está impulsado por una sola llamada de Capgo: Aprenda más sobre el setChannel API.
Cambiar de canal instantáneo (v5.34.0+)
A partir de la versión del plugin 5.34.0, 6.34.0, 7.34.0 o 8.0.0 (dependiendo de su versión principal), setChannel() funciona de manera diferente y mucho más rápida:
- Validación de backend (solo lectura): Se envía una solicitud al Capgo backend para validar que el canal esté permitido
- Actualización de almacenamiento local: Si la validación pasa, el canal se guarda en el almacenamiento local del dispositivo
- Efecto instantáneo: La próxima verificación de actualizaciones utiliza el nuevo canal de inmediato
Anteriormente, setChannel() guardó la sobrescritura del canal en la base de datos del servidor (como la consola o API cambios). Los dispositivos tuvieron que esperar la replicación del servidor (hasta 2 minutos) antes de que se reconociera el nuevo canal. El nuevo comportamiento solo lee desde el servidor (para la validación) y almacena localmente, lo que hace que los cambios de canal sean instantáneos.
Flujo de Cambio de Canal Completo
Para una mejor experiencia del usuario, normalmente querrás hacer más que solo cambiar el canal y esperar al próximo reinicio de la aplicación. Una aproximación común es verificar inmediatamente las actualizaciones, descargarlas si están disponibles y recargar la aplicación para que el usuario aterrice directamente en la actualización del canal seleccionado.
Un flujo típico se ve así:
- Cambiar el canal (
setChannel) - Verificar una actualización (
getLatest) - Obtener y aplicar la actualización (
download,setonext) - Recargar la aplicación si es necesario (
reload)
Aquí tienes un ejemplo completo:
import { CapacitorUpdater } from '@capgo/capacitor-updater';
async function switchChannel(selectedChannel: string) {
try {
// 1. Set the updates channel (with optional auto-update trigger)
await CapacitorUpdater.setChannel({
channel: selectedChannel,
triggerAutoUpdate: true // Immediately check for updates
});
console.log(`Switched to channel: ${selectedChannel}`);
// If you want more control, handle the update manually:
// const latest = await CapacitorUpdater.getLatest();
// if (latest.url) {
// const bundle = await CapacitorUpdater.download({
// url: latest.url,
// version: latest.version
// });
// await CapacitorUpdater.set({ id: bundle.id });
// }
} catch (error) {
console.error('Failed to switch channel:', error);
}
}
// Switch to the beta channel
switchChannel('beta');
La forma en que estructures este flujo es a tu elección. Puedes dividir estos pasos en múltiples interacciones o ejecutarlos todos al mismo tiempo. Independientemente de cómo estructures el flujo, asegúrate de tener en cuenta los errores. Problemas de red o un canal inválido pueden impedir que se aplique una actualización.
El Único Requisito: Habilitar Autoasignación
Esta es la única cosa que debes hacer para habilitar el cambio de canal. Antes de que tu aplicación pueda cambiar a un canal utilizando setChannel(), debes habilitar la autoasignación para ese canal en la consola de Capgo:
- Ve a la sección Canales de tu consola de Capgo
- Haz clic en el nombre del canal que deseas gestionar
- Habilita “Allow devices to self associate”
- Permitir a los dispositivos autoasociarse"

Habilita la autoasignación en las configuraciones del canal defaultChannel Se requiere configuración. Solo habilite la autoasignación en los canales que desee que los usuarios puedan cambiar a.
Si esta configuración está deshabilitada, cualquier intento de llamar setChannel() con este canal fallará y se disparará el channelPrivate evento.
Lista de Canales Disponibles
Puede obtener la lista de canales disponibles para la autoasignación:
const { channels } = await CapacitorUpdater.listChannels();
console.log('Available channels:', channels.map(c => c.name));
// Use this to build a channel selector UI
Esto solo devuelve canales donde la autoasignación está habilitada.
Obtener el Canal Actual
Verifique qué canal está asignado actualmente al dispositivo:
const { channel } = await CapacitorUpdater.getChannel();
console.log('Current channel:', channel);
Revertir a Canal Predeterminado
Para eliminar la sobrescritura de canal y regresar al predeterminado:
await CapacitorUpdater.unsetChannel({});
Esto desvincula el dispositivo de cualquier canal asignado específicamente, causando que regrese al canal predeterminado. defaultChannel In su configuración o el valor por defecto de la nube.
Cómo Probar el Surf de Canales
Para ver el surf de canales en acción, necesitará una compilación de lanzamiento - el __CAPGO_KEEP_0__ está diseñado para compilaciones de lanzamiento. En compilaciones de depuración, la aplicación carga típicamente JavaScript de un servidor de desarrollo en lugar de eso, lo que evita el flujo de actualización normal. @capgo/capacitor-updater API is designed for release builds. In debug builds, the app typically loads JavaScript from a development server instead, which bypasses the normal update flow.
El único requisito para el surf de canales es habilitar
“Permitir que los dispositivos se asocien de forma autónoma” en cada canal que desee permitir cambiar a. No se necesitan cambios de configuración en su aplicación. Creación de una Compilación de Prueba
Compile su aplicación como de costumbre:
Luego cree sus compilaciones nativas utilizando Xcode o Android Studio, o utilice su pipeline de CI/CD. La aplicación comenzará en el canal que esté configurado como el valor por defecto de la nube en su panel de control __CAPGO_KEEP_0__.
bun run build && npx cap sync
Then create your native builds using Xcode or Android Studio, or use your CI/CD pipeline. The app will start on whichever channel is set as the cloud default in your Capgo dashboard.
Publicación de Actualizaciones en Diferentes Canales
Una vez que la aplicación está instalada, publica actualizaciones a diferentes canales:
# Publish to preview channel
npx @capgo/cli@latest bundle upload --channel preview
# Publish to production channel
npx @capgo/cli@latest bundle upload --channel production
Desde allí, navega a tu interfaz de navegación por canales en la aplicación y activa el cambio de canal. La aplicación debería descargar la actualización del canal seleccionado y recargar en la nueva actualización.
Crear una interfaz de cambio de canal
La navegación por canales es algo que normalmente deseas exponer a un conjunto limitado de usuarios, no a todos los que utilizan tu aplicación. Por ejemplo, podrías tener un botón disponible solo para empleados autenticados que cambia la aplicación al canal de prueba.
Aquí tienes un ejemplo de componente React para un cambio de canal:
import { useState, useEffect } from 'react';
import { CapacitorUpdater } from '@capgo/capacitor-updater';
export function ChannelSwitcher() {
const [currentChannel, setCurrentChannel] = useState<string>('');
const [availableChannels, setAvailableChannels] = useState<string[]>([]);
const [isLoading, setIsLoading] = useState(false);
useEffect(() => {
loadChannelInfo();
}, []);
async function loadChannelInfo() {
const { channel } = await CapacitorUpdater.getChannel();
setCurrentChannel(channel || 'default');
const { channels } = await CapacitorUpdater.listChannels();
setAvailableChannels(channels.map(c => c.name));
}
async function handleChannelSwitch(channel: string) {
setIsLoading(true);
try {
await CapacitorUpdater.setChannel({
channel,
triggerAutoUpdate: true
});
setCurrentChannel(channel);
// App will update in background or on next restart
} catch (error) {
console.error('Failed to switch channel:', error);
} finally {
setIsLoading(false);
}
}
return (
<div>
<p>Current channel: {currentChannel}</p>
<div>
{availableChannels.map(channel => (
<button
key={channel}
onClick={() => handleChannelSwitch(channel)}
disabled={isLoading || channel === currentChannel}
>
Switch to {channel}
</button>
))}
</div>
</div>
);
}
Problemas de actualización de OTA
Ninguno de estos es específico de la navegación por canales, pero tienden a volverse evidentes rápidamente una vez que comienzas a cambiar canales en tiempo de ejecución.
Incompatibilidades de versión en tiempo de ejecución
Las actualizaciones en Capgo están vinculadas a versiones nativas de la aplicación. Si la versión nativa de una actualización no coincide con la versión nativa de la aplicación instalada, la actualización no se descargará ni se aplicará. Al navegar por canales, esto suele aparecer como la aplicación cambiando de canales pero sin aplicar la actualización, aunque una exista en ese canal.
Normalmente significa que la actualización se publicó desde una versión nativa diferente de la aplicación. Asegúrate de que el paquete de tu canal sea compatible con la versión nativa instalada en el dispositivo.
Eliminar o deshacer actualizaciones
Si una aplicación ya ha descargado una actualización para un canal, eliminar esa actualización de la consola de Capgo no la elimina de los dispositivos que ya la tienen. La eliminación solo detiene El futuro descargas.
La forma más confiable de deshacer una actualización mala es publicar una actualización conocida como buena en el mismo canal. Esto crea una nueva actualización en la parte superior de la historia del canal, que los clientes tratarán como la versión más reciente y aplicarán en su lugar.
Capgo también proporciona un mecanismo de retroceso que puede instruir a los clientes a re-aplicar una actualización estable previa o regresar a la actualización incorporada en la compilación.
Consideraciones de migración de datos
Cambiar de canal cambia el paquete de JavaScript que ejecuta la aplicación. Si su aplicación depende de migraciones o formas de datos que no son compatibles entre canales, cambiar de un lado a otro puede causar problemas.
Por ejemplo, si una actualización de beta aplica una migración de base de datos, la versión de producción no entenderá el nuevo esquema. Los desarrolladores deben asegurarse de que sus actualizaciones permanezcan seguras para cambiar entre ellas o restrinjan el cambio a una dirección cuando sea necesario.
¿Por qué el surf de canales mejora la iteración móvil?
El surf de canales es especialmente útil cuando necesita revisar cambios rápidamente en un entorno de producción.
Validación Rápida
Imagine una corrección de bug urgente que necesita validación antes de ser lanzada ampliamente. Con el surf de canales, el cambio puede ser aislado a un pequeño conjunto de usuarios designados que pueden revisarlo antes de que llegue a producción.
Revisión de partes interesadas
A un propietario de producto o un especialista en pruebas pueden cambiar su instalación de producción a otro canal de actualización, verificar la corrección o la característica, y luego cambiar de nuevo una vez que estén listos.
Pruebas Simplificadas
Esto facilita la participación de partes interesadas no técnicas en la revisión y la toma de decisiones, mientras se mantiene el flujo de trabajo suave. Una sola instalación de producción se convierte en una herramienta flexible para la prueba, la retroalimentación y la validación.
Uso de Casos
- Pruebas de QA: Que el equipo de pruebas QA cambie entre ramas de características
- Programas Beta: Los usuarios optan por el canal de beta para tener acceso temprano
- Revisión de partes interesadas: Los propietarios de productos preview los cambios antes de la liberación
- Pruebas A/B: Asignar usuarios a diferentes canales para experimentos
- Depuración: Cambiar a un usuario específico a un canal de depuración para diagnosticar problemas
Comparación: Métodos de cambio de canal
| Método | Tiempo de efecto | Persistido en | Uso de caso |
|---|---|---|---|
setChannel() desde plugin | Instantáneo | Solo dispositivo (local) | Cambiar el canal del usuario iniciado en la aplicación |
| Opción de dispositivo en la consola | Hasta 2 min | Base de datos de backend | Cambios iniciados por el administrador para dispositivos específicos |
| Asignación del canal API | Hasta 2 min | Base de datos de backend | Integraciones de backend automatizadas |
Para obtener la mejor experiencia del usuario al crear interfaces de usuario de cambio de canal, utilice siempre el método del plugin. setChannel() Prácticas recomendadas
Limitar el acceso
- : La navegación por canales suele ser para uso interno - no la exponga a todos los usuarios.Limitar el acceso
- Gestionar Errores: Siempre maneje errores de manera suave cuando se cambian canales
- ValidarCompatibilidad: Asegúrese de que las actualizaciones en diferentes canales sean compatibles con la versión nativa instalada
- Documentar Canales: Mantenga una documentación clara de qué es cada canal para
- Monitorear Uso: Registre qué dispositivos están en qué canales para depuración
Recursos
- : Capgo Actualizaciones en Vivo Documentación
- Documentación de Canales
- : Referencia del Plugin API
- Capgo CLI Comandos
Conclusión
La navegación entre canales transforma la forma en que puedes iterar en tu aplicación Capacitor. En lugar de tratar los compilados de producción como puntos finales fijos, se convierten en herramientas flexibles para la prueba, la validación y la iteración rápida.
Con la introducción reciente de la navegación instantánea entre canales, la experiencia es ahora ininterrumpida - los usuarios pueden cambiar de canal y recibir actualizaciones inmediatamente del nuevo canal sin ningún período de espera.
Ya sea que estés validando correcciones de errores con partes interesadas, ejecutando programas de beta o depurando problemas con usuarios específicos, la navegación entre canales te da la flexibilidad para enviar la actualización correcta al usuario correcto en el momento correcto.
Sigue adelante desde Navegación entre Canales para Capgo: Cómo cambiar los canales de actualización en tiempo de ejecución
Si estás utilizando Navegación entre Canales para Capgo: Cómo cambiar los canales de actualización en tiempo de ejecución para planificar la ruta de canales y la implementación de lanzamiento en etapas, conecta con Canales para obtener detalles de implementación en Canales, Canales para los detalles de implementación en Channels, Channels para los detalles de implementación en Channels, Solución de Pruebas Beta para el flujo de trabajo del producto en Solución de Pruebas Beta, y Solución de Alcance de Versión para el flujo de trabajo del producto en Solución de Alcance de Versión.