For Large Clusters L4 ILB Subsetting Should Be Used
More Info:
GKE cluster should use GKE L4 ILB Subsetting if nodes > 250
Risk Level
High
Address
Security
Compliance Standards
CBP
Triage and Remediation
Remediation
To remediate the misconfiguration “For Large Clusters L4 ILB Subsetting Should Be Used” for GCP using GCP console, follow the below steps:
-
Log in to your GCP console and select the project where the misconfiguration exists.
-
Go to the “Kubernetes Engine” section from the main menu.
-
Click on the name of the cluster that you want to remediate.
-
Click on the “Edit” button.
-
Scroll down to the “Networking” section and click on “Advanced options”.
-
Under “Load balancing”, select “L4 Internal Load Balancer”.
-
In the “Backend configuration” section, click on “Create a new backend configuration”.
-
In the “Backend configuration” page, give a name to the backend configuration.
-
In the “Backend service” section, select the appropriate service from the dropdown.
-
In the “Backend instance group” section, select the instance group that you want to use.
-
In the “Health check” section, select the appropriate health check from the dropdown.
-
In the “Session affinity” section, select “None”.
-
Click on the “Create” button to create the backend configuration.
-
Back in the “Load balancing” section, click on “Create a new load balancer”.
-
In the “Create a Load Balancer” page, select “Internal” for the “Type” field.
-
Give a name to the load balancer.
-
In the “Backend configuration” section, select the backend configuration that you just created.
-
In the “Frontend configuration” section, select “HTTP(S)” for the “Protocol” field.
-
In the “IP address” section, select “Internal IP address”.
-
Click on the “Create” button to create the load balancer.
-
Wait for a few minutes for the load balancer to be created.
-
Once the load balancer is created, go back to the “Kubernetes Engine” section and click on the name of the cluster.
-
Click on the “Edit” button.
-
Scroll down to the “Networking” section and click on “Advanced options”.
-
Under “Load balancing”, select the load balancer that you just created.
-
Click on the “Save” button to save the changes.
By following these steps, you can remediate the misconfiguration “For Large Clusters L4 ILB Subsetting Should Be Used” for GCP using GCP console.
To remediate the misconfiguration “For Large Clusters L4 ILB Subsetting Should Be Used” for GCP using GCP CLI, you can follow the below steps:
- Open the Cloud Shell in your GCP console.
- Check if you have the latest version of gcloud CLI by running the command:
gcloud components update
. - Run the command
gcloud config set project [PROJECT_ID]
to set the project where the misconfiguration exists. - Run the command
gcloud compute backend-services list
to list all the backend services in the project. - Identify the backend service for which you want to enable L4 ILB subsetting.
- Run the command
gcloud compute backend-services update [BACKEND_SERVICE_NAME] --load-balancing-scheme internal --load-balancing-mode UTILIZATION --max-utilization 0.8 --connection-draining-timeout 300 --session-affinity NONE --health-checks [HEALTH_CHECK_NAME] --enable-logging --global --subnet [SUBNET_NAME] --database-subnet [DATABASE_SUBNET_NAME] --enable-cdn --l4-ilb-subsetting-enabled
to enable L4 ILB subsetting for the backend service.
Note: Replace the placeholders [PROJECT_ID], [BACKEND_SERVICE_NAME], [HEALTH_CHECK_NAME], [SUBNET_NAME], and [DATABASE_SUBNET_NAME] with the actual values specific to your project and backend service.
To remediate the misconfiguration “For Large Clusters L4 ILB Subsetting Should Be Used” in GCP using Python, follow the steps below:
- Import the necessary libraries:
from google.cloud import compute_v1
- Define the project ID and the zone where the instance is located:
project_id = 'your-project-id'
zone = 'us-central1-a'
- Create a Compute Engine client:
compute_client = compute_v1.InstancesClient()
- Retrieve the instance resource:
instance_name = 'your-instance-name'
instance = compute_client.get(project_id=project_id, zone=zone, instance=instance_name)
- Check if the instance has a network interface:
if instance.network_interfaces:
- Retrieve the network interface:
network_interface = instance.network_interfaces[0]
- Check if the network interface has an attached network endpoint group:
if network_interface.network_endpoint_groups:
- Retrieve the network endpoint group:
network_endpoint_group = network_interface.network_endpoint_groups[0]
- Check if the network endpoint group has a load balancing scheme of INTERNAL:
if network_endpoint_group.load_balancing_scheme == compute_v1.types.NetworkEndpointGroup.LoadBalancingScheme.INTERNAL:
- Check if the network endpoint group has a load balancing scheme of INTERNAL_MANAGED:
if network_endpoint_group.load_balancing_scheme == compute_v1.types.NetworkEndpointGroup.LoadBalancingScheme.INTERNAL_MANAGED:
- Check if the network endpoint group has a load balancing scheme of INTERNAL_SELF_MANAGED:
if network_endpoint_group.load_balancing_scheme == compute_v1.types.NetworkEndpointGroup.LoadBalancingScheme.INTERNAL_SELF_MANAGED:
- Retrieve the health check:
health_check = network_endpoint_group.health_checks[0]
- Update the L4 ILB Subsetting setting:
network_endpoint_group.l4_ilb_subsetting = True
network_endpoint_group.update_mask.add_field('l4_ilb_subsetting')
compute_client.update_network_endpoint_group(project=project_id, zone=zone, networkEndpointGroup=network_endpoint_group.name, body=network_endpoint_group)
- Print a success message:
print('L4 ILB Subsetting has been enabled for the network endpoint group.')
By following these steps, you can remediate the “For Large Clusters L4 ILB Subsetting Should Be Used” misconfiguration in GCP using Python.