wrider | c1be425 | 2019-11-26 10:13:54 -0500 | [diff] [blame] | 1 | .. This work is licensed under a Creative Commons Attribution 4.0 International License. |
| 2 | .. SPDX-License-Identifier: CC-BY-4.0 |
| 3 | .. ===============LICENSE_START======================================================= |
Lott, Christopher (cl778h) | c22d1ce | 2020-01-20 13:53:43 -0500 | [diff] [blame] | 4 | .. Copyright (C) 2019-2020 AT&T Intellectual Property |
wrider | c1be425 | 2019-11-26 10:13:54 -0500 | [diff] [blame] | 5 | .. =================================================================================== |
Lott, Christopher (cl778h) | c22d1ce | 2020-01-20 13:53:43 -0500 | [diff] [blame] | 6 | .. This documentation file is distributed under the Creative Commons Attribution |
| 7 | .. 4.0 International License (the "License"); you may not use this file except in |
wrider | c1be425 | 2019-11-26 10:13:54 -0500 | [diff] [blame] | 8 | .. compliance with the License. You may obtain a copy of the License at |
| 9 | .. |
| 10 | .. http://creativecommons.org/licenses/by/4.0 |
| 11 | .. |
| 12 | .. This file is distributed on an "AS IS" BASIS, |
| 13 | .. WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
| 14 | .. See the License for the specific language governing permissions and |
| 15 | .. limitations under the License. |
| 16 | .. ===============LICENSE_END========================================================= |
| 17 | |
| 18 | |
Lott, Christopher (cl778h) | ca9b3ee | 2020-01-20 15:56:57 -0500 | [diff] [blame^] | 19 | Script for Setting Up 1-Node Kubernetes Cluster |
wrider | c1be425 | 2019-11-26 10:13:54 -0500 | [diff] [blame] | 20 | ----------------------------------------------- |
| 21 | |
Lott, Christopher (cl778h) | cb20033 | 2020-01-20 15:56:57 -0500 | [diff] [blame] | 22 | The it/dep repo can be used for generating a simple script that can help setting up a |
| 23 | one-node Kubernetes cluster for dev and testing purposes. Related files are under the |
Lott, Christopher (cl778h) | ca9b3ee | 2020-01-20 15:56:57 -0500 | [diff] [blame^] | 24 | **ric-infra/00-Kubernetes** directory. Clone the it/dep git repository on the target VM. |
wrider | c1be425 | 2019-11-26 10:13:54 -0500 | [diff] [blame] | 25 | |
Lott, Christopher (cl778h) | cb20033 | 2020-01-20 15:56:57 -0500 | [diff] [blame] | 26 | :: |
| 27 | |
Lott, Christopher (cl778h) | ca9b3ee | 2020-01-20 15:56:57 -0500 | [diff] [blame^] | 28 | % git clone https://gerrit.o-ran-sc.org/r/it/dep |
Lott, Christopher (cl778h) | cb20033 | 2020-01-20 15:56:57 -0500 | [diff] [blame] | 29 | |
wrider | c1be425 | 2019-11-26 10:13:54 -0500 | [diff] [blame] | 30 | |
| 31 | Configurations |
| 32 | -------------- |
| 33 | |
| 34 | The generation of the script reads in the parameters from the following files: |
| 35 | |
Lott, Christopher (cl778h) | cb20033 | 2020-01-20 15:56:57 -0500 | [diff] [blame] | 36 | - etc/env.rc: Normally no change needed for this file. If where the Kubernetes cluster runs |
| 37 | has special requirements, such as running private Docker registry with self-signed certificates, |
| 38 | or hostnames that can be only resolved via private /etc/hosts entries, such parameters are |
| 39 | entered into this file. |
| 40 | - etc/infra.rc: This file specifies the docker host, Kubernetes, and Kubernetes CNI versions. |
| 41 | If a version is left empty, the installation will use the default version that the OS package |
| 42 | management software would install. |
| 43 | - etc/openstack.rc: If the Kubernetes cluster is deployed on Open Stack VMs, this file specifies |
| 44 | parameters for accessing the APIs of the Open Stack installation. This is not supported in Amber |
| 45 | release yet. |
wrider | c1be425 | 2019-11-26 10:13:54 -0500 | [diff] [blame] | 46 | |
| 47 | |
| 48 | Generating Set-up Script |
| 49 | ------------------------ |
| 50 | |
Lott, Christopher (cl778h) | cb20033 | 2020-01-20 15:56:57 -0500 | [diff] [blame] | 51 | After the configurations are updated, the following steps will create a script file that can be |
| 52 | used for setting up a one-node Kubernetes cluster. You must run this command on a Linux machine |
| 53 | with the 'envsubst' command installed. |
wrider | c1be425 | 2019-11-26 10:13:54 -0500 | [diff] [blame] | 54 | |
| 55 | :: |
| 56 | |
Lott, Christopher (cl778h) | cb20033 | 2020-01-20 15:56:57 -0500 | [diff] [blame] | 57 | % cd bin |
| 58 | % ./gen-cloud-init.sh |
wrider | c1be425 | 2019-11-26 10:13:54 -0500 | [diff] [blame] | 59 | |
Lott, Christopher (cl778h) | c22d1ce | 2020-01-20 13:53:43 -0500 | [diff] [blame] | 60 | A file named **k8s-1node-cloud-init.sh** would now appear under the bin directory. |
wrider | c1be425 | 2019-11-26 10:13:54 -0500 | [diff] [blame] | 61 | |
| 62 | |
| 63 | Setting up Kubernetes Cluster |
| 64 | ----------------------------- |
| 65 | |
Lott, Christopher (cl778h) | c22d1ce | 2020-01-20 13:53:43 -0500 | [diff] [blame] | 66 | The new **k8s-1node-cloud-init.sh** file is now ready for setting up the Kubernetes cluster. |
wrider | c1be425 | 2019-11-26 10:13:54 -0500 | [diff] [blame] | 67 | |
Lott, Christopher (cl778h) | cb20033 | 2020-01-20 15:56:57 -0500 | [diff] [blame] | 68 | It can be run from a root shell of an existing Ubuntu 16.04 or 18.04 VM. Running this script |
| 69 | will replace any existing installation of Docker host, Kubernetes, and Helm on the VM. The |
| 70 | script will reboot the machine upon successful completion. Run the script like this: |
wrider | c1be425 | 2019-11-26 10:13:54 -0500 | [diff] [blame] | 71 | |
Lott, Christopher (cl778h) | cb20033 | 2020-01-20 15:56:57 -0500 | [diff] [blame] | 72 | :: |
wrider | c1be425 | 2019-11-26 10:13:54 -0500 | [diff] [blame] | 73 | |
Lott, Christopher (cl778h) | cb20033 | 2020-01-20 15:56:57 -0500 | [diff] [blame] | 74 | % sudo -i |
| 75 | # ./k8s-1node-cloud-init.sh |
| 76 | |
| 77 | This script can also be used as the user-data (a.k.a. cloud-init script) supplied to Open Stack |
| 78 | when launching a new Ubuntu 16.04 or 18.04 VM. |
| 79 | |
| 80 | Upon successful execution of the script and reboot of the machine, when queried in a root shell |
| 81 | with the kubectl command the VM should display information similar to below: |
wrider | c1be425 | 2019-11-26 10:13:54 -0500 | [diff] [blame] | 82 | |
| 83 | :: |
| 84 | |
| 85 | # kubectl get pods --all-namespaces |
| 86 | NAMESPACE NAME READY STATUS RESTARTS AGE |
| 87 | kube-system coredns-5644d7b6d9-4gjp5 1/1 Running 0 103m |
| 88 | kube-system coredns-5644d7b6d9-pvsj8 1/1 Running 0 103m |
| 89 | kube-system etcd-ljitest 1/1 Running 0 102m |
| 90 | kube-system kube-apiserver-ljitest 1/1 Running 0 103m |
| 91 | kube-system kube-controller-manager-ljitest 1/1 Running 0 102m |
| 92 | kube-system kube-flannel-ds-amd64-nvjmq 1/1 Running 0 103m |
| 93 | kube-system kube-proxy-867v5 1/1 Running 0 103m |
| 94 | kube-system kube-scheduler-ljitest 1/1 Running 0 102m |
| 95 | kube-system tiller-deploy-68bf6dff8f-6pwvc 1/1 Running 0 102m |