Antes de implementar un servicio en Cloud Run, puedes desarrollarlo de forma local con un emulador de Cloud Run.
Configura el servicio para el desarrollo
Si no tienes un archivo .vscode/launch.json
definido, el diálogo Run/Debug on Cloud Run Emulator te permite configurar el lanzamiento y, luego, guardar la configuración en .vscode/launch.json
. Si tienes configurado un archivo .vscode/launch.json
, puedes editarlo directamente.
Para ejecutar el servicio de manera local, especifica la configuración:
- Abre la paleta de comandos (presiona
Ctrl
/Cmd
+Shift
+P
o haz clic en Ver > Paleta de comandos) y, luego, ejecuta el comando Run on Cloud Run Emulator. En el cuadro de diálogo Ejecutar/Depurar en un emulador de Cloud Run, establece las especificaciones para tu configuración:
- Solo las herramientas de compilación instaladas de forma local están disponibles para el emulador de Cloud Run.
- Elige Docker o Buildpacks como tu compilador y, luego, especifica la fuente.
- Para especificar las variables de entorno que se pasarán a los contenedores en ejecución, expande Configuración de compilación avanzada y, luego, haz clic para especificar los pares clave-valor (opcional).
Nombre Descripción Ejemplo PUERTO Es el puerto en el que el servidor HTTP debe escuchar. 8080 K_SERVICE El nombre del servicio de Cloud Run que se ejecuta. hello-world K_REVISION El nombre de la revisión de Cloud Run que se ejecuta. hello-world.1 K_CONFIGURATION El nombre de la configuración de Cloud Run que creó la revisión. hello-world - Para especificar conexiones de Cloud SQL, expande Configuración avanzada del servicio, haz clic en Conexiones y, luego, especifica una conexión de Cloud SQL por línea (opcional).
- (Opcional) Marca la opción Permitir el acceso al servicio desde otros dispositivos de la red local.
- Opcional: Si solo quieres volver a compilar y ejecutar el servicio de forma manual, en lugar de hacerlo automáticamente cuando realices un cambio, borra la opción Automatically re-build and re-run on changes.
Ejecuta el servicio de forma local
Después de definir la configuración que desees, haz clic en Run para ejecutar el servicio.
Si se te solicita, autentica tus credenciales para ejecutar y depurar una aplicación de forma local.
Supervisa el estado de tu implementación en la ventana de salida.
Una vez completada la implementación, puedes ver el servicio en ejecución si abres la URL que se muestra en la ventana de resultados.
Para ver los registros detallados, cambia a la vista detallada de Cloud Run en la ventana de salida.
Cuando se complete la sesión, haz clic con el botón derecho para usar los siguientes comandos:
- Ver registros: Abre los registros de la aplicación de una implementación específica con el explorador de registros de Cloud Code.
- Abrir URL: Abre la URL del servicio de la aplicación de un servicio específico en un navegador web.
Si desactivaste el modo de observación en la configuración de lanzamiento y deseas realizar cambios en la aplicación y volver a compilar y a implementar la aplicación, haz clic en la barra de estado de Cloud Code y, luego, en Activar el modo de observación.
Para detener la implementación, puedes hacer clic en el botón Detener en la barra de acciones de la implementación actual.
Almacenar secretos
Si el código incluye datos potencialmente sensibles, como claves de API, contraseñas y certificados, almacenarlos como secretos puede ayudar a protegerlos. La integración de Secret Manager de Cloud Code te permite almacenar estos secretos de forma segura y recuperarlos de manera programática. Para obtener información detallada sobre cómo crear y administrar secretos con Cloud Code, consulta la guía de Secret Manager.
Personaliza una configuración launch.json existente
El complemento de Cloud Code actualiza el archivo de configuración launch.json
automáticamente cuando eliges una acción de ejecución. Para personalizar aún más la manera en la que se ejecuta tu servicio, puedes especificar los siguientes campos en tu archivo .vscode/launch.json
:
watch: Observa los cambios en el lugar de trabajo y vuelve a ejecutar el servicio. Es verdadero de forma predeterminada.
En el siguiente ejemplo, se muestra el reloj configurado en
true
:"watch": true,
build: Especifica el compilador (Docker, jibMaven, jibGradle o buildpacks) con el que deseas compilar tus imágenes.
En el siguiente ejemplo, se muestra un compilador de Docker:
"build": { "docker": { "path": "Dockerfile" } },
En el siguiente ejemplo, se muestra un compilador de buildpack:
"build": { "buildpacks": { "path": "src/requirements.txt", "builder": "gcr.io/buildpacks/builder:v1" } },
image: Especifica el nombre de la imagen que se usará.
En el siguiente ejemplo, se muestra cómo especificar un nombre de imagen:
"image": "hello-world",
servicio: Especifica el servicio de Cloud Run que quieres usar.
En el siguiente ejemplo, se muestra cómo especificar un nombre de servicio, un puerto y límites de recursos:
"service": { "name": "hello-world", "containerPort": 8080, "resources": { "limits": { "memory": "256Mi" } } },
debug: Especifica la configuración de depuración, como la asignación de ruta de acceso remota, para asignar una ruta de acceso local a una ruta en el contenedor remoto.
En el siguiente ejemplo, se muestra una sección de depuración que indica la ubicación de los archivos fuente:
"debug": { "sourceFileMap": { "${workspaceFolder}": "/app" } }