1. Descripción general
En este codelab, aprenderás a supervisar el rendimiento de tu app durante el lanzamiento de una función. Nuestra app de ejemplo tendrá funcionalidad básica y está configurada para mostrar una imagen de fondo diferente según una marca de Firebase Remote Config. Revisaremos la instrumentación de seguimientos para supervisar el rendimiento de la app, el lanzamiento de un cambio de configuración en la app, la supervisión del efecto y la observación de cómo podemos mejorar el rendimiento.
Qué aprenderás
- Cómo agregar Firebase Performance Monitoring a tu app para dispositivos móviles a fin de obtener métricas listas para usar (como el tiempo de inicio de la app y los fotogramas lentos o congelados)
- Cómo agregar seguimientos personalizados para comprender las rutas de código fundamentales de los recorridos de tus usuarios
- Cómo usar el panel de Performance Monitoring para comprender tus métricas y hacer un seguimiento de los cambios importantes, como el lanzamiento de una función
- Cómo configurar alertas de rendimiento para supervisar tus métricas clave
- Cómo lanzar un cambio de Firebase Remote Config
Requisitos previos
- Android Studio 4.0 o una versión posterior
- Un emulador de Android con nivel de API 16 o posterior
- Java 8 o superior
- Conocimientos básicos sobre Firebase Remote Config
2. Configura el proyecto de muestra
Descarga el código
Ejecuta el siguiente comando para clonar el código de muestra de este codelab. Se creará una carpeta llamada codelab-perf-rc-android
en tu máquina:
$ git clone https://github.com/FirebaseExtended/codelab-feature-rollout-performance.git
Si no tienes Git en tu máquina, también puedes descargar el código directamente desde GitHub.
Importa el proyecto de la carpeta firebase-perf-rc-android-start
a Android Studio. Es probable que veas algunas excepciones de tiempo de ejecución o tal vez una advertencia sobre un archivo google-services.json
faltante. Lo corregiremos en la siguiente sección.
En este codelab, usarás el complemento Firebase Assistant para registrar tu app para Android con un proyecto de Firebase y agregar los archivos de configuración, los complementos y las dependencias necesarios de Firebase a tu proyecto de Android, todo desde Android Studio.
Conecta tu app a Firebase.
- Ve a Android Studio/Ayuda > Comprueba si hay actualizaciones para asegurarte de que estás usando las versiones más recientes de Android Studio y Firebase Assistant.
- Selecciona Herramientas > Firebase para abrir el panel de Assistant.
- Selecciona Performance Monitoring para agregarlo a tu app y, luego, haz clic en Comenzar a usar Performance Monitoring.
- Haz clic en Conectar a Firebase para conectar el proyecto de Android con Firebase (se abrirá Firebase console en el navegador).
- En Firebase console, haz clic en Agregar proyecto y, luego, ingresa un nombre para el proyecto (si ya tienes uno, puedes seleccionarlo). Haz clic en Continuar y acepta las condiciones para crear el proyecto de Firebase y una nueva app de Firebase.
A continuación, deberías ver un diálogo para Conectar la nueva app de Firebase a tu proyecto de Android Studio.
- Haz clic en Conectar.
- Abre Android Studio. En el panel Asistente, verás la confirmación de que tu app está conectada a Firebase.
Agrega Performance Monitoring a la app
En el panel Assistant de Android Studio, haz clic en Add Performance Monitoring to your app.
Verás un diálogo para Accept Changes después de la cual Android Studio deberá sincronizar tu app para garantizar que se hayan agregado todas las dependencias necesarias.
Por último, deberías ver el mensaje de éxito en el panel Assistant en Android Studio que indica que todas las dependencias se configuraron correctamente.
Como paso adicional, habilita el registro de depuración siguiendo las instrucciones del paso "Habilita el registro de depuración (opcional)". Las mismas instrucciones también están disponibles en la documentación pública.
3. Ejecuta la app
Ahora, deberías ver el archivo google-services.json
en el directorio del módulo (nivel de app) de tu app, y esta debería compilarse. En Android Studio, haz clic en Run > Ejecuta "app" para compilar y ejecutar la app en tu emulador de Android.
Cuando se esté ejecutando la app, primero deberías ver una pantalla de presentación como la siguiente:
Luego, después de unos segundos, se mostrará la página principal con la imagen predeterminada:
¿Qué sucede en niveles más profundos?
La pantalla de presentación se implementa en SplashScreenActivity y hace lo siguiente:
- En
onCreate()
, inicializamos la configuración de Firebase Remote Config y recuperamos los valores de configuración que establecerás en el panel de Remote Config más adelante en este codelab. - En
executeTasksBasedOnRC()
, leemos el valor de configuración de la marcaseasonal_image_url
. Si el valor de configuración proporciona una URL, descargamos la imagen de forma síncrona. - Cuando se completa la descarga, la app navega a MainActivity y llama a
finish()
para finalizarSplashScreenActivity
.
En MainActivity
, si se define seasonal_image_url
a través de Remote Config, se habilitará la función y la imagen descargada se mostrará como el fondo de la página principal. De lo contrario, se mostrará la imagen predeterminada (que se muestra arriba).
4. Configura Remote Config
Ahora que tu app se está ejecutando, puedes configurar la nueva marca de función.
- En el panel izquierdo de Firebase console, busca la sección Participación y, luego, haz clic en Remote Config.
- Haz clic en el botón Crear configuración para abrir el formulario de configuración y agrega
seasonal_image_url
como la clave del parámetro. - Haz clic en Agregar descripción y, luego, ingresa esta descripción:
Shows a seasonal image (replaces default) in the main page when the restaurant list is empty.
- Haz clic en Agregar nuevo -> Valor condicional -> Crea una condición nueva.
- Como nombre de la condición, ingresa
Seasonal image rollout
. - En la sección
Applies if...
, seleccionaUser in random percentile <= 0%
. (Debes dejar la función inhabilitada hasta que tengas todo listo para lanzarla en un paso posterior). - Haz clic en Crear condición. Usarás esta condición más adelante para lanzar la nueva función para tus usuarios.
- Abre el formulario de creación de tu primer parámetro y busca el campo Valor para el lanzamiento de imágenes de temporada. Ingresa la URL donde se descargará la imagen de temporada:
https://images.unsplash.com/photo-1552691021-7043334e0b51
- Deja el valor predeterminado como una cadena vacía. Esto significa que se mostrará la imagen predeterminada en la base de código en lugar de una imagen descargada de una URL.
- Haz clic en Guardar.
Puedes ver que la configuración nueva se creó como borrador.
- Haz clic en Publicar cambios y confirma los cambios en la parte superior para actualizar la app.
5. Agrega la supervisión del tiempo de carga de los datos
Tu app precarga algunos datos antes de mostrar MainActivity
y muestra una pantalla de presentación para ocultar este proceso. No querrás que los usuarios esperen demasiado en esta pantalla, por lo que, por lo general, es beneficioso supervisar el tiempo que se muestra la pantalla de presentación.
Firebase Performance Monitoring ofrece una manera de lograrlo. Puedes instrumentar seguimientos de código personalizado para supervisar el rendimiento de código específico de tu app, como el tiempo de carga de los datos y el tiempo de procesamiento de la función nueva.
Para realizar un seguimiento del tiempo que se muestra la pantalla de presentación, deberás agregar un seguimiento de código personalizado a SplashScreenActivity
, que es el Activity
que implementa la pantalla de presentación.
- Inicializa, crea y, luego, inicia un seguimiento de código personalizado llamado
splash_screen_trace
:
SplashScreenActivity.java.
// ...
import com.google.firebase.perf.FirebasePerformance;
import com.google.firebase.perf.metrics.Trace;
// ...
public class SplashScreenActivity extends AppCompatActivity {
private static final String TAG = "SplashScreenActivity";
private static final String SEASONAL_IMAGE_URL_RC_FLAG = "seasonal_image_url";
// TODO: Initialize splash_screen_trace
private final Trace splashScreenTrace = FirebasePerformance.startTrace("splash_screen_trace");
// ...
}
- Finaliza el registro en el método
onDestroy()
deSplashScreenActivity
:
SplashScreenActivity.java.
@Override
protected void onDestroy() {
super.onDestroy();
// TODO: Stop the splash_screen_trace here
splashScreenTrace.stop();
}
Dado que la nueva función descarga y procesa una imagen, agregarás un segundo seguimiento de código personalizado que hará un seguimiento del tiempo adicional que el atributo se agregó a SplashScreenActivity
.
- Inicializa, crea y, luego, inicia un seguimiento de código personalizado llamado
splash_seasonal_image_processing
:
SplashScreenActivity.java.
private void executeTasksBasedOnRC(FirebaseRemoteConfig rcConfig) {
String seasonalImageUrl = rcConfig.getString(SEASONAL_IMAGE_URL_RC_FLAG);
Log.d(TAG, SEASONAL_IMAGE_URL_RC_FLAG + ": " + seasonalImageUrl);
if (!seasonalImageUrl.isEmpty()) {
// TODO: Start the splash_seasonal_image_processing here
final Trace seasonalImageProcessingTrace = FirebasePerformance
.startTrace("splash_seasonal_image_processing");
// ...
}
}
- Finaliza el registro en los métodos
onLoadFailed()
yonResourceReady()
deRequestListener
:
SplashScreenActivity.java.
Glide.with(SplashScreenActivity.this.getApplicationContext())
.asBitmap()
.load(seasonalImageUrl)
.signature(new ObjectKey(Utils.getCacheUUID()))
.listener(new RequestListener<Bitmap>() {
@Override
public boolean onLoadFailed(
@Nullable GlideException e,
Object model, Target<Bitmap> target,
boolean isFirstResource) {
// TODO: Stop the splash_seasonal_image_processing here
seasonalImageProcessingTrace.stop();
launchMainActivity();
return true;
}
@Override
public boolean onResourceReady(Bitmap resource, Object model,
Target<Bitmap> target, DataSource dataSource,
boolean isFirstResource) {
// TODO: Stop the splash_seasonal_image_processing here
seasonalImageProcessingTrace.stop();
launchMainActivity();
return true;
}
})
.preload();
Ahora que agregaste seguimientos de código personalizado para hacer un seguimiento de la duración de la pantalla de presentación (splash_screen_trace)
y el tiempo de procesamiento de la nueva función (splash_seasonal_image_processing
), vuelve a ejecutar la app en Android Studio. Deberías ver un mensaje de registro que contiene Logging trace metric: splash_screen_trace
, seguido de la duración del seguimiento. No verás un mensaje de registro para splash_seasonal_image_processing
porque aún no habilitaste la nueva función.
6. Agrega un atributo personalizado al seguimiento
En el caso de los seguimientos de código personalizado, Performance Monitoring registra automáticamente los atributos predeterminados (metadatos comunes, como la versión de la app, el país, el dispositivo, etc.) para que puedas filtrar los datos del seguimiento en Firebase console. También puedes agregar y supervisar atributos personalizados.
En tu app, acabas de agregar dos seguimientos de código personalizado para supervisar la duración de la pantalla de presentación y el tiempo de procesamiento de la nueva función. Un factor que puede afectar esta duración es si la imagen que se muestra es la predeterminada o si debe descargarse desde una URL. Y quién sabe. Es posible que, con el tiempo, tengas distintas URLs desde las que descargues una imagen.
Por lo tanto, agreguemos un atributo personalizado que represente la URL de la imagen de temporada a estos seguimientos de código personalizado. De esa manera, puedes filtrar los datos de duración por estos valores más adelante.
- Agrega el atributo personalizado (
seasonal_image_url_attribute
) parasplash_screen_trace
al comienzo del métodoexecuteTasksBasedOnRC
:
SplashScreenActivity.java.
private void executeTasksBasedOnRC(FirebaseRemoteConfig rcConfig) {
String seasonalImageUrl = rcConfig.getString(SEASONAL_IMAGE_URL_RC_FLAG);
Log.d(TAG, SEASONAL_IMAGE_URL_RC_FLAG + ": " + seasonalImageUrl);
// TODO: Add a custom attribute "seasonal_image_url_attribute" to splash_screen_trace
if (seasonalImageUrl.isEmpty()) {
splashScreenTrace.putAttribute("seasonal_image_url_attribute", "unset");
} else {
splashScreenTrace.putAttribute("seasonal_image_url_attribute", seasonalImageUrl);
}
// ...
}
- Agrega el mismo atributo personalizado para
splash_seasonal_image_processing
justo después de la llamada astartTrace("splash_seasonal_image_processing")
:
SplashScreenActivity.java.
if (!seasonalImageUrl.isEmpty()) {
// TODO: Start the splash_seasonal_image_processing here
final Trace seasonalImageProcessingTrace = FirebasePerformance
.startTrace("splash_seasonal_image_processing");
// TODO: Add a custom attribute "seasonal_image_url_attribute" to splash_seasonal_image_processing
seasonalImageProcessingTrace
.putAttribute("seasonal_image_url_attribute", seasonalImageUrl);
// ...
}
Ahora que agregaste un atributo personalizado (seasonal_image_url_attribute
) para ambos seguimientos personalizados (splash_screen_trace
y splash_seasonal_image_processing
), vuelve a ejecutar la app en Android Studio. Deberías ver un mensaje de registro que contiene Setting attribute 'seasonal_image_url_attribute' to 'unset' on trace 'splash_screen_trace'.
. Aún no habilitaste el parámetro seasonalImageUrl de Remote Config, por lo que el valor del atributo es unset
.
El SDK de Performance Monitoring recopilará los datos de seguimiento y los enviará a Firebase. Puedes ver los datos en el panel Rendimiento de Firebase console, que explicaremos en detalle en el siguiente paso del codelab.
7. Configura tu panel de Performance Monitoring
Configura el panel para supervisar la función
En Firebase console, selecciona el proyecto que tiene la app de Friendly Eats.
En el panel izquierdo, busca la sección Versión y Supervisar y, luego, haz clic en Rendimiento.
Deberías ver el panel Rendimiento con los primeros datos en el panel de métricas. El SDK de Performance Monitoring recopila datos de rendimiento de tu app y los muestra minutos después de su recopilación.
En este panel, puedes hacer un seguimiento de las métricas clave de tu app. La vista predeterminada incluye la duración del seguimiento del tiempo de inicio de la app, pero puedes agregar las métricas que más te interesen. Dado que estás haciendo un seguimiento de la nueva función que agregaste, puedes adaptar tu panel para que muestre la duración del seguimiento de código personalizado splash_screen_trace
.
- Haz clic en uno de los cuadros vacíos Seleccionar una métrica (Select a metric).
- En la ventana de diálogo, selecciona el tipo de seguimiento de Seguimientos personalizados y el nombre de seguimiento
splash_screen_trace
.
- Haz clic en Seleccionar métrica para ver la duración de
splash_screen_trace
agregada a tu panel.
Puedes usar estos mismos pasos para agregar otras métricas que te interesen, de modo que puedas ver rápidamente cómo cambia su rendimiento con el paso del tiempo y hasta con diferentes lanzamientos.
El panel de métricas es una herramienta eficaz para realizar un seguimiento del rendimiento de las métricas clave que experimentan tus usuarios. En este codelab, tienes un pequeño conjunto de datos en un período acotado, por lo que usarás otras vistas de panel que te ayudarán a comprender el rendimiento del lanzamiento de funciones.
8. Lanza tu función
Ahora que configuraste la supervisión, está todo listo para implementar el cambio de Firebase Remote Config (seasonal_image_url)
que configuraste antes.
Para implementar un cambio, deberás volver a la página de Remote Config en Firebase console para aumentar el percentil de usuarios de tu condición de segmentación. Normalmente, lanzarás funciones nuevas para una pequeña parte de los usuarios y las aumentarás solo cuando estés seguro de que no hay problemas con ellas. Sin embargo, en este codelab, eres los únicos usuarios de la app, por lo que puedes cambiar el percentil a 100%.
- Haz clic en la pestaña Condiciones en la parte superior de la página.
- Haz clic en la condición
Seasonal image rollout
que agregaste antes. - Cambia el percentil a 100%.
- Haz clic en Guardar condición.
- Haz clic en Publicar cambios y confirma los cambios.
En Android Studio, reinicia la app en el emulador para ver la función nueva. Después de la pantalla de presentación, deberías ver la nueva pantalla principal de estado vacío.
9. Verifica los cambios en el rendimiento
Ahora, revisemos el rendimiento de la carga de la pantalla de presentación en el panel Rendimiento de Firebase console. En este paso del codelab, usarás diferentes partes del panel para ver datos de rendimiento.
- En la pestaña principal Panel, desplázate hacia abajo hasta la tabla de seguimientos y haz clic en la pestaña Seguimientos personalizados. En esta tabla, verás los seguimientos de código personalizado que agregaste antes, además de algunos seguimientos listos para usar.
- Ahora que habilitaste la nueva función, busca el seguimiento de código personalizado
splash_seasonal_image_processing
, que medía el tiempo que se tardó en descargar y procesar la imagen. En el valor de Duración del seguimiento, puedes ver que la descarga y el procesamiento tardan una cantidad de tiempo significativa.
- Como tienes datos de
splash_seasonal_image_processing
, puedes agregar la duración de este seguimiento a tu panel de métricas en la parte superior de la pestaña Panel.
Al igual que antes, haz clic en uno de los cuadros vacíos Seleccionar una métrica (Select a metric). En la ventana de diálogo, selecciona el tipo de seguimiento Seguimientos personalizados y el nombre de seguimiento splash_seasonal_image_processing
. Por último, haz clic en Seleccionar métrica para agregar esta métrica al panel.
- Para confirmar con más detalle las diferencias, puedes analizar con más detalle los datos de
splash_screen_trace
. Haz clic en la tarjetasplash_screen_trace
del panel de métricas y, luego, en Ver detalles de las métricas.
- En la página de detalles, verás una lista de atributos en la esquina inferior izquierda, incluido el atributo personalizado que creaste anteriormente. Haz clic en el atributo personalizado
seasonal_image_url_attribute
para ver la duración de la pantalla de presentación de cada URL de imagen de temporada que se encuentra a la derecha:
- Es probable que los valores de duración de la pantalla de presentación sean un poco diferentes a los de la captura de pantalla anterior, pero deberías tener una duración mayor cuando la imagen se descarga desde una URL en comparación con el uso de la imagen predeterminada (representada como "sin definir").
En este codelab, el motivo de esta mayor duración podría ser sencillo, pero en una app real puede no ser tan obvio. Los datos de duración recopilados provendrán de diferentes dispositivos que ejecuten la app en diferentes condiciones de conexión de red, las cuales podrían ser peores de lo que esperabas. Veamos cómo investigarías este problema si esta fuera una situación del mundo real.
- Haz clic en Rendimiento en la parte superior de la página para volver a la pestaña principal Panel:
- En la tabla de seguimientos, en la parte inferior de la página, haz clic en la pestaña Solicitudes de red. En esta tabla, verás todas las solicitudes de red de tu app agregadas en patrones de URL, incluido el patrón de URL
images.unsplash.com/**
. Si comparas el valor de este tiempo de respuesta con el tiempo total que se tarda en descargar y procesar imágenes (es decir, la duración del seguimientosplash_seasonal_image_processing
), puedes ver que se dedica una gran cantidad de tiempo a descargar la imagen.
Hallazgos de rendimiento
Con Firebase Performance Monitoring, notaste el siguiente impacto en los usuarios finales con la nueva función habilitada:
- El tiempo dedicado a
SplashScreenActivity
aumentó. - La duración de
splash_seasonal_image_processing
fue muy alta. - El retraso se debió al tiempo de respuesta para la descarga de la imagen y al tiempo de procesamiento correspondiente necesario para la imagen.
En el siguiente paso, mitigarás el impacto en el rendimiento mediante la reversión de la función y la identificación de cómo puedes mejorar su implementación.
10. Revertir la función
Aumenta la cantidad de usuarios el tiempo de espera durante la pantalla de presentación no es conveniente. Uno de los beneficios clave de Remote Config es la capacidad de pausar y revertir el lanzamiento sin tener que lanzar otra versión para los usuarios. Esto te permite reaccionar rápidamente ante los problemas (como los problemas de rendimiento que descubriste en el último paso) y minimizar la cantidad de usuarios insatisfechos.
Como mitigación rápida, restablecerás el percentil de lanzamiento a 0
para que todos tus usuarios vuelvan a ver la imagen predeterminada:
- Regresa a la página Remote Config de Firebase console.
- Haz clic en Condiciones en la parte superior de la página.
- Haz clic en la condición
Seasonal image rollout
que agregaste antes. - Cambia el percentil a 0%.
- Haz clic en Guardar condición.
- Haz clic en Publicar cambios y confirma los cambios.
Reinicia la app en Android Studio. Deberías ver la pantalla principal con el estado original vacío:
11. Corrige los problemas de rendimiento
Anteriormente en el codelab, descubriste que la descarga de una imagen para la pantalla de presentación provocaba una demora en la app. Si observas la imagen descargada con mayor detenimiento, notamos que estás usando la resolución original de la imagen, que era superior a 2 MB. Una solución rápida al problema de rendimiento es reducir la calidad a una resolución más adecuada, de modo que la imagen tarde menos tiempo en descargarse.
Vuelve a lanzar el valor de Remote Config
- Regresa a la página Remote Config de Firebase console.
- Haz clic en el ícono Editar del parámetro
seasonal_image_url
. - Actualiza el Valor para el lanzamiento de imágenes de temporada a
https://images.unsplash.com/photo-1552691021-7043334e0b51?w=640
y, luego, haz clic en Guardar.
- Haz clic en la pestaña Condiciones en la parte superior de la página.
- Haz clic en Lanzamiento de imágenes de temporada y, luego, vuelve a establecer el percentil en 100%.
- Haz clic en Guardar condición.
- Haz clic en el botón Publicar cambios.
12. Prueba la solución y configura alertas
Ejecuta la app de manera local
Con el nuevo valor de configuración establecido para usar una URL de imagen de descarga diferente, vuelve a ejecutar la app. Esta vez, notarás que el tiempo que pasas en la pantalla de presentación es más corto que antes.
Cómo consultar el rendimiento de los cambios
Vuelve al panel Rendimiento de Firebase console para ver cómo se ven las métricas.
- Esta vez, usarás la tabla de seguimientos para navegar a la página de detalles. En la pestaña Seguimientos personalizados de la tabla de seguimientos, haz clic en el seguimiento personalizado
splash_seasonal_image_processing
para volver a ver una vista más detallada de su métrica de duración.
- Haz clic en el atributo personalizado
seasonal_image_url_attribute
para volver a ver el desglose de estos. Si colocas el cursor sobre las URLs, verás un valor que coincide con la URL nueva para la imagen de tamaño reducido:https://images.unsplash.com/photo-1552691021-7043334e0b51?w=640
(con?w=640
al final). El valor de duración asociado con esta imagen es considerablemente menor que el de la imagen anterior y más aceptable para los usuarios.
- Ahora que mejoraste el rendimiento de la pantalla de presentación, puedes configurar alertas para que te notifiquen cuando un seguimiento supere el umbral que estableciste. Abre el panel Rendimiento y haz clic en el ícono del menú ampliado (de tres puntos) de splash_screen_trace y, luego, en Configuración de alertas.
- Haz clic en el botón de activación para habilitar la alerta de Duración. Establece el valor del umbral para que sea un poco superior al valor que ves, de modo que, si tu splash_screen_trace lo supera, recibas un correo electrónico.
- Haz clic en Guardar para crear la alerta. Desplázate hacia abajo hasta la tabla de seguimientos y, luego, haz clic en la pestaña Seguimientos personalizados para ver que la alerta está habilitada.
13. ¡Felicitaciones!
¡Felicitaciones! Habilitaste el SDK de Firebase Performance Monitoring y recopilaste registros para medir el rendimiento de una función nueva. Supervisaste las métricas de rendimiento clave para el lanzamiento de una función nueva y reaccionaste rápidamente cuando se descubrió un problema de rendimiento. Todo esto fue posible gracias a la capacidad de realizar cambios en la configuración con Remote Config y supervisar los problemas de rendimiento en tiempo real.
Temas abordados
- Agrega el SDK de Firebase Performance Monitoring a tu app
- Agrega un seguimiento de código personalizado a tu código para medir una función específica
- Configurar un parámetro y un valor condicional de Remote Config para controlar o lanzar una función nueva
- Comprender cómo usar el panel de supervisión del rendimiento para identificar problemas durante un lanzamiento
- Cómo configurar alertas de rendimiento para recibir notificaciones cuando el rendimiento de la app supera el umbral que estableciste