2015-07-12 04:04:52 +00:00
|
|
|
<!-- BEGIN MUNGE: UNVERSIONED_WARNING -->
|
|
|
|
|
|
|
|
<!-- BEGIN STRIP_FOR_RELEASE -->
|
|
|
|
|
2015-07-15 00:28:47 +00:00
|
|
|
![WARNING](http://kubernetes.io/img/warning.png)
|
|
|
|
![WARNING](http://kubernetes.io/img/warning.png)
|
|
|
|
![WARNING](http://kubernetes.io/img/warning.png)
|
2015-07-13 22:15:35 +00:00
|
|
|
|
|
|
|
<h1>PLEASE NOTE: This document applies to the HEAD of the source
|
2015-07-12 04:04:52 +00:00
|
|
|
tree only. If you are using a released version of Kubernetes, you almost
|
|
|
|
certainly want the docs that go with that version.</h1>
|
|
|
|
|
|
|
|
<strong>Documentation for specific releases can be found at
|
|
|
|
[releases.k8s.io](http://releases.k8s.io).</strong>
|
|
|
|
|
2015-07-15 00:28:47 +00:00
|
|
|
![WARNING](http://kubernetes.io/img/warning.png)
|
|
|
|
![WARNING](http://kubernetes.io/img/warning.png)
|
|
|
|
![WARNING](http://kubernetes.io/img/warning.png)
|
2015-07-13 22:15:35 +00:00
|
|
|
|
2015-07-12 04:04:52 +00:00
|
|
|
<!-- END STRIP_FOR_RELEASE -->
|
|
|
|
|
|
|
|
<!-- END MUNGE: UNVERSIONED_WARNING -->
|
2015-06-22 19:39:35 +00:00
|
|
|
Running Multi-Node Kubernetes Using Docker
|
|
|
|
------------------------------------------
|
2015-04-06 23:29:46 +00:00
|
|
|
|
2015-04-07 04:47:04 +00:00
|
|
|
_Note_:
|
|
|
|
These instructions are somewhat significantly more advanced than the [single node](docker.md) instructions. If you are
|
2015-04-06 23:29:46 +00:00
|
|
|
interested in just starting to explore Kubernetes, we recommend that you start there.
|
|
|
|
|
2015-07-14 03:58:33 +00:00
|
|
|
_Note_:
|
|
|
|
There is a [bug](https://github.com/docker/docker/issues/14106) in Docker 1.7.0 that prevents this from working correctly.
|
|
|
|
Please install Docker 1.6.2 or wait for Docker 1.7.1.
|
|
|
|
|
2015-06-22 19:39:35 +00:00
|
|
|
**Table of Contents**
|
2015-06-22 18:56:19 +00:00
|
|
|
|
2015-06-23 15:20:31 +00:00
|
|
|
- [Prerequisites](#prerequisites)
|
|
|
|
- [Overview](#overview)
|
|
|
|
- [Bootstrap Docker](#bootstrap-docker)
|
|
|
|
- [Master Node](#master-node)
|
|
|
|
- [Adding a worker node](#adding-a-worker-node)
|
|
|
|
- [Testing your cluster](#testing-your-cluster)
|
2015-04-06 23:29:46 +00:00
|
|
|
|
2015-06-22 19:39:35 +00:00
|
|
|
## Prerequisites
|
|
|
|
1. You need a machine with docker installed.
|
|
|
|
|
2015-04-07 04:47:04 +00:00
|
|
|
## Overview
|
|
|
|
This guide will set up a 2-node kubernetes cluster, consisting of a _master_ node which hosts the API server and orchestrates work
|
|
|
|
and a _worker_ node which receives work from the master. You can repeat the process of adding worker nodes an arbitrary number of
|
|
|
|
times to create larger clusters.
|
2015-04-06 23:29:46 +00:00
|
|
|
|
2015-04-07 04:47:04 +00:00
|
|
|
Here's a diagram of what the final result will look like:
|
|
|
|
![Kubernetes Single Node on Docker](k8s-docker.png)
|
2015-04-06 23:29:46 +00:00
|
|
|
|
2015-04-07 04:47:04 +00:00
|
|
|
### Bootstrap Docker
|
|
|
|
This guide also uses a pattern of running two instances of the Docker daemon
|
|
|
|
1) A _bootstrap_ Docker instance which is used to start system daemons like ```flanneld``` and ```etcd```
|
|
|
|
2) A _main_ Docker instance which is used for the Kubernetes infrastructure and user's scheduled containers
|
2015-04-06 23:29:46 +00:00
|
|
|
|
2015-04-07 04:47:04 +00:00
|
|
|
This pattern is necessary because the ```flannel``` daemon is responsible for setting up and managing the network that interconnects
|
|
|
|
all of the Docker containers created by Kubernetes. To achieve this, it must run outside of the _main_ Docker daemon. However,
|
|
|
|
it is still useful to use containers for deployment and management, so we create a simpler _bootstrap_ daemon to achieve this.
|
2015-04-06 23:29:46 +00:00
|
|
|
|
2015-04-07 04:47:04 +00:00
|
|
|
## Master Node
|
|
|
|
The first step in the process is to initialize the master node.
|
2015-04-06 23:29:46 +00:00
|
|
|
|
2015-04-07 04:47:04 +00:00
|
|
|
See [here](docker-multinode/master.md) for detailed instructions.
|
2015-04-06 23:29:46 +00:00
|
|
|
|
2015-04-07 04:47:04 +00:00
|
|
|
## Adding a worker node
|
2015-04-06 23:29:46 +00:00
|
|
|
|
2015-04-07 04:47:04 +00:00
|
|
|
Once your master is up and running you can add one or more workers on different machines.
|
2015-04-06 23:29:46 +00:00
|
|
|
|
2015-04-07 04:47:04 +00:00
|
|
|
See [here](docker-multinode/worker.md) for detailed instructions.
|
2015-04-06 23:29:46 +00:00
|
|
|
|
2015-04-07 04:47:04 +00:00
|
|
|
## Testing your cluster
|
2015-04-06 23:29:46 +00:00
|
|
|
|
2015-05-01 05:16:59 +00:00
|
|
|
Once your cluster has been created you can [test it out](docker-multinode/testing.md)
|
|
|
|
|
2015-07-10 01:02:10 +00:00
|
|
|
For more complete applications, please look in the [examples directory](../../examples/)
|
2015-05-14 22:12:45 +00:00
|
|
|
|
|
|
|
|
2015-07-14 00:13:09 +00:00
|
|
|
<!-- BEGIN MUNGE: GENERATED_ANALYTICS -->
|
2015-05-14 22:12:45 +00:00
|
|
|
[![Analytics](https://kubernetes-site.appspot.com/UA-36037335-10/GitHub/docs/getting-started-guides/docker-multinode.md?pixel)]()
|
2015-07-14 00:13:09 +00:00
|
|
|
<!-- END MUNGE: GENERATED_ANALYTICS -->
|