Set up Insights: Kubernetes connector

The Insights feature is available only with Snyk AppRisk Pro.

Snyk recommends installing the Snyk Runtime Sensor to achieve the most effective integration and access its continuously expanded set of features.

What is Kubernetes connector for Snyk AppRisk?

One of the goals is to identify risk factors for workloads that are publicly accessible through a network configuration. To do that, Snyk needs to understand what images are deployed on which workloads and how they are configured.

Thus, Snyk needs to collect the following information:

  • The list of images and their IDs and SHAs that are deployed.

  • The services and associated configuration, for example, the networking services you are using.

The Kubernetes connector is the agent deployed in your Kubernetes clusters to collect this information.

Getting started with Kubernetes connector for Snyk AppRisk

Prerequisites for Kubernetes connector for Snyk AppRisk

Before you can deploy the Kubernetes connector in your Kubernetes clusters, be sure you have the following:

  • A Snyk Organization to which the Kubernetes information collected will be sent to be stored. This could be a new Organization; it does not have to be the same one containing the Snyk Projects you wish to use with Snyk AppRisk, but it must be in the same Snyk Group.

  • A Snyk service account created specifically to be used with the Kubernetes connector. For instructions on creating a service account, see Service accounts. For the roles and permissions, Snyk recommends:

    • Creating a new specific role for this service account

    • Taking a least privilege approach, granting the new specific role the sole permission required to Publish Kubernetes Resources.

Step 1: Create a Snyk Organization

If you create a separate Organization for the Kubernetes connector, follow the steps in the Snyk documentation to create a Snyk Organization. The new Snyk Organization must be in the same Snyk Group as your other Snyk Organization.

If you are not creating a separate Snyk Organization, continue with the next step.

Step 2: Create a new role

Follow the steps in this documentation to create a new role.

This example illustrates creating a new role called Kubernetes connector

Step 3: Assign permissions to this role

Navigate to the newly created role and select edit; you will also be taken to this page immediately after creating the role.

Scroll to the bottom of the page, tick the Publish Kubernetes Resources permission, and save the changes by clicking the Update Role Permissions button.

Step 4: Create a service account and assign it to a role

Next, create a new service account for Kubernetes connector integration with Snyk AppRisk.

Snyk recommends creating this service account for the Snyk Organization used or created for the Kubernetes agent.

Navigate to that Snyk Organization -> Settings -> Service Account.

Create a new service account with your chosen name, and from the dropdown, select the role you created in the previous step.

After the service account is created, you will see the API token. Copy the API token and save it somewhere safe; you will need this to configure the agent in the Helm chart.

Step 5: Install the Kubernetes connector in your Kubernetes clusters

Snyk recommends using the Helm Chart to deploy the agent; the Helm Chart will create the associated permissions for the agent to run on your cluster. The user installing the Helm Chart needs sufficient permissions on the Kubernetes cluster to create new roles. Follow the instructions on the Kubernetes-scanner GitHub repo to use the Helm Chart to deploy the latest released version.

To ensure you have set up your Kubernetes connector properly, navigate to the Set up Insights tab on the Issues page and check the Kubernetes resources table to view the data that Insights has access to.

FAQ

What is the difference between the Kubernetes monitor (also called Snyk Controller or Snyk-Monitor), the Kubernetes connector for Snyk AppRisk and the Snyk Runtime Sensor?

  • The Kubernetes monitor extracts images from a Kubernetes cluster’s workloads and scans them for vulnerabilities. The Kubernetes monitor reports the Deployed risk factor.

  • The Kubernetes connector for Snyk AppRisk extracts workload configurations from a Kubernetes cluster. The Kubernetes connector reports the Public facing and Deployed risk factors.

  • The Snyk Runtime Sensor watches your deployments on a Kubernetes cluster and sends the collected data to Snyk. The Snyk Runtime Sensor reports the Deployed and Loaded package risk factors.

Risk factors are available only based on the integration option you implemented.

For prioritization to work, do I need all three integration options, or would one suffice?

You need only one of the installation options. Snyk recommends installing the Snyk Runtime Sensor that reports the Deployed and Loaded package risk factors.

If I’m a customer and already use the existing agent, do I also need to install the Kubernetes connector?

If you want to view both the Deployed and Public Facing risk factors, you must install the Kubernetes connector into your Kubernetes clusters.

If you have only the existing agent installed, Snyk can compute only the Deployed risk factor.

What workload data is the Kubernetes connector collecting?

The list of data Snyk is collecting is on the Kubernetes scanner GitHub repo.

What happens to my data if I delete the Kubernetes connector?

If you choose to delete the Kubernetes connector, your data and risk factors will remain available for 48 hours.

What happens to my data if the Kubernetes connector stops working?

If, for any reason, the Kubernetes connector stops working, your data and risk factors will remain available for 48 hours.

Last updated