Usa los registros de flujo para guardar los metadatos del tráfico de red, incluidas las 5-tuplas, en Google Distributed Cloud (GDC) aislado para la pila de observabilidad en forma de registros consultables. Usa estos registros para lo siguiente:
- Comprender los flujos de tráfico de un servicio específico en una organización
- Comprender e identificar problemas con el estado de red de una carga de trabajo de Kubernetes
- Verifica las políticas de red de Kubernetes.
El registro de flujo es una función de GDC basada en el proyecto de código abierto Hubble: https://github.com/cilium/hubble. Configura los registros de flujo con el recurso FlowLog de la API de Networking.
Antes de comenzar
Debes obtener autorización para administrar o ver los registros de flujo desde la consola de GDC. Para administrar los registros de flujo, pídele al administrador de IAM de tu organización que te otorgue el rol de administrador de registros de flujo (
flowlog-admin). Para ver solo los registros de flujo existentes, pídele al administrador de IAM de tu organización que te otorgue el rol de visualizador de registros de flujo (flowlog-viewer).Para obtener información sobre cómo configurar vinculaciones de roles desde la consola de GDC, consulta Otorga acceso a los recursos.
Antes de consultar y ver los registros de flujo en los paneles, debes obtener acceso a la instancia de supervisión. Para obtener más información, consulta Cómo consultar y ver métricas.
Crea un registro de flujo
Crea un registro de flujo para guardar los metadatos del tráfico de red que se filtran según un conjunto determinado de especificaciones.
Crea un registro de flujo con filtros de protocolo y espacio de nombres
Crea un archivo
example-flowlog.yamlcon el siguiente contenido:apiVersion: networking.gdc.goog/v1 kind: FlowLog metadata: name: "FLOW_LOG_NAME" namespace: "platform" spec: filters: - l4Protocols: - tcp source: namespacePodSelectors: - namespace: gpc-system - namespace: kube-system destination: namespacePodSelectors: - namespace: kube-system lifetime: duration: "1h"Reemplaza
FLOW_LOG_NAMEpor el nombre elegido para el registro de flujo.En este ejemplo, el registro de flujo captura todos los flujos para los que cualquier pod en el espacio de nombres
gpc-systemokube-systeminició una conexión TCP a cualquier pod en el espacio de nombreskube-system. Se detiene el registro de los registros una hora después de la creación del objeto.Crea el objeto de registro de flujo:
kubectl --kubeconfig MANAGEMENT_API_SERVER apply -f example-flowlog.yamlReemplaza
MANAGEMENT_API_SERVERpor la ruta de acceso al archivo kubeconfig del servidor de la API de Management zonal.Verifica que el valor de
FLOW_LOG_NAMEse haya conciliado correctamente y que el proceso de registro se haya iniciado. Para ello, examina el campoStatus:kubectl --kubeconfig MANAGEMENT_API_SERVER describe -n platform FLOW_LOG_NAMEEjemplo de estado:
Status: Clusters: Cluster: org-1-infra-cluster Conditions: Last Transition Time: 2024-01-19T01:46:11Z Message: Observed Generation: 1 Reason: ResourcesPropagated Status: True Type: Propagated Name: cilium-flowlog-config Namespace: kube-system Node: org-1-infra Cluster: user-vm-1-cluster Conditions: Last Transition Time: 2024-01-19T01:46:11Z Message: Observed Generation: 1 Reason: ResourcesPropagated Status: True Type: Propagated Name: cilium-flowlog-config Namespace: kube-system Node: user-vm-1 Cluster: user-vm-2-cluster Conditions: Last Transition Time: 2024-01-19T01:46:11Z Message: Observed Generation: 1 Reason: ResourcesPropagated Status: True Type: Propagated Name: cilium-flowlog-config Namespace: kube-system Node: user-vm-2 Conditions: Last Transition Time: 2024-01-18T19:17:53Z Message: Observed Generation: 1 Reason: Active Status: True Type: Logging Last Transition Time: 2024-01-19T01:46:11Z Message: Observed Generation: 1 Reason: ResourcesPropagated Status: True Type: Propagated Last Transition Time: 2024-01-18T19:17:53Z Message: Observed Generation: 1 Reason: Succeeded Status: True Type: Reconciled Start Time: 2024-01-18T19:17:53Z End Time: 2024-01-18T20:17:53ZEl resultado de este ejemplo contiene las siguientes condiciones:
Propagated: La configuración del registro de flujo se envió a los clústeresuser-vm-1,user-vm-2yorg-1-infra.Reconciled: El registro de flujo se programó correctamente en los clústeresuser-vm-1,user-vm-2yorg-1-infra.Logging: El registro de flujo no venció ni está inhabilitado, no encontró ningún error y puede generar registros si los filtros coinciden con los flujos.- Los íconos
Start TimeyEnd Timeindican que el trabajo comenzó a las19:17:53y vence a las20:17:53.
Para que este registro de flujo pueda producir entradas de registro correctamente, todas las condiciones de
Propagated,ReconciledyLoggingdeben ser verdaderas.
Modificar registro de flujo
Para modificar un registro de flujo existente, modifica la definición del objeto de registro de flujo creado en el archivo example-flowlog.yaml y vuelve a aplicarlo:
kubectl --kubeconfig MANAGEMENT_API_SERVER apply -f example-flowlog.yaml
Visualiza los registros de flujo en el panel de supervisión
Abre el panel de registros operativos. Para obtener más información, consulta Cómo consultar registros operativos.
Establece el valor del menú desplegable identifier en
network-flow-logs, luego haz clic en add json parser y proporciona el siguiente valor a la consulta:{identifier="network-flow-logs"} | json:
Haz clic en Ejecutar consulta. Esto muestra las entradas de registro de flujo guardadas:

Usa los filtros para definir mejor los resultados. Por ejemplo, proporciona el menú desplegable cluster con un valor de
user-vm-1para observar solo los flujos recopilados del clústeruser-vm-1:
Navega por las entradas del registro de flujo, expande la entrada para ver los detalles y agrega más filtros de etiquetas según sea necesario con el ícono de acceso directo. En este ejemplo, queremos filtrar aún más los flujos por su dirección IP de origen:

Haz clic en el ícono de acceso directo
+para filtrar los flujos por un campo de metadatos específico.
Visualiza los resultados por nombre del registro de flujo
Cuando se crean varios registros de flujo, se puede crear un filtro de etiquetas adicional para ver los resultados de uno o más registros de flujo.
Para ver los resultados limitados a los registros producidos por FLOW_LOG_NAME, crea un filtro de etiquetas con los siguientes valores:
Labelestá establecido enOn. Distingue mayúsculas de minúsculas.Operatorestá establecido en~=. Esto usa un comparador de expresiones regulares.Valueestá establecido en/FLOW_LOG_NAME/. El valorFLOW_LOG_NAMEdebe estar entre/.
Filtra los resultados para ver solo los registros producidos por flowlog1:

Referencias
- Documentación sobre el exportador dinámico de Hubble: https://docs.cilium.io/en/latest/observability/hubble-exporter/#dynamic-exporter-configuration