This page explains how to create and manage stateless workloads within a Google Distributed Cloud (GDC) air-gapped Kubernetes cluster. Stateless workloads let you scale your application deployment based on workload demands, all without having to manage persistent storage in a Kubernetes cluster to store data or application state. This page helps you get started so you can efficiently optimize and adjust your application's availability.
This page is for developers within the application operator group, who are responsible for creating application workloads for their organization. For more information, see Audiences for GDC air-gapped documentation.
Before you begin
To run commands against a Kubernetes cluster, make sure you have the following resources:
- Locate the Kubernetes cluster name, or ask your Platform Administrator what the cluster name is. 
- Sign in and generate the kubeconfig file for the Kubernetes cluster if you don't have one. 
- Use the kubeconfig path of the Kubernetes cluster to replace - KUBERNETES_CLUSTER_KUBECONFIGin these instructions.
To get the required permissions to create stateless workloads, ask your
Organization IAM Admin to grant you the Namespace Admin role (namespace-admin)
in your project namespace.
Create a deployment
You create a deployment by writing a Deployment manifest and running
kubectl apply to create the resource. This method also retains updates made to
live resources without merging the changes back into the manifest files.
To create a Deployment from its manifest file, run:
kubectl --kubeconfig KUBERNETES_CLUSTER_KUBECONFIG -n NAMESPACE \
    apply -f - <<EOF
apiVersion: apps/v1
kind: Deployment
metadata:
  name: DEPLOYMENT_NAME
spec:
  replicas: NUMBER_OF_REPLICAS
  selector:
    matchLabels:
      run: APP_NAME
  template:
    metadata:
      labels: # The labels given to each pod in the deployment, which are used
              # to manage all pods in the deployment.
        run: APP_NAME
    spec: # The pod specification, which defines how each pod runs in the deployment.
      containers:
      - name: CONTAINER_NAME
        image: CONTAINER_IMAGE
EOF
Replace the following:
- KUBERNETES_CLUSTER_KUBECONFIG: the kubeconfig file for the Kubernetes cluster to which you're deploying container workloads.
- NAMESPACE: the project namespace in which to deploy the container workloads.
- DEPLOYMENT_NAME: the kubeconfig file for the cluster to which you're deploying container workloads.
- APP_NAME: the name of the application to run within the deployment.
- NUMBER_OF_REPLICAS: the number of replicated- Podobjects that the deployment manages.
- CONTAINER_NAME: the name of the container.
- CONTAINER_IMAGE: the name of the container image. You must include the container registry path and version of the image, such as- REGISTRY_PATH/hello-app:1.0. For more information about setting the container registry path, see the Managed Harbor Service overview.
For example:
apiVersion: apps/v1
kind: Deployment
metadata:
  name: my-app
spec:
  replicas: 3
  selector:
    matchLabels:
      run: my-app
  template:
    metadata:
      labels:
        run: my-app
    spec:
      containers:
      - name: hello-app
        image: REGISTRY_PATH/hello-app:1.0
If you're deploying GPU workloads to your containers, see Manage GPU container workloads for more information.