This is an archived version of the documentation. View the latest version here.
In addition to the imperative style commands described elsewhere, Kubernetes supports declarative YAML or JSON configuration files. Often times config files are preferable to imperative commands, since they can be checked into version control and changes to the files can be code reviewed, producing a more robust, reliable and archival system.
$ cd kubernetes
$ kubectl create -f ./pod.yamlWhere pod.yaml contains something like:
apiVersion: v1
kind: Pod
metadata:
  name: nginx
  labels:
    app: nginx
spec:
  containers:
  - name: nginx
    image: nginx
    ports:
    - containerPort: 80You can see your cluster's pods:
$ kubectl get podsand delete the pod you just created:
$ kubectl delete pods nginxTo run replicated containers, you need a Replication Controller. A replication controller is responsible for ensuring that a specific number of pods exist in the cluster.
$ cd kubernetes
$ kubectl create -f ./replication.yamlWhere replication.yaml contains:
apiVersion: v1
kind: ReplicationController
metadata:
  name: nginx
spec:
  replicas: 3
  selector:
    app: nginx
  template:
    metadata:
      name: nginx
      labels:
        app: nginx
    spec:
      containers:
      - name: nginx
        image: nginx
        ports:
        - containerPort: 80To delete the replication controller (and the pods it created):
$ kubectl delete rc nginx