Configura la seguridad del servicio en la malla de servicios de sidecar de Envoy en GKE
En esta página, se describe cómo configurar funciones de seguridad en la malla de servicios de sidecar de Envoy en GKE.
Requisitos previos
Como punto de partida, en esta guía se supone que ya hiciste lo siguiente:
- Creaste un clúster de GKE y lo registraste en una flota.
- Configura la malla de servicios de sidecar de Envoy con las APIs de Gateway.
Configura políticas de autorización en contenedores secundarios en GKE
En esta sección, se muestra cómo configurar diferentes tipos de políticas de autorización en los pares secundarios de Cloud Service Mesh en GKE.
Antes de crear una política de autorización, debes instalar la CustomResourceDefinition (CRD) GCPAuthzPolicy:
curl https://github.com/GoogleCloudPlatform/gke-networking-recipes/blob/main/gateway-api/config/mesh/crd/experimental/gcpauthzpolicy.yaml \
| kubectl apply -f -
Las políticas de autorización pueden aplicar el control de acceso en el tráfico que ingresa a los subprocesos de Envoy. Las políticas se pueden aplicar en implementaciones de Kubernetes. Deployment debe estar en el mismo espacio de nombres que la política de autorización.
Política de autorización para rechazar todas las solicitudes
Cuando tienes una carga de trabajo que debe realizar solo llamadas salientes, como un trabajo cron, puedes configurar una política de autorización para rechazar cualquier solicitud HTTP entrante a la carga de trabajo. En el siguiente ejemplo, se rechazan las solicitudes HTTP entrantes a la carga de trabajo whereami
.
Sigue estos pasos para crear y aplicar la política de autorización de denegación:
Para crear una política de denegación, crea un archivo llamado
deny-all-authz-policy.yaml
:cat >deny-all-authz-policy.yaml <<EOF apiVersion: networking.gke.io/v1 kind: GCPAuthzPolicy metadata: name: myworkload-authz namespace: sidecar-example spec: targetRefs: - kind: Deployment name: whereami httpRules: - to: operations: - paths: - type: Prefix value: "/" action: DENY EOF
Aplica la política:
kubectl apply -f deny-all-authz-policy.yaml
Política de autorización para permitir solicitudes
También puedes configurar una política de permiso que solo permita solicitudes que coincidan con un criterios específico y rechace el resto. En el siguiente ejemplo, se configura una
política de autorización en whereami
, en la que solo se permitirán las solicitudes GET
que tengan el encabezado HTTP x-user-role:admin
presente en la solicitud.
Sigue estos pasos para crear y aplicar la política de autorización de permiso, borra la política de denegación creada anteriormente antes de agregar esta política para ver los resultados:
Para crear una política personalizada, crea un archivo llamado
allow-authz-policy.yaml
:cat >allow-authz-policy.yaml <<EOF apiVersion: networking.gke.io/v1 kind: GCPAuthzPolicy metadata: name: myworkload-authz namespace: sidecar-example spec: targetRefs: - kind: Deployment name: whereami httpRules: - to: operations: - methods: ["GET"] when: "request.headers['x-user-role'] == 'admin' action: ALLOW EOF
Aplica la política:
kubectl apply -f allow-authz-policy.yaml
Política de autorización para denegar solicitudes según reglas
En el siguiente ejemplo, se rechazan las solicitudes HTTP GET
entrantes a la carga de trabajo whereami
cuando se encuentra en la ruta /admin
.
Sigue estos pasos para crear y aplicar la política de autorización de denegación:
Para crear una política de denegación, crea un archivo llamado
deny-path-authz-policy.yaml
:cat >deny-path-authz-policy.yaml <<EOF apiVersion: networking.gke.io/v1 kind: GCPAuthzPolicy metadata: name: myworkload-authz namespace: sidecar-example spec: targetRefs: - kind: Deployment name: whereami httpRules: - to: operations: - paths: - type: Prefix value: "/admin" methods: ["GET"] action: DENY EOF
Aplica la política:
kubectl apply -f deny-path-authz-policy.yaml