This repository has been archived by the owner on Oct 16, 2018. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 21
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
* Tutorials init documentation file added. * Setup init documentation file added.
- Loading branch information
1 parent
3e13f93
commit df809c5
Showing
57 changed files
with
7,660 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,10 @@ | ||
--- | ||
no_issue: true | ||
title: Setup | ||
main_menu: true | ||
weight: 30 | ||
--- | ||
|
||
This section provides instructions for installing Kubernetes and setting | ||
up a Kubernetes cluster. For an overview of the different options, see | ||
[Picking the Right Solution](/docs/setup/pick-right-solution/). |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,21 @@ | ||
--- | ||
title: Building from Source | ||
--- | ||
|
||
You can either build a release from source or download a pre-built release. If you do not plan on developing Kubernetes itself, we suggest using a pre-built version of the current release, which can be found in the [Release Notes](/docs/imported/release/notes/). | ||
|
||
The Kubernetes source code can be downloaded from the [kubernetes/kubernetes](https://github.com/kubernetes/kubernetes) repo. | ||
|
||
## Building from source | ||
|
||
If you are simply building a release from source there is no need to set up a full golang environment as all building happens in a Docker container. | ||
|
||
Building a release is simple. | ||
|
||
```shell | ||
git clone https://github.com/kubernetes/kubernetes.git | ||
cd kubernetes | ||
make release | ||
``` | ||
|
||
For more details on the release process see the kubernetes/kubernetes [`build`](http://releases.k8s.io/{{< param "githubbranch" >}}/build/) directory. |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,127 @@ | ||
--- | ||
title: Building Large Clusters | ||
--- | ||
|
||
## Support | ||
|
||
At {{< param "version" >}}, Kubernetes supports clusters with up to 5000 nodes. More specifically, we support configurations that meet *all* of the following criteria: | ||
|
||
* No more than 5000 nodes | ||
* No more than 150000 total pods | ||
* No more than 300000 total containers | ||
* No more than 100 pods per node | ||
|
||
<br> | ||
|
||
{{< toc >}} | ||
|
||
## Setup | ||
|
||
A cluster is a set of nodes (physical or virtual machines) running Kubernetes agents, managed by a "master" (the cluster-level control plane). | ||
|
||
Normally the number of nodes in a cluster is controlled by the value `NUM_NODES` in the platform-specific `config-default.sh` file (for example, see [GCE's `config-default.sh`](http://releases.k8s.io/{{< param "githubbranch" >}}/cluster/gce/config-default.sh)). | ||
|
||
Simply changing that value to something very large, however, may cause the setup script to fail for many cloud providers. A GCE deployment, for example, will run in to quota issues and fail to bring the cluster up. | ||
|
||
When setting up a large Kubernetes cluster, the following issues must be considered. | ||
|
||
### Quota Issues | ||
|
||
To avoid running into cloud provider quota issues, when creating a cluster with many nodes, consider: | ||
|
||
* Increase the quota for things like CPU, IPs, etc. | ||
* In [GCE, for example,](https://cloud.google.com/compute/docs/resource-quotas) you'll want to increase the quota for: | ||
* CPUs | ||
* VM instances | ||
* Total persistent disk reserved | ||
* In-use IP addresses | ||
* Firewall Rules | ||
* Forwarding rules | ||
* Routes | ||
* Target pools | ||
* Gating the setup script so that it brings up new node VMs in smaller batches with waits in between, because some cloud providers rate limit the creation of VMs. | ||
|
||
### Etcd storage | ||
|
||
To improve performance of large clusters, we store events in a separate dedicated etcd instance. | ||
|
||
When creating a cluster, existing salt scripts: | ||
|
||
* start and configure additional etcd instance | ||
* configure api-server to use it for storing events | ||
|
||
### Size of master and master components | ||
|
||
On GCE/Google Kubernetes Engine, and AWS, `kube-up` automatically configures the proper VM size for your master depending on the number of nodes | ||
in your cluster. On other providers, you will need to configure it manually. For reference, the sizes we use on GCE are | ||
|
||
* 1-5 nodes: n1-standard-1 | ||
* 6-10 nodes: n1-standard-2 | ||
* 11-100 nodes: n1-standard-4 | ||
* 101-250 nodes: n1-standard-8 | ||
* 251-500 nodes: n1-standard-16 | ||
* more than 500 nodes: n1-standard-32 | ||
|
||
And the sizes we use on AWS are | ||
|
||
* 1-5 nodes: m3.medium | ||
* 6-10 nodes: m3.large | ||
* 11-100 nodes: m3.xlarge | ||
* 101-250 nodes: m3.2xlarge | ||
* 251-500 nodes: c4.4xlarge | ||
* more than 500 nodes: c4.8xlarge | ||
|
||
{{< note >}} | ||
On Google Kubernetes Engine, the size of the master node adjusts automatically based on the size of your cluster. For more information, see [this blog post](https://cloudplatform.googleblog.com/2017/11/Cutting-Cluster-Management-Fees-on-Google-Kubernetes-Engine.html). | ||
|
||
On AWS, master node sizes are currently set at cluster startup time and do not change, even if you later scale your cluster up or down by manually removing or adding nodes or using a cluster autoscaler. | ||
{{< /note >}} | ||
|
||
### Addon Resources | ||
|
||
To prevent memory leaks or other resource issues in [cluster addons](https://releases.k8s.io/{{< param "githubbranch" >}}/cluster/addons) from consuming all the resources available on a node, Kubernetes sets resource limits on addon containers to limit the CPU and Memory resources they can consume (See PR [#10653](http://pr.k8s.io/10653/files) and [#10778](http://pr.k8s.io/10778/files)). | ||
|
||
For example: | ||
|
||
```yaml | ||
containers: | ||
- name: fluentd-cloud-logging | ||
image: k8s.gcr.io/fluentd-gcp:1.16 | ||
resources: | ||
limits: | ||
cpu: 100m | ||
memory: 200Mi | ||
``` | ||
Except for Heapster, these limits are static and are based on data we collected from addons running on 4-node clusters (see [#10335](http://issue.k8s.io/10335#issuecomment-117861225)). The addons consume a lot more resources when running on large deployment clusters (see [#5880](http://issue.k8s.io/5880#issuecomment-113984085)). So, if a large cluster is deployed without adjusting these values, the addons may continuously get killed because they keep hitting the limits. | ||
To avoid running into cluster addon resource issues, when creating a cluster with many nodes, consider the following: | ||
* Scale memory and CPU limits for each of the following addons, if used, as you scale up the size of cluster (there is one replica of each handling the entire cluster so memory and CPU usage tends to grow proportionally with size/load on cluster): | ||
* [InfluxDB and Grafana](http://releases.k8s.io/{{< param "githubbranch" >}}/cluster/addons/cluster-monitoring/influxdb/influxdb-grafana-controller.yaml) | ||
* [kubedns, dnsmasq, and sidecar](http://releases.k8s.io/{{< param "githubbranch" >}}/cluster/addons/dns/kube-dns/kube-dns.yaml.in) | ||
* [Kibana](http://releases.k8s.io/{{< param "githubbranch" >}}/cluster/addons/fluentd-elasticsearch/kibana-deployment.yaml) | ||
* Scale number of replicas for the following addons, if used, along with the size of cluster (there are multiple replicas of each so increasing replicas should help handle increased load, but, since load per replica also increases slightly, also consider increasing CPU/memory limits): | ||
* [elasticsearch](http://releases.k8s.io/{{< param "githubbranch" >}}/cluster/addons/fluentd-elasticsearch/es-statefulset.yaml) | ||
* Increase memory and CPU limits slightly for each of the following addons, if used, along with the size of cluster (there is one replica per node but CPU/memory usage increases slightly along with cluster load/size as well): | ||
* [FluentD with ElasticSearch Plugin](http://releases.k8s.io/{{< param "githubbranch" >}}/cluster/addons/fluentd-elasticsearch/fluentd-es-ds.yaml) | ||
* [FluentD with GCP Plugin](http://releases.k8s.io/{{< param "githubbranch" >}}/cluster/addons/fluentd-gcp/fluentd-gcp-ds.yaml) | ||
Heapster's resource limits are set dynamically based on the initial size of your cluster (see [#16185](http://issue.k8s.io/16185) | ||
and [#22940](http://issue.k8s.io/22940)). If you find that Heapster is running | ||
out of resources, you should adjust the formulas that compute heapster memory request (see those PRs for details). | ||
For directions on how to detect if addon containers are hitting resource limits, see the [Troubleshooting section of Compute Resources](/docs/concepts/configuration/manage-compute-resources-container/#troubleshooting). | ||
In the [future](http://issue.k8s.io/13048), we anticipate to set all cluster addon resource limits based on cluster size, and to dynamically adjust them if you grow or shrink your cluster. | ||
We welcome PRs that implement those features. | ||
### Allowing minor node failure at startup | ||
For various reasons (see [#18969](https://github.com/kubernetes/kubernetes/issues/18969) for more details) running | ||
`kube-up.sh` with a very large `NUM_NODES` may fail due to a very small number of nodes not coming up properly. | ||
Currently you have two choices: restart the cluster (`kube-down.sh` and then `kube-up.sh` again), or before | ||
running `kube-up.sh` set the environment variable `ALLOWED_NOTREADY_NODES` to whatever value you feel comfortable | ||
with. This will allow `kube-up.sh` to succeed with fewer than `NUM_NODES` coming up. Depending on the | ||
reason for the failure, those additional nodes may join later or the cluster may remain at a size of | ||
`NUM_NODES - ALLOWED_NOTREADY_NODES`. |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,3 @@ | ||
--- | ||
title: Custom Cloud Solutions | ||
--- |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,91 @@ | ||
--- | ||
title: CoreOS on AWS or GCE | ||
--- | ||
|
||
{{< toc >}} | ||
|
||
There are multiple guides on running Kubernetes with [CoreOS](https://coreos.com/kubernetes/docs/latest/): | ||
|
||
### Official CoreOS Guides | ||
|
||
These guides are maintained by CoreOS and deploy Kubernetes the "CoreOS Way" with full TLS, the DNS add-on, and more. These guides pass Kubernetes conformance testing and we encourage you to [test this yourself](https://coreos.com/kubernetes/docs/latest/conformance-tests.html). | ||
|
||
[**AWS Multi-Node**](https://coreos.com/kubernetes/docs/latest/kubernetes-on-aws.html) | ||
|
||
Guide and CLI tool for setting up a multi-node cluster on AWS. CloudFormation is used to set up a master and multiple workers in auto-scaling groups. | ||
|
||
<hr/> | ||
|
||
[**Bare Metal Multi-Node**](https://coreos.com/kubernetes/docs/latest/kubernetes-on-baremetal.html#automated-provisioning) | ||
|
||
Guide and HTTP/API service for PXE booting and provisioning a multi-node cluster on bare metal. [Ignition](https://coreos.com/ignition/docs/latest/) is used to provision a master and multiple workers on the first boot from disk. | ||
|
||
[**Vagrant Multi-Node**](https://coreos.com/kubernetes/docs/latest/kubernetes-on-vagrant.html) | ||
|
||
Guide to setting up a multi-node cluster on Vagrant. The deployer can independently configure the number of etcd nodes, master nodes, and worker nodes to bring up a fully HA control plane. | ||
|
||
<hr/> | ||
|
||
[**Vagrant Single-Node**](https://coreos.com/kubernetes/docs/latest/kubernetes-on-vagrant-single.html) | ||
|
||
The quickest way to set up a Kubernetes development environment locally. As easy as `git clone`, `vagrant up` and configuring `kubectl`. | ||
|
||
<hr/> | ||
|
||
[**Full Step by Step Guide**](https://coreos.com/kubernetes/docs/latest/getting-started.html) | ||
|
||
A generic guide to setting up an HA cluster on any cloud or bare metal, with full TLS. Repeat the master or worker steps to configure more machines of that role. | ||
|
||
### Community Guides | ||
|
||
These guides are maintained by community members, cover specific platforms and use cases, and experiment with different ways of configuring Kubernetes on CoreOS. | ||
|
||
[**Easy Multi-node Cluster on Google Compute Engine**](https://github.com/rimusz/coreos-multi-node-k8s-gce/blob/master/README.md) | ||
|
||
Scripted installation of a single master, multi-worker cluster on GCE. Kubernetes components are managed by [fleet](https://github.com/coreos/fleet). | ||
|
||
<hr/> | ||
|
||
[**Multi-node cluster using cloud-config and Weave on Vagrant**](https://github.com/errordeveloper/weave-demos/blob/master/poseidon/README.md) | ||
|
||
Configure a Vagrant-based cluster of 3 machines with networking provided by Weave. | ||
|
||
<hr/> | ||
|
||
[**Multi-node cluster using cloud-config and Vagrant**](https://github.com/pires/kubernetes-vagrant-coreos-cluster/blob/master/README.md) | ||
|
||
Configure a single master, multi-worker cluster locally, running on your choice of hypervisor: VirtualBox, Parallels, or VMware | ||
|
||
<hr/> | ||
|
||
[**Single-node cluster using a small macOS App**](https://github.com/rimusz/kube-solo-osx/blob/master/README.md) | ||
|
||
Guide to running a solo cluster (master + worker) controlled by an macOS menubar application. Uses xhyve + CoreOS under the hood. | ||
|
||
<hr/> | ||
|
||
[**Multi-node cluster with Vagrant and fleet units using a small macOS App**](https://github.com/rimusz/coreos-osx-gui-kubernetes-cluster/blob/master/README.md) | ||
|
||
Guide to running a single master, multi-worker cluster controlled by an macOS menubar application. Uses Vagrant under the hood. | ||
|
||
<hr/> | ||
|
||
[**Multi-node cluster using cloud-config, CoreOS and VMware ESXi**](https://github.com/xavierbaude/VMware-coreos-multi-nodes-Kubernetes) | ||
|
||
Configure a single master, single worker cluster on VMware ESXi. | ||
|
||
<hr/> | ||
|
||
[**Single/Multi-node cluster using cloud-config, CoreOS and Foreman**](https://github.com/johscheuer/theforeman-coreos-kubernetes) | ||
|
||
Configure a standalone Kubernetes or a Kubernetes cluster with [Foreman](https://theforeman.org). | ||
|
||
## Support Level | ||
|
||
|
||
IaaS Provider | Config. Mgmt | OS | Networking | Docs | Conforms | Support Level | ||
-------------------- | ------------ | ------ | ---------- | --------------------------------------------- | ---------| ---------------------------- | ||
GCE | CoreOS | CoreOS | flannel | [docs](/docs/getting-started-guides/coreos) | | Community ([@pires](https://github.com/pires)) | ||
Vagrant | CoreOS | CoreOS | flannel | [docs](/docs/getting-started-guides/coreos) | | Community ([@pires](https://github.com/pires), [@AntonioMeireles](https://github.com/AntonioMeireles)) | ||
|
||
For support level information on all solutions, see the [Table of solutions](/docs/getting-started-guides/#table-of-solutions) chart. |
Oops, something went wrong.