Kubernetes-설정

Kubernetes를 설정하기 전에 vDC (가상 데이터 센터)를 설정하는 것이 중요합니다. 이것은 네트워크를 통해 서로 통신 할 수있는 기계 세트로 간주 될 수 있습니다. 실습 방식의 경우 다음에서 vDC를 설정할 수 있습니다.PROFITBRICKS 물리적 또는 클라우드 인프라를 설정하지 않은 경우.

클라우드에서 IaaS 설정이 완료되면 다음을 구성해야합니다. Master 그리고 Node.

Note− Ubuntu 머신에 대한 설정이 표시됩니다. 다른 Linux 시스템에서도 동일하게 설정할 수 있습니다.

전제 조건

Installing Docker− 모든 Kubernetes 인스턴스에 Docker가 필요합니다. 다음은 Docker를 설치하는 단계입니다.

Step 1 − 루트 사용자 계정으로 컴퓨터에 로그온합니다.

Step 2− 패키지 정보를 업데이트합니다. apt 패키지가 작동하는지 확인하십시오.

Step 3 − 다음 명령을 실행합니다.

$ sudo apt-get update
$ sudo apt-get install apt-transport-https ca-certificates

Step 4 − 새 GPG 키를 추가합니다.

$ sudo apt-key adv \
   --keyserver hkp://ha.pool.sks-keyservers.net:80 \
   --recv-keys 58118E89F3A912897C070ADBF76221572C52609D
$ echo "deb https://apt.dockerproject.org/repo ubuntu-trusty main" | sudo tee
/etc/apt/sources.list.d/docker.list

Step 5 − API 패키지 이미지를 업데이트합니다.

$ sudo apt-get update

위의 모든 작업이 완료되면 Docker 엔진의 실제 설치를 시작할 수 있습니다. 그러나이 전에 사용중인 커널 버전이 올바른지 확인해야합니다.

Docker Engine 설치

다음 명령을 실행하여 Docker 엔진을 설치하십시오.

Step 1 − 컴퓨터에 로그온합니다.

Step 2 − 패키지 색인을 업데이트합니다.

$ sudo apt-get update

Step 3 − 다음 명령을 사용하여 Docker Engine을 설치합니다.

$ sudo apt-get install docker-engine

Step 4 − Docker 데몬을 시작합니다.

$ sudo apt-get install docker-engine

Step 5 − Docker가 설치되어 있는지 확인하려면 다음 명령을 사용하십시오.

$ sudo docker run hello-world

etcd 2.0 설치

Kubernetes Master Machine에 설치해야합니다. 설치하려면 다음 명령을 실행하십시오.

$ curl -L https://github.com/coreos/etcd/releases/download/v2.0.0/etcd
-v2.0.0-linux-amd64.tar.gz -o etcd-v2.0.0-linux-amd64.tar.gz ->1
$ tar xzvf etcd-v2.0.0-linux-amd64.tar.gz ------>2
$ cd etcd-v2.0.0-linux-amd64 ------------>3
$ mkdir /opt/bin ------------->4
$ cp etcd* /opt/bin ----------->5

위의 명령 세트에서-

  • 먼저 etcd. 지정된 이름으로 저장하십시오.
  • 그런 다음 tar 패키지의 압축을 풀어야합니다.
  • 우리는 dir을 만듭니다. / opt라는 이름의 bin 내부.
  • 추출 된 파일을 대상 위치에 복사하십시오.

이제 Kubernetes를 구축 할 준비가되었습니다. 클러스터의 모든 머신에 Kubernetes를 설치해야합니다.

$ git clone https://github.com/GoogleCloudPlatform/kubernetes.git
$ cd kubernetes
$ make release

위의 명령은 _outputkubernetes 폴더의 루트에있는 dir. 다음으로, 선택한 / opt / bin 등의 디렉토리에 디렉토리를 추출 할 수 있습니다.

다음으로 Kubernetes 마스터 및 노드 설정부터 실제로 시작해야하는 네트워킹 부분이 있습니다. 이를 위해 노드 머신에서 수행 할 수있는 호스트 파일에 항목을 작성합니다.

$ echo "<IP address of master machine> kube-master
< IP address of Node Machine>" >> /etc/hosts

다음은 위 명령의 출력입니다.

이제 Kubernetes Master의 실제 구성부터 시작하겠습니다.

먼저 모든 구성 파일을 올바른 위치에 복사하기 시작합니다.

$ cp <Current dir. location>/kube-apiserver /opt/bin/
$ cp <Current dir. location>/kube-controller-manager /opt/bin/
$ cp <Current dir. location>/kube-kube-scheduler /opt/bin/
$ cp <Current dir. location>/kubecfg /opt/bin/
$ cp <Current dir. location>/kubectl /opt/bin/
$ cp <Current dir. location>/kubernetes /opt/bin/

