Split Kubernetes install from Mulinode guide
Splits the OSH AIO gate script-based installation guide out of the main multinode guide, and adds context to the multinode guide around using a prod-grade k8s installer or the gate scripts as appropriate. Change-Id: I9fa9d498e49efc1867c8f347fd3c814263c23717 Story: 2002526 Task: 22200
This commit is contained in:
parent
2840259fb8
commit
b1fccbafb1
@ -9,4 +9,5 @@ Contents:
|
|||||||
common-requirements
|
common-requirements
|
||||||
developer/index
|
developer/index
|
||||||
multinode
|
multinode
|
||||||
|
kubernetes-gate
|
||||||
ext-dns-fqdn
|
ext-dns-fqdn
|
||||||
|
144
doc/source/install/kubernetes-gate.rst
Normal file
144
doc/source/install/kubernetes-gate.rst
Normal file
@ -0,0 +1,144 @@
|
|||||||
|
=====================
|
||||||
|
Gate-Based Kubernetes
|
||||||
|
=====================
|
||||||
|
|
||||||
|
Overview
|
||||||
|
========
|
||||||
|
|
||||||
|
You can use any Kubernetes deployment tool to bring up a working Kubernetes
|
||||||
|
cluster for use with OpenStack-Helm. This guide describes how to simply stand
|
||||||
|
up a multinode Kubernetes cluster via the OpenStack-Helm gate scripts,
|
||||||
|
which use KubeADM and Ansible. Although this cluster won't be
|
||||||
|
production-grade, it will serve as a quick starting point in a lab or
|
||||||
|
proof-of-concept environment.
|
||||||
|
|
||||||
|
OpenStack-Helm-Infra KubeADM deployment
|
||||||
|
=======================================
|
||||||
|
|
||||||
|
On the worker nodes:
|
||||||
|
|
||||||
|
.. code-block:: shell
|
||||||
|
|
||||||
|
#!/bin/bash
|
||||||
|
set -xe
|
||||||
|
sudo apt-get update
|
||||||
|
sudo apt-get install --no-install-recommends -y git
|
||||||
|
|
||||||
|
|
||||||
|
SSH-Key preparation
|
||||||
|
-------------------
|
||||||
|
|
||||||
|
Create an ssh-key on the master node, and add the public key to each node that
|
||||||
|
you intend to join the cluster.
|
||||||
|
|
||||||
|
.. note::
|
||||||
|
1. To generate the key you can use ``ssh-keygen -t rsa``
|
||||||
|
2. To copy the ssh key to each node, this can be accomplished with
|
||||||
|
the ``ssh-copy-id`` command, for example: *ssh-copy-id
|
||||||
|
ubuntu@192.168.122.178*
|
||||||
|
3. Copy the key: ``sudo cp ~/.ssh/id_rsa /etc/openstack-helm/deploy-key.pem``
|
||||||
|
4. Set correct ownership: ``sudo chown ubuntu
|
||||||
|
/etc/openstack-helm/deploy-key.pem``
|
||||||
|
|
||||||
|
Test this by ssh'ing to a node and then executing a command with
|
||||||
|
'sudo'. Neither operation should require a password.
|
||||||
|
|
||||||
|
Clone the OpenStack-Helm Repos
|
||||||
|
------------------------------
|
||||||
|
|
||||||
|
Once the host has been configured the repos containing the OpenStack-Helm charts
|
||||||
|
should be cloned onto each node in the cluster:
|
||||||
|
|
||||||
|
.. code-block:: shell
|
||||||
|
|
||||||
|
#!/bin/bash
|
||||||
|
set -xe
|
||||||
|
|
||||||
|
sudo chown -R ubuntu: /opt
|
||||||
|
git clone https://git.openstack.org/openstack/openstack-helm-infra.git /opt/openstack-helm-infra
|
||||||
|
git clone https://git.openstack.org/openstack/openstack-helm.git /opt/openstack-helm
|
||||||
|
|
||||||
|
|
||||||
|
Create an inventory file
|
||||||
|
------------------------
|
||||||
|
|
||||||
|
On the master node create an inventory file for the cluster:
|
||||||
|
|
||||||
|
.. note::
|
||||||
|
node_one, node_two and node_three below are all worker nodes,
|
||||||
|
children of the master node that the commands below are executed on.
|
||||||
|
|
||||||
|
.. code-block:: shell
|
||||||
|
|
||||||
|
#!/bin/bash
|
||||||
|
set -xe
|
||||||
|
cat > /opt/openstack-helm-infra/tools/gate/devel/multinode-inventory.yaml <<EOF
|
||||||
|
all:
|
||||||
|
children:
|
||||||
|
primary:
|
||||||
|
hosts:
|
||||||
|
node_one:
|
||||||
|
ansible_port: 22
|
||||||
|
ansible_host: $node_one_ip
|
||||||
|
ansible_user: ubuntu
|
||||||
|
ansible_ssh_private_key_file: /etc/openstack-helm/deploy-key.pem
|
||||||
|
ansible_ssh_extra_args: -o StrictHostKeyChecking=no
|
||||||
|
nodes:
|
||||||
|
hosts:
|
||||||
|
node_two:
|
||||||
|
ansible_port: 22
|
||||||
|
ansible_host: $node_two_ip
|
||||||
|
ansible_user: ubuntu
|
||||||
|
ansible_ssh_private_key_file: /etc/openstack-helm/deploy-key.pem
|
||||||
|
ansible_ssh_extra_args: -o StrictHostKeyChecking=no
|
||||||
|
node_three:
|
||||||
|
ansible_port: 22
|
||||||
|
ansible_host: $node_three_ip
|
||||||
|
ansible_user: ubuntu
|
||||||
|
ansible_ssh_private_key_file: /etc/openstack-helm/deploy-key.pem
|
||||||
|
ansible_ssh_extra_args: -o StrictHostKeyChecking=no
|
||||||
|
EOF
|
||||||
|
|
||||||
|
Create an environment file
|
||||||
|
--------------------------
|
||||||
|
|
||||||
|
On the master node create an environment file for the cluster:
|
||||||
|
|
||||||
|
.. code-block:: shell
|
||||||
|
|
||||||
|
#!/bin/bash
|
||||||
|
set -xe
|
||||||
|
function net_default_iface {
|
||||||
|
sudo ip -4 route list 0/0 | awk '{ print $5; exit }'
|
||||||
|
}
|
||||||
|
cat > /opt/openstack-helm-infra/tools/gate/devel/multinode-vars.yaml <<EOF
|
||||||
|
kubernetes_network_default_device: $(net_default_iface)
|
||||||
|
EOF
|
||||||
|
|
||||||
|
Additional configuration variables can be found `here
|
||||||
|
<https://github.com/openstack/openstack-helm-infra/blob/master/roles/deploy-kubeadm-aio-common/defaults/main.yml>`_.
|
||||||
|
In particular, ``kubernetes_cluster_pod_subnet`` can be used to override the
|
||||||
|
pod subnet set up by Calico (the default container SDN), if you have a
|
||||||
|
preexisting network that conflicts with the default pod subnet of 192.168.0.0/16.
|
||||||
|
|
||||||
|
.. note::
|
||||||
|
This installation, by default will use Google DNS servers, 8.8.8.8 or 8.8.4.4
|
||||||
|
and updates resolv.conf. These DNS nameserver entries can be changed by
|
||||||
|
updating file ``/opt/openstack-helm-infra/tools/images/kubeadm-aio/assets/opt/playbooks/vars.yaml``
|
||||||
|
under section ``external_dns_nameservers``. This change must be done on each
|
||||||
|
node in your cluster.
|
||||||
|
|
||||||
|
|
||||||
|
Run the playbooks
|
||||||
|
-----------------
|
||||||
|
|
||||||
|
On the master node run the playbooks:
|
||||||
|
|
||||||
|
.. code-block:: shell
|
||||||
|
|
||||||
|
#!/bin/bash
|
||||||
|
set -xe
|
||||||
|
cd /opt/openstack-helm-infra
|
||||||
|
make dev-deploy setup-host multinode
|
||||||
|
make dev-deploy k8s multinode
|
||||||
|
|
@ -39,145 +39,28 @@ The installation procedures below, will take an administrator from a new
|
|||||||
|
|
||||||
.. warning:: Until the Ubuntu kernel shipped with 16.04 supports CephFS
|
.. warning:: Until the Ubuntu kernel shipped with 16.04 supports CephFS
|
||||||
subvolume mounts by default the `HWE Kernel
|
subvolume mounts by default the `HWE Kernel
|
||||||
<../troubleshooting/ubuntu-hwe-kernel.rst>`__ is required to use CephFS.
|
<../troubleshooting/ubuntu-hwe-kernel.html>`__ is required to use CephFS.
|
||||||
|
|
||||||
Kubernetes Preparation
|
Kubernetes Preparation
|
||||||
======================
|
======================
|
||||||
|
|
||||||
You can use any Kubernetes deployment tool to bring up a working Kubernetes
|
You can use any Kubernetes deployment tool to bring up a working Kubernetes
|
||||||
cluster for use with OpenStack-Helm. For simplicity however we will describe
|
cluster for use with OpenStack-Helm. For production deployments,
|
||||||
deployment using the OpenStack-Helm gate scripts to bring up a reference cluster
|
please choose (and tune appropriately) a highly-resilient Kubernetes
|
||||||
using KubeADM and Ansible.
|
distribution, e.g.:
|
||||||
|
|
||||||
OpenStack-Helm Infra KubeADM deployment
|
- `Airship <https://airshipit.org/>`_, a declarative open cloud
|
||||||
---------------------------------------
|
infrastructure platform
|
||||||
|
- `KubeADM <https://kubernetes.io/docs/setup/independent/high-availability/>`_,
|
||||||
|
the foundation of a number of Kubernetes installation solutions
|
||||||
|
|
||||||
On the worker nodes:
|
For a lab or proof-of-concept environment, the OpenStack-Helm gate scripts
|
||||||
|
can be used to quickly deploy a multinode Kubernetes cluster using KubeADM
|
||||||
|
and Ansible. Please refer to the deployment guide
|
||||||
|
`here <./kubernetes-gate.html>`__.
|
||||||
|
|
||||||
.. code-block:: shell
|
Managing and configuring a Kubernetes cluster is beyond the scope
|
||||||
|
of OpenStack-Helm and this guide.
|
||||||
#!/bin/bash
|
|
||||||
set -xe
|
|
||||||
sudo apt-get update
|
|
||||||
sudo apt-get install --no-install-recommends -y git
|
|
||||||
|
|
||||||
|
|
||||||
SSH-Key preparation
|
|
||||||
-------------------
|
|
||||||
|
|
||||||
Create an ssh-key on the master node, and add the public key to each node that
|
|
||||||
you intend to join the cluster.
|
|
||||||
|
|
||||||
.. note::
|
|
||||||
1. To generate the key you can use ``ssh-keygen -t rsa``
|
|
||||||
2. To copy the ssh key to each node, this can be accomplished with
|
|
||||||
the ``ssh-copy-id`` command, for example: *ssh-copy-id
|
|
||||||
ubuntu@192.168.122.178*
|
|
||||||
3. Copy the key: ``sudo cp ~/.ssh/id_rsa /etc/openstack-helm/deploy-key.pem``
|
|
||||||
4. Set correct ownership: ``sudo chown ubuntu
|
|
||||||
/etc/openstack-helm/deploy-key.pem``
|
|
||||||
|
|
||||||
Test this by ssh'ing to a node and then executing a command with
|
|
||||||
'sudo'. Neither operation should require a password.
|
|
||||||
|
|
||||||
Clone the OpenStack-Helm Repos
|
|
||||||
------------------------------
|
|
||||||
|
|
||||||
Once the host has been configured the repos containing the OpenStack-Helm charts
|
|
||||||
should be cloned onto each node in the cluster:
|
|
||||||
|
|
||||||
.. code-block:: shell
|
|
||||||
|
|
||||||
#!/bin/bash
|
|
||||||
set -xe
|
|
||||||
|
|
||||||
sudo chown -R ubuntu: /opt
|
|
||||||
git clone https://git.openstack.org/openstack/openstack-helm-infra.git /opt/openstack-helm-infra
|
|
||||||
git clone https://git.openstack.org/openstack/openstack-helm.git /opt/openstack-helm
|
|
||||||
|
|
||||||
|
|
||||||
Create an inventory file
|
|
||||||
------------------------
|
|
||||||
|
|
||||||
On the master node create an inventory file for the cluster:
|
|
||||||
|
|
||||||
.. note::
|
|
||||||
node_one, node_two and node_three below are all worker nodes,
|
|
||||||
children of the master node that the commands below are executed on.
|
|
||||||
|
|
||||||
.. code-block:: shell
|
|
||||||
|
|
||||||
#!/bin/bash
|
|
||||||
set -xe
|
|
||||||
cat > /opt/openstack-helm-infra/tools/gate/devel/multinode-inventory.yaml <<EOF
|
|
||||||
all:
|
|
||||||
children:
|
|
||||||
primary:
|
|
||||||
hosts:
|
|
||||||
node_one:
|
|
||||||
ansible_port: 22
|
|
||||||
ansible_host: $node_one_ip
|
|
||||||
ansible_user: ubuntu
|
|
||||||
ansible_ssh_private_key_file: /etc/openstack-helm/deploy-key.pem
|
|
||||||
ansible_ssh_extra_args: -o StrictHostKeyChecking=no
|
|
||||||
nodes:
|
|
||||||
hosts:
|
|
||||||
node_two:
|
|
||||||
ansible_port: 22
|
|
||||||
ansible_host: $node_two_ip
|
|
||||||
ansible_user: ubuntu
|
|
||||||
ansible_ssh_private_key_file: /etc/openstack-helm/deploy-key.pem
|
|
||||||
ansible_ssh_extra_args: -o StrictHostKeyChecking=no
|
|
||||||
node_three:
|
|
||||||
ansible_port: 22
|
|
||||||
ansible_host: $node_three_ip
|
|
||||||
ansible_user: ubuntu
|
|
||||||
ansible_ssh_private_key_file: /etc/openstack-helm/deploy-key.pem
|
|
||||||
ansible_ssh_extra_args: -o StrictHostKeyChecking=no
|
|
||||||
EOF
|
|
||||||
|
|
||||||
Create an environment file
|
|
||||||
--------------------------
|
|
||||||
|
|
||||||
On the master node create an environment file for the cluster:
|
|
||||||
|
|
||||||
.. code-block:: shell
|
|
||||||
|
|
||||||
#!/bin/bash
|
|
||||||
set -xe
|
|
||||||
function net_default_iface {
|
|
||||||
sudo ip -4 route list 0/0 | awk '{ print $5; exit }'
|
|
||||||
}
|
|
||||||
cat > /opt/openstack-helm-infra/tools/gate/devel/multinode-vars.yaml <<EOF
|
|
||||||
kubernetes_network_default_device: $(net_default_iface)
|
|
||||||
EOF
|
|
||||||
|
|
||||||
Additional configuration variables can be found `here
|
|
||||||
<https://github.com/openstack/openstack-helm-infra/blob/master/roles/deploy-kubeadm-aio-common/defaults/main.yml>`_.
|
|
||||||
In particular, ``kubernetes_cluster_pod_subnet`` can be used to override the
|
|
||||||
pod subnet set up by Calico (the default container SDN), if you have a
|
|
||||||
preexisting network that conflicts with the default pod subnet of 192.168.0.0/16.
|
|
||||||
|
|
||||||
.. note::
|
|
||||||
This installation, by default will use Google DNS servers, 8.8.8.8 or 8.8.4.4
|
|
||||||
and updates resolv.conf. These DNS nameserver entries can be changed by
|
|
||||||
updating file ``/opt/openstack-helm-infra/tools/images/kubeadm-aio/assets/opt/playbooks/vars.yaml``
|
|
||||||
under section ``external_dns_nameservers``. This change must be done on each
|
|
||||||
node in your cluster.
|
|
||||||
|
|
||||||
|
|
||||||
Run the playbooks
|
|
||||||
-----------------
|
|
||||||
|
|
||||||
On the master node run the playbooks:
|
|
||||||
|
|
||||||
.. code-block:: shell
|
|
||||||
|
|
||||||
#!/bin/bash
|
|
||||||
set -xe
|
|
||||||
cd /opt/openstack-helm-infra
|
|
||||||
make dev-deploy setup-host multinode
|
|
||||||
make dev-deploy k8s multinode
|
|
||||||
|
|
||||||
Deploy OpenStack-Helm
|
Deploy OpenStack-Helm
|
||||||
=====================
|
=====================
|
||||||
|
Loading…
x
Reference in New Issue
Block a user