Service Catalog

    It provides a way to list, provision, and bind with external Managed Services from without needing detailed knowledge about how those services are created or managed.

    A service broker, as defined by the Open service broker API spec, is an endpoint for a set of managed services offered and maintained by a third-party, which could be a cloud provider such as AWS, GCP, or Azure. Some examples of managed services are Microsoft Azure Cloud Queue, Amazon Simple Queue Service, and Google Cloud Pub/Sub, but they can be any software offering that can be used by an application.

    Using Service Catalog, a can browse the list of managed services offered by a service broker, provision an instance of a managed service, and bind with it to make it available to an application in the Kubernetes cluster.

    An application developer wants to use message queuing as part of their application running in a Kubernetes cluster. However, they do not want to deal with the overhead of setting such a service up and administering it themselves. Fortunately, there is a cloud provider that offers message queuing as a managed service through its service broker.

    A cluster operator can setup Service Catalog and use it to communicate with the cloud provider’s service broker to provision an instance of the message queuing service and make it available to the application within the Kubernetes cluster. The application developer therefore does not need to be concerned with the implementation details or management of the message queue. The application can access the message queue as a service.

    Service Catalog uses the to communicate with service brokers, acting as an intermediary for the Kubernetes API Server to negotiate the initial provisioning and retrieve the credentials necessary for the application to use a managed service.

    It is implemented using a CRDs-based architecture.

    Service Catalog installs the API and provides the following Kubernetes resources:

    • ClusterServiceBroker: An in-cluster representation of a service broker, encapsulating its server connection details. These are created and managed by cluster operators who wish to use that broker server to make new types of managed services available within their cluster.
    • ClusterServiceClass: A managed service offered by a particular service broker. When a new ClusterServiceBroker resource is added to the cluster, the Service Catalog controller connects to the service broker to obtain a list of available managed services. It then creates a new ClusterServiceClass resource corresponding to each managed service.
    • ClusterServicePlan: A specific offering of a managed service. For example, a managed service may have different plans available, such as a free tier or paid tier, or it may have different configuration options, such as using SSD storage or having more resources. Similar to ClusterServiceClass, when a new ClusterServiceBroker is added to the cluster, Service Catalog creates a new ClusterServicePlan resource corresponding to each Service Plan available for each managed service.
    • ServiceInstance: A provisioned instance of a ClusterServiceClass. These are created by cluster operators to make a specific instance of a managed service available for use by one or more in-cluster applications. When a new ServiceInstance resource is created, the Service Catalog controller connects to the appropriate service broker and instruct it to provision the service instance.
    • ServiceBinding: Access credentials to a ServiceInstance. These are created by cluster operators who want their applications to make use of a ServiceInstance. Upon creation, the Service Catalog controller creates a Kubernetes Secret containing connection details and credentials for the Service Instance, which can be mounted into Pods.

    Authentication

    Service Catalog supports these methods of authentication:

    1. Listing the managed services and Service Plans available from a service broker.
    2. Provisioning a new instance of the managed service.
    3. Binding to the managed service, which returns the connection credentials.
    4. Mapping the connection credentials into the application.

    First, a cluster operator must create a ClusterServiceBroker resource within the servicecatalog.k8s.io group. This resource contains the URL and connection details necessary to access a service broker endpoint.

    This is an example of a ClusterServiceBroker resource:

    The following is a sequence diagram illustrating the steps involved in listing managed services and Plans available from a service broker:

    List Services

    1. Once the ClusterServiceBroker resource is added to Service Catalog, it triggers a call to the external service broker for a list of available services.

    2. The service broker returns a list of available managed services and a list of Service Plans, which are cached locally as ClusterServiceClass and ClusterServicePlan resources respectively.

    Provisioning a new instance

    This is an example of a ServiceInstance resource:

    1. apiVersion: servicecatalog.k8s.io/v1beta1
    2. kind: ServiceInstance
    3. metadata:
    4. name: cloud-queue-instance
    5. namespace: cloud-apps
    6. spec:
    7. # References one of the previously returned services
    8. clusterServiceClassExternalName: cloud-provider-service
    9. clusterServicePlanExternalName: service-plan-name
    10. #####
    11. # Additional parameters can be added here,
    12. # which may be used by the service broker.
    13. #####

    The following sequence diagram illustrates the steps involved in provisioning a new instance of a managed service:

    1. When the ServiceInstance resource is created, Service Catalog initiates a call to the external service broker to provision an instance of the service.
    2. The service broker creates a new instance of the managed service and returns an HTTP response.
    3. A cluster operator can then check the status of the instance to see if it is ready.

    After a new instance has been provisioned, a cluster operator must bind to the managed service to get the connection credentials and service account details necessary for the application to use the service. This is done by creating a ServiceBinding resource.

    The following is an example of a ServiceBinding resource:

    The following sequence diagram illustrates the steps involved in binding to a managed service instance:

    Bind to a managed service

    1. After the ServiceBinding is created, Service Catalog makes a call to the external service broker requesting the information necessary to bind with the service instance.
    2. The service broker returns the information necessary to connect and access the managed service instance. This is provider and service-specific so the information returned may differ between Service Providers and their managed services.

    Mapping the connection credentials

    After binding, the final step involves mapping the connection credentials and service-specific information into the application. These pieces of information are stored in secrets that the application in the cluster can access and use to connect directly with the managed service.

    Pod configuration File

    One method to perform this mapping is to use a declarative Pod configuration.

    1. ...
    2. spec:
    3. volumes:
    4. - name: provider-cloud-key
    5. secret:
    6. secretName: sa-key
    7. containers:
    8. ...
    9. volumeMounts:
    10. - name: provider-cloud-key
    11. mountPath: /var/secrets/provider
    12. env:
    13. - name: PROVIDER_APPLICATION_CREDENTIALS
    14. value: "/var/secrets/provider/key.json"

    The following example describes how to map secret values into application environment variables. In this example, the messaging queue topic name is mapped from a secret named provider-queue-credentials with a key named topic to the environment variable TOPIC.

    1. ...
    2. env:
    3. - name: "TOPIC"
    4. valueFrom:
    5. secretKeyRef:
    6. name: provider-queue-credentials