¿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 el canal de actualizaciones en tiempo de ejecución, convirtiendo una aplicación de producción en un espacio flexible para la revisión e 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 canal sin afectar a los usuarios en production. En el pasado, cambiar de canales 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 diferentes canales
- Implementar gradualmente nuevas características
- 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 Capgo documentación de canales los cubre en mayor 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 canales de actualización en tiempo de ejecución, y continuará recibiendo actualizaciones del canal seleccionado recientemente 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 QA 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 cubierta, el cambio de canal funciona permitiendo que la aplicación le diga al cliente de actualizaciones qué canal usar. Esa elección 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 necesita estar configurado con Capgo Actualizaciones en Vivo. Para configurarlo, sigue el Capgo guía rápida de inicio.
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. code consola.
No hay cambios o modificaciones de configuración 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 : Aprende más sobre el setChannel API.
Intercambio de canales instantáneo (v5.34.0+)
Desde la versión del plugin 5.34.0, 6.34.0, 7.34.0 o 8.0.0 (dependiendo de tu 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 la canal sea permitido
- Actualización de almacenamiento local: Si la validación pasa, el canal se guarda en el almacenamiento local del dispositivo
- Effecto 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 backend (como Dashboard o API cambios). Los dispositivos tuvieron que esperar la replicación del backend (hasta 2 minutos) antes de que el nuevo canal fuera reconocido. El nuevo comportamiento solo lee del backend (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 simplemente cambiar el canal y esperar al próximo reinicio de la aplicación. Una aproximación común es verificar inmediatamente actualizaciones, descargarlas si están disponibles y recargar la aplicación para que el usuario aterrice directamente en la actualización seleccionada del canal.
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í hay 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 a la vez. 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 en 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 los ajustes del canal defaultChannel setting requerido. Solo habilite la autoasignación en los canales que desee que los usuarios puedan cambiar a.
Si se deshabilita esta configuración, 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 a la predeterminada:
await CapacitorUpdater.unsetChannel({});
Esto desvincula el dispositivo de cualquier canal asignado específicamente, causando que regrese a la 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ás 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 asocie de forma autónoma” en cada canal que desee permitir cambiar a. No se necesitan cambios de configuración en tu aplicación. Creando una Compilación de Prueba
Compila tu aplicación de manera habitual:
Luego crea tus compilaciones nativas utilizando Xcode o Android Studio, o utiliza tu pipeline de CI/CD. La aplicación comenzará en el canal que se establezca como valor por defecto en la nube en tu 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.
Publicando 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 de 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 OTA
Ninguno de estos es específico de la navegación por canales, pero tienden a volverse evidentes rápidamente una vez que comiences 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á. Cuando se navega por canales, esto suele aparecer como la aplicación cambiando de canales pero sin que se aplique 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 desde la consola de Capgo no la elimina de los dispositivos que ya la tienen. La eliminación solo detiene la descarga de la actualización en los dispositivos que ya la han descargado. idioma 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 anterior 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 urgente de un bug 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 la producción.
Revisión de partes interesadas
Un propietario de producto o un especialista en pruebas puede 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.
Casos de Uso
- Pruebas de QA: Que el equipo de pruebas pueda cambiar entre ramas de características
- Programas Beta: Los usuarios se optan por el canal beta para el acceso temprano
- Revisión de partes interesadas: Los propietarios de producto pueden previsualizar los cambios antes de la liberación
- Pruebas A/B: Asignar usuarios a diferentes canales para experimentos
- Depuración: Cambiar a un canal de depuración a un usuario específico para diagnosticar problemas
Comparación: Métodos de cambio de canal
| Método | Tiempo de efecto | Persistido en | Uso |
|---|---|---|---|
setChannel() desde plugin | Inmediato | Solo dispositivo (local) | Switch de canal iniciado por el usuario en la aplicación |
| Ocultar dispositivo en la consola | Hasta 2 min | Base de datos de backend | Cambios iniciados por el administrador para dispositivos específicos |
| API asignación de canal | 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, siempre utilice el método del plugin. setChannel() Prácticas recomendadas
Limitar el acceso
- : El cambio de canal suele ser para uso interno - no lo exponga a todos los usuariosLimitar el acceso: El cambio de canal suele ser para uso interno - no lo exponga a todos los usuarios
- 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 los canales y la implementación de un despliegue en etapas, conecta con Canales para obtener detalles de implementación en Canales, Canales para los detalles de implementación en Canales, Canales para los detalles de implementación en Canales, 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.