En este documento, se describe cómo usar roles y permisos de Identity and Access Management (IAM) para para controlar el acceso a los datos de registro la API de Logging, el el Explorador de registros Google Cloud CLI.
Descripción general
Los permisos y los roles de IAM determinan tu capacidad para acceder a los datos de registros en la API de Logging, el Explorador de registros y la CLI de Google Cloud.
Un rol es un conjunto de permisos. No puedes otorgar permisos principales directamente. En su lugar, les otorgas una función. Cuando otorgas un rol a una principal, le otorgas todos los permisos que el rol contiene. Puedes otorgar varios roles a la misma principal.
Para usar Logging dentro de un recurso de Google Cloud, como un proyecto, una carpeta, un bucket o una organización de Google Cloud, una principal debe tener un de IAM que contiene los permisos adecuados.
Funciones predefinidas
IAM proporciona roles predefinidos para otorgar acceso detallado a a recursos específicos de Google Cloud y evitar el acceso no deseado a otros de Google Cloud. Google Cloud crea y mantiene estos roles y actualiza sus permisos automáticamente, según sea necesario, como cuando Logging agrega funciones nuevas.
En la siguiente tabla, se enumeran los roles predefinidos de Logging. Para de cada rol, la tabla muestra el título del rol, la descripción permisos y el tipo de recurso de nivel más bajo en el que se pueden otorgar los roles. Puedes otorgar los roles predefinidos a nivel del proyecto de Google Cloud o, en la mayoría de los casos, a cualquier tipo superior en la jerarquía de recursos. Para restringir el rol de Acceso a la vista de registros a una vista de registros en un bucket, usa los atributos de recursos para las condiciones de IAM.
Para obtener una lista de todos los permisos individuales que contiene un rol, consulta Cómo obtener los metadatos de la función.
Role | Permissions |
---|---|
Logging Admin( Provides all permissions necessary to use all features of Cloud Logging. Lowest-level resources where you can grant this role:
|
|
Logs Bucket Writer( Ability to write logs to a log bucket. Lowest-level resources where you can grant this role:
|
|
Logs Configuration Writer( Provides permissions to read and write the configurations of logs-based metrics and sinks for exporting logs. Lowest-level resources where you can grant this role:
|
|
Log Field Accessor( Ability to read restricted fields in a log bucket. Lowest-level resources where you can grant this role:
|
|
Log Link Accessor( Ability to see links for a bucket. |
|
Logs Writer( Provides the permissions to write log entries. Lowest-level resources where you can grant this role:
|
|
Private Logs Viewer( Provides permissions of the Logs Viewer role and in addition, provides read-only access to log entries in private logs. Lowest-level resources where you can grant this role:
|
|
SQL Alert Writer Beta( Ability to write SQL Alerts. |
|
Logs View Accessor( Ability to read logs in a view. Lowest-level resources where you can grant this role:
|
|
Logs Viewer( Provides access to view logs. Lowest-level resources where you can grant this role:
|
|
En las siguientes secciones, se proporciona información adicional para ayudarte a decidir qué roles se aplican a los casos de uso de tus principales.
Funciones de Logging
Para permitir que un usuario realice todas las acciones en Logging, otorga el rol de Administrador de Logging (
roles/logging.admin
).Para permitir que un usuario cree y modifique configuraciones de registro, otorga el rol de escritor de configuración de registros (
roles/logging.configWriter
). Este rol te permite crear o modificar cualquiera de los siguientes elementos:- Receptores de registros
- Buckets de registros
- Vistas de registro
- Conjuntos de datos vinculados
- Permisos de registros
Este rol no es suficiente para crear métricas basadas en registros o políticas de alertas basadas en registros. Para obtener información sobre el los roles necesarios para estas tareas, consulta Permisos para métricas basadas en registros y Permisos para políticas de alertas basadas en registros.
Para permitir que un usuario lea registros en los buckets
_Required
y_Default
, o use las páginas Explorador de registros y Análisis de registros, otorga uno de los siguientes roles:- Para obtener acceso a todos los registros del bucket
_Required
y a la vista_Default
en el bucket_Default
, otorga el rol de Visualizador de registros (roles/logging.viewer
). - Para obtener acceso a todos los registros de los buckets
_Required
y_Default
, incluidos los registros de acceso a los datos, otorga el rol de Visor de registros privados (roles/logging.privateLogViewer
).
- Para obtener acceso a todos los registros del bucket
Para permitir que un usuario lea registros en todas las vistas de registro de un proyecto, otorgue el rol de IAM de
roles/logging.viewAccessor
en el proyecto.Para permitir que un usuario solo lea los registros de una vista de registro específica, tienes dos opciones:
Crea una política de IAM para la vista de registro y, luego, agrega una IAM vinculada a esa política que otorga a la principal acceso a la vista de registro.
Otorga a la principal el rol de IAM de
roles/logging.viewAccessor
en el proyecto que contiene la vista de registro. pero adjuntar un Condición de IAM a restringir el otorgamiento a una vista de registro específica.
Para obtener información sobre cómo crear vistas de registro y otorgar acceso, consulta Configura vistas de registro en un bucket de registros.
- Para otorgar a un usuario acceso a campos restringidos de
LogEntry
, si los hay, haz lo siguiente: en un bucket de registros determinado, otorga rol de Acceso a campos de registros (roles/logging.fieldAccessor
). Para obtener más información, consulta Configura el acceso a nivel del campo.
Para permitir que un usuario escriba registros con la API de Logging, otorga el rol de escritor de registros (
roles/logging.logWriter
). Este rol no otorga permisos de lectura.Para permitir que la cuenta de servicio de un receptor enrute los registros a un bucket en un otro proyecto de Google Cloud, otórgale a la cuenta de servicio Rol de escritor de buckets de registros (
roles/logging.bucketWriter
). Para obtener instrucciones sobre cómo otorgar permisos a una cuenta de servicio, consulta Cómo establecer permisos de destino.
Funciones a nivel de proyecto
Para otorgar acceso de lectura a la mayoría de los servicios de Google Cloud, otorga el rol de Visualizador (
roles/viewer
).Este rol incluye todos los permisos otorgados por el Visualizador de registros (
roles/logging.viewer
).Para otorgar acceso de editor a la mayoría de los servicios de Google Cloud, otorga el rol de editor (
roles/editor
).Este rol incluye todos los permisos otorgados por el de Visualizador de registros (
roles/logging.viewer
) y los permisos para escribir entradas de registro, borrar registros y crear métricas basadas en registros. Sin embargo, este rol no permite que los usuarios creen receptores, lean registros de auditoría de acceso a los datos que se encuentran en el bucket_Default
ni lean registros que se encuentran en buckets de registro definidos por el usuario.Para otorgar acceso completo a la mayoría de los servicios de Google Cloud, otorga el rol de propietario (
roles/owner
).
Otorgando funciones
Para obtener información sobre cómo otorgar un rol a una principal, consulta Cómo otorgar, cambiar y revocar el acceso a los recursos
Se puede asignar varios roles al mismo usuario. Para obtener una lista de los permisos que contiene una función, consulta la página sobre cómo obtener los metadatos de la función.
Si intentas acceder a un recurso de Google Cloud y no tienes los recursos permisos, comunícate con la principal que aparece como Propietario de la recurso.
Funciones personalizadas
A fin de crear una función personalizada con permisos de Logging, haz lo siguiente:
Para una función que otorga permisos a la API de Logging, elige los permisos de Permisos de la API y, luego, sigue las instrucciones para crear una función personalizada.
Para un rol que otorgue permisos para usar el Explorador de registros, elige grupos de permisos en Permisos de la consola y, luego, sigue las instrucciones para crear un rol personalizado.
Para obtener un rol que otorgue permisos para usar
gcloud logging
, consulta la sección Permisos de línea de comandos en esta página y, luego, sigue las instrucciones para crear un rol personalizado.
Para obtener más información sobre los roles personalizados, consulta Comprende las funciones personalizadas de IAM.
Permisos de Cloud Logging
La siguiente tabla es una lista parcial de los permisos necesarios para determinados de Cloud Logging. Esta tabla puede ayudarte a identificar los permisos que necesitas para usar páginas como el Explorador de registros.
En la tabla, a.b.[x,y]
significa a.b.x
y a.b.y
.
Actividad de Console | Permisos necesarios |
---|---|
Acceso de solo lectura mínimo | logging.logEntries.list |
Ver los registros de auditoría de acceso a los datos | logging.privateLogEntries.list |
Visualiza métricas basadas en registros | logging.logMetrics.[list, get] |
Ver receptores | logging.sinks.[list, get] |
Consulta el uso de registros | logging.usage.get |
Excluye registros | logging.exclusions.[list, create, get, update, delete]
Cuando se crea un rol personalizado que incluye permisos para
administrar filtros de exclusión, agregar |
Crea y usa receptores | logging.sinks.[list, create, get, update, delete]
Cuando creas un receptor, también debes otorgar a la cuenta de servicio un rol de IAM que le permite escribir entradas de registro en destino. Para obtener más información, consulta Configura los permisos del destino. Una vez que tus entradas de registro se enrutan a un destino compatible, el acceso a ellas se controla por completo con los permisos y roles de IAM en el destino. |
Crea alertas basadas en registros | Consulta Roles necesarios para crear y Usar políticas de alertas basadas en registros |
Crea métricas basadas en registros | logging.logMetrics.[list, create, get, update, delete]
Si deseas obtener información sobre otros roles de IAM que necesitas para crear y usar métricas basadas en registros, consulta Roles necesarios para crear y usar métricas basadas en registros. |
Guarda y usa consultas privadas | logging.queries.usePrivate logging.queries.[listShared,getShared] |
Guarda y usa consultas compartidas | logging.queries.[share, getShared, updateShared, deleteShared,
listShared] |
Usa consultas recientes | logging.queries.[create, list] |
Permisos para la línea de comandos
Los comandos gcloud logging
están controlados por los permisos de IAM.
Para usar cualquiera de los comandos de gcloud logging
, las principales deben tener lo siguiente:
serviceusage.services.use
.
Un principal también debe tener el rol de IAM correspondiente al recurso del registro y al caso de uso. Para obtener más información, consulta los permisos de la interfaz de línea de comandos.
Roles necesarios para crear y usar métricas basadas en registros
A continuación, se incluye un resumen de las funciones y los permisos comunes que un principal necesita para acceder a las métricas basadas en registros:
El rol de Escritor de configuración de registros (
roles/logging.configWriter
) permite que los principales enumeren, creen, obtengan, actualicen y borren métricas basadas en registros.El rol de Visualizador de registros (
roles/logging.viewer
) contiene permisos para ver las métricas existentes. Específicamente, una principal necesita los permisoslogging.logMetrics.get
ylogging.logMetrics.list
para ver las métricas existentes.El Visualizador de Monitoring (
roles/monitoring.viewer
) contiene los permisos para leer datos de TimeSeries. Específicamente, un principal necesita El permisomonitoring.timeSeries.list
para leer datos de series temporalesLos roles de Administrador de Logging (
roles/logging.admin
), Editor de proyectos (roles/editor
) y Propietario del proyecto (roles/owner
) contienen los permisos para crear métricas basadas en registros. Específicamente, un principal necesita el permisologging.logMetrics.create
para crear métricas basadas en registros.
Roles necesarios para crear y usar políticas de alertas basadas en registros
Para crear y administrar políticas de alertas basadas en registros, un principal necesita los siguientes roles y permisos de Logging y Monitoring:
-
Para obtener los permisos que necesitas para crear políticas de alertas basadas en registros en la supervisión y crear las reglas de notificación de registro asociadas, pídele a tu administrador que te otorgue los siguientes roles de IAM en tu proyecto:
-
Editor de políticas de alertas de Monitoring (
roles/monitoring.alertPolicyEditor
) -
Escritor de configuración de registros (
roles/logging.configWriter
)
Para obtener más información sobre cómo otorgar roles, consulta Administra el acceso a proyectos, carpetas y organizaciones.
Estos roles predefinidos contienen los permisos necesarios para crear políticas de alertas basadas en registros en Monitoring y para crear las reglas de notificación de registro asociadas. Para ver los permisos exactos que son necesarios, expande la sección Permisos requeridos:
Permisos necesarios
Se requieren los siguientes permisos para crear políticas de alertas basadas en registros en Monitoring y las reglas de notificación de Logging asociadas:
-
monitoring.alertPolicies.create
-
logging.notificationRules.create
También puedes obtener estos permisos con roles personalizados o con otros roles predefinidos.
-
Editor de políticas de alertas de Monitoring (
Si creas tu política de alertas en Google Cloud CLI, también se requiere el siguiente rol o permiso:
-
Para obtener el permiso que necesitas para crear una política de alertas con la CLI de Google Cloud, pídele a tu administrador que te otorgue el rol de IAM de Consumidor de Service Usage (
roles/serviceusage.serviceUsageConsumer
) en tu proyecto. Para obtener más información sobre cómo otorgar roles, consulta Administra el acceso a proyectos, carpetas y organizaciones.Este rol predefinido contiene las
serviceusage.services.use
permiso, que se requiere para crear una política de alertas con Google Cloud CLI.También puedes obtener este permiso con roles personalizados o con otros roles predefinidos.
Si tu proyecto de Google Cloud ya tiene canales de notificaciones, puedes configura tu política de alertas para usar un canal existente sin ninguna roles o permisos adicionales. Sin embargo, si necesitas crear un canal de notificaciones para tu política de alertas basada en registros, se aplicará el siguiente rol o permiso requerido:
-
A fin de obtener el permiso que necesitas para crear un canal de notificaciones para una política de alertas basada en registros, solicita a tu administrador que te otorgue el Rol de IAM de Editor de canal de notificaciones de Monitoring (
roles/monitoring.notificationChannelEditor
) en tu proyecto.Este rol predefinido contiene las
monitoring.notificationChannels.create
permiso, que se requiere para crear un canal de notificaciones para una política de alertas basada en registros.
Niveles de acceso de Logging
Los permisos de acceso son método heredado de especificar permisos para las cuentas de servicio en tu Instancias de VM de Compute Engine.
Los siguientes niveles de acceso aplican a la API de Logging:
Nivel de acceso | Permisos otorgados |
---|---|
https://www.googleapis.com/auth/logging.read | roles/logging.viewer |
https://www.googleapis.com/auth/logging.write | roles/logging.logWriter |
https://www.googleapis.com/auth/logging.admin | Acceso completo a la API de Logging. |
https://www.googleapis.com/auth/cloud-platform | Acceso completo a la API de Logging y a otras API habilitadas de Google Cloud. |
Si deseas obtener información sobre el uso de este método heredado para configurar las contraseñas niveles de acceso, consulta Permisos de la cuenta de servicio.