Fedora 35
Sponsored Link

Kubernetes : Pod デプロイ2021/11/11

 
Pod 作成等の基本操作です。
[1] Pod の作成/削除等の操作です。
# [test-nginx] pod を起動する

[root@dlp ~]#
kubectl create deployment test-nginx --image=nginx

deployment.apps/test-nginx created
[root@dlp ~]#
kubectl get pods

NAME                         READY   STATUS    RESTARTS   AGE
test-nginx-59ffd87f5-w4tqq   1/1     Running   0          27s

# [test-nginx] pod の環境変数を表示する

[root@dlp ~]#
kubectl exec test-nginx-59ffd87f5-w4tqq -- env

PATH=/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin
TERM=xterm
HOSTNAME=test-nginx-59ffd87f5-w4tqq
KUBERNETES_SERVICE_HOST=10.96.0.1
KUBERNETES_SERVICE_PORT=443
KUBERNETES_SERVICE_PORT_HTTPS=443
KUBERNETES_PORT=tcp://10.96.0.1:443
KUBERNETES_PORT_443_TCP=tcp://10.96.0.1:443
KUBERNETES_PORT_443_TCP_PROTO=tcp
KUBERNETES_PORT_443_TCP_PORT=443
KUBERNETES_PORT_443_TCP_ADDR=10.96.0.1
NGINX_VERSION=1.21.4
NJS_VERSION=0.7.0
PKG_RELEASE=1~bullseye
HOME=/root

# [test-nginx] pod にシェルアクセス

[root@dlp ~]#
kubectl exec -it test-nginx-59ffd87f5-w4tqq -- bash
root@test-nginx-59ffd87f5-w4tqq:/#
hostname

test-nginx-59ffd87f5-w4tqq
root@test-nginx-59ffd87f5-w4tqq:/#
exit
# [test-nginx] pod のログを表示する

[root@dlp ~]#
kubectl logs test-nginx-59ffd87f5-w4tqq

/docker-entrypoint.sh: /docker-entrypoint.d/ is not empty, will attempt to perform configuration
/docker-entrypoint.sh: Looking for shell scripts in /docker-entrypoint.d/
/docker-entrypoint.sh: Launching /docker-entrypoint.d/10-listen-on-ipv6-by-default.sh
10-listen-on-ipv6-by-default.sh: info: Getting the checksum of /etc/nginx/conf.d/default.conf
10-listen-on-ipv6-by-default.sh: info: Enabled listen on IPv6 in /etc/nginx/conf.d/default.conf
/docker-entrypoint.sh: Launching /docker-entrypoint.d/20-envsubst-on-templates.sh
/docker-entrypoint.sh: Launching /docker-entrypoint.d/30-tune-worker-processes.sh
/docker-entrypoint.sh: Configuration complete; ready for start up
2021/11/11 05:03:10 [notice] 1#1: using the "epoll" event method
2021/11/11 05:03:10 [notice] 1#1: nginx/1.21.4
2021/11/11 05:03:10 [notice] 1#1: built by gcc 10.2.1 20210110 (Debian 10.2.1-6)
2021/11/11 05:03:10 [notice] 1#1: OS: Linux 5.14.10-300.fc35.x86_64
2021/11/11 05:03:10 [notice] 1#1: getrlimit(RLIMIT_NOFILE): 1048576:1048576
2021/11/11 05:03:10 [notice] 1#1: start worker processes
2021/11/11 05:03:10 [notice] 1#1: start worker process 31
2021/11/11 05:03:10 [notice] 1#1: start worker process 32

# pod をスケールアウトする

[root@dlp ~]#
kubectl scale deployment test-nginx --replicas=3

deployment.extensions/test-nginx scaled
[root@dlp ~]#
kubectl get pods -o wide

NAME                         READY   STATUS    RESTARTS   AGE     IP                NODE               NOMINATED NODE   READINESS GATES
test-nginx-59ffd87f5-pdnzs   1/1     Running   0          88s     192.168.40.194    node01.srv.world   <none>           <none>
test-nginx-59ffd87f5-w4tqq   1/1     Running   0          3m59s   192.168.241.129   node02.srv.world   <none>           <none>
test-nginx-59ffd87f5-xld9r   1/1     Running   0          88s     192.168.40.193    node01.srv.world   <none>           <none>

# サービスを設定する

[root@dlp ~]#
kubectl expose deployment test-nginx --type="NodePort" --port 80

service "test-nginx" exposed
[root@dlp ~]#
kubectl get services test-nginx

NAME         TYPE       CLUSTER-IP      EXTERNAL-IP   PORT(S)        AGE
test-nginx   NodePort   10.98.169.252   <none>        80:30508/TCP   56s

# アクセス確認

[root@dlp ~]#
curl 10.98.169.252

<!DOCTYPE html>
<html>
<head>
<title>Welcome to nginx!</title>
.....
.....
<p><em>Thank you for using nginx.</em></p>
</body>
</html>

# サービスを削除する

[root@dlp ~]#
kubectl delete services test-nginx

service "test-nginx" deleted
# Pod を削除する

[root@dlp ~]#
kubectl delete deployment test-nginx

deployment.extensions "test-nginx" deleted
関連コンテンツ