위의 명령은 모든 구성 파일을 필요한 위치에 복사합니다. 이제 Kubernetes 폴더를 빌드 한 동일한 디렉토리로 돌아갑니다.

$ cp kubernetes/cluster/ubuntu/init_conf/kube-apiserver.conf /etc/init/
$ cp kubernetes/cluster/ubuntu/init_conf/kube-controller-manager.conf /etc/init/
$ cp kubernetes/cluster/ubuntu/init_conf/kube-kube-scheduler.conf /etc/init/

$ cp kubernetes/cluster/ubuntu/initd_scripts/kube-apiserver /etc/init.d/
$ cp kubernetes/cluster/ubuntu/initd_scripts/kube-controller-manager /etc/init.d/
$ cp kubernetes/cluster/ubuntu/initd_scripts/kube-kube-scheduler /etc/init.d/

$ cp kubernetes/cluster/ubuntu/default_scripts/kubelet /etc/default/
$ cp kubernetes/cluster/ubuntu/default_scripts/kube-proxy /etc/default/
$ cp kubernetes/cluster/ubuntu/default_scripts/kubelet /etc/default/

다음 단계는 / etc 아래에 복사 된 구성 파일을 업데이트하는 것입니다. dir.

다음 명령을 사용하여 마스터에서 etcd를 구성하십시오.

$ ETCD_OPTS = "-listen-client-urls = http://kube-master:4001"

kube-apiserver 구성

이를 위해 마스터에서 편집해야합니다. /etc/default/kube-apiserver 앞서 복사 한 파일.

$ KUBE_APISERVER_OPTS = "--address = 0.0.0.0 \
--port = 8080 \
--etcd_servers = <The path that is configured in ETCD_OPTS> \
--portal_net = 11.1.1.0/24 \
--allow_privileged = false \
--kubelet_port = < Port you want to configure> \
--v = 0"

kube 컨트롤러 관리자 구성

다음 내용을 추가해야합니다. /etc/default/kube-controller-manager.

$ KUBE_CONTROLLER_MANAGER_OPTS = "--address = 0.0.0.0 \
--master = 127.0.0.1:8080 \
--machines = kube-minion \ -----> #this is the kubernatics node
--v = 0

다음으로 해당 파일에서 kube 스케줄러를 구성하십시오.

$ KUBE_SCHEDULER_OPTS = "--address = 0.0.0.0 \
--master = 127.0.0.1:8080 \
--v = 0"

위의 모든 작업이 완료되면 Kubernetes 마스터를 불러 와서 진행하는 것이 좋습니다. 이를 위해 Docker를 다시 시작합니다.

$ service docker restart

Kubernetes 노드 구성

Kubernetes 노드는 두 가지 서비스를 실행합니다. kubelet and the kube-proxy. 계속 진행하기 전에 다운로드 한 바이너리를 kubernetes 노드를 구성하려는 필수 폴더에 복사해야합니다.

kubernetes 마스터에 대해 수행 한 파일 복사와 동일한 방법을 사용하십시오. kubelet 및 kube-proxy 만 실행하므로 구성 할 것입니다.

$ cp <Path of the extracted file>/kubelet /opt/bin/
$ cp <Path of the extracted file>/kube-proxy /opt/bin/
$ cp <Path of the extracted file>/kubecfg /opt/bin/
$ cp <Path of the extracted file>/kubectl /opt/bin/
$ cp <Path of the extracted file>/kubernetes /opt/bin/

이제 컨텐츠를 적절한 디렉토리에 복사합니다.

$ cp kubernetes/cluster/ubuntu/init_conf/kubelet.conf /etc/init/
$ cp kubernetes/cluster/ubuntu/init_conf/kube-proxy.conf /etc/init/
$ cp kubernetes/cluster/ubuntu/initd_scripts/kubelet /etc/init.d/
$ cp kubernetes/cluster/ubuntu/initd_scripts/kube-proxy /etc/init.d/
$ cp kubernetes/cluster/ubuntu/default_scripts/kubelet /etc/default/
$ cp kubernetes/cluster/ubuntu/default_scripts/kube-proxy /etc/default/

우리는 kubeletkube-proxy conf 파일.

우리는 /etc/init/kubelet.conf.

$ KUBELET_OPTS = "--address = 0.0.0.0 \
--port = 10250 \
--hostname_override = kube-minion \
--etcd_servers = http://kube-master:4001 \
--enable_server = true
--v = 0"
/

kube-proxy의 경우 다음 명령을 사용하여 구성합니다.

$ KUBE_PROXY_OPTS = "--etcd_servers = http://kube-master:4001 \
--v = 0"
/etc/init/kube-proxy.conf

마지막으로 Docker 서비스를 다시 시작합니다.

$ service docker restart

이제 구성이 완료되었습니다. 다음 명령을 실행하여 확인할 수 있습니다.

$ /opt/bin/kubectl get minions