--- --- * TOC {:toc} The user guide is intended for anyone who wants to run programs and services on an existing Kubernetes cluster. Setup and administration of a Kubernetes cluster is described in the [Cluster Admin Guide](/docs/admin/). The [Developer Guide](/docs/devel/) is for anyone wanting to either write code which directly accesses the Kubernetes API, or to contribute directly to the Kubernetes project. Please ensure you have completed the [prerequisites for running examples from the user guide](/docs/user-guide/prereqs). ## Quick walkthrough 1. [Kubernetes 101](/docs/user-guide/walkthrough/) 1. [Kubernetes 201](/docs/user-guide/walkthrough/k8s201) ## Thorough walkthrough If you don't have much familiarity with Kubernetes, we recommend you read the following sections in order: 1. [Quick start: launch and expose an application](/docs/user-guide/quick-start) 1. [Configuring and launching containers: configuring common container parameters](/docs/user-guide/configuring-containers) 1. [Deploying continuously running applications](/docs/user-guide/deploying-applications) 1. [Connecting applications: exposing applications to clients and users](/docs/user-guide/connecting-applications) 1. [Working with containers in production](/docs/user-guide/production-pods) 1. [Managing deployments](/docs/user-guide/managing-deployments) 1. [Application introspection and debugging](/docs/user-guide/introspection-and-debugging) 1. [Using the Kubernetes web user interface](/docs/user-guide/ui) 1. [Logging](/docs/user-guide/logging) 1. [Monitoring](/docs/user-guide/monitoring) 1. [Getting into containers via `exec`](/docs/user-guide/getting-into-containers) 1. [Connecting to containers via proxies](/docs/user-guide/connecting-to-applications-proxy) 1. [Connecting to containers via port forwarding](/docs/user-guide/connecting-to-applications-port-forward) ## Concept guide [**Overview**](/docs/user-guide/overview) : A brief overview of Kubernetes concepts. [**Cluster**](/docs/admin/) : A cluster is a set of physical or virtual machines and other infrastructure resources used by Kubernetes to run your applications. [**Node**](/docs/admin/node) : A node is a physical or virtual machine running Kubernetes, onto which pods can be scheduled. [**Pod**](/docs/user-guide/pods) : A pod is a co-located group of containers and volumes. [**Label**](/docs/user-guide/labels) : A label is a key/value pair that is attached to a resource, such as a pod, to convey a user-defined identifying attribute. Labels can be used to organize and to select subsets of resources. [**Selector**](/docs/user-guide/labels/#label-selectors) : A selector is an expression that matches labels in order to identify related resources, such as which pods are targeted by a load-balanced service. [**Replication Controller**](/docs/user-guide/replication-controller) : A replication controller ensures that a specified number of pod replicas are running at any one time. It both allows for easy scaling of replicated systems and handles re-creation of a pod when the machine it is on reboots or otherwise fails. [**Service**](/docs/user-guide/services) : A service defines a set of pods and a means by which to access them, such as single stable IP address and corresponding DNS name. [**Volume**](/docs/user-guide/volumes) : A volume is a directory, possibly with some data in it, which is accessible to a Container as part of its filesystem. Kubernetes volumes build upon [Docker Volumes](https://docs.docker.com/userguide/dockervolumes/), adding provisioning of the volume directory and/or device. [**Secret**](/docs/user-guide/secrets) : A secret stores sensitive data, such as authentication tokens, which can be made available to containers upon request. [**Name**](/docs/user-guide/identifiers) : A user- or client-provided name for a resource. [**Namespace**](/docs/user-guide/namespaces) : A namespace is like a prefix to the name of a resource. Namespaces help different projects, teams, or customers to share a cluster, such as by preventing name collisions between unrelated teams. [**Annotation**](/docs/user-guide/annotations) : A key/value pair that can hold larger (compared to a label), and possibly not human-readable, data, intended to store non-identifying auxiliary data, especially data manipulated by tools and system extensions. Efficient filtering by annotation values is not supported. ## Further reading * API resources * [Working with resources](/docs/user-guide/working-with-resources) * Pods and containers * [Pod lifecycle and restart policies](/docs/user-guide/pod-states) * [Lifecycle hooks](/docs/user-guide/container-environment) * [Compute resources, such as cpu and memory](/docs/user-guide/compute-resources) * [Specifying commands and requesting capabilities](/docs/user-guide/containers) * [Downward API: accessing system configuration from a pod](/docs/user-guide/downward-api) * [Images and registries](/docs/user-guide/images) * [Migrating from docker-cli to kubectl](/docs/user-guide/docker-cli-to-kubectl) * [Tips and tricks when working with config](/docs/user-guide/config-best-practices) * [Assign pods to selected nodes](/docs/user-guide/node-selection/) * [Perform a rolling update on a running group of pods](/docs/user-guide/update-demo/)