Skip to content

Kubernetes v1.21.11部署Nginx

创建 pod

pod 是 k8s 最小的编排单位,通常来说不需要直接创建 pod。这里是为了演示 pod 的使用创建了一个 pod。

创建pod的配置文件 nginx-pod.yml

yml
apiVersion: v1
kind: Pod
metadata:
  name: nginx
  labels:
    app: nginx
spec:
  containers:
  - name: nginx
    image: nginx:alpine
    ports:
    - containerPort: 80

文件描述:

  • apiVersion:这个配置文件声明对象要使用那个api版本,具体怎么写可以看Which Kubernetes apiVersion Should I Use?
  • kind:这个配置文件声明对象的种类。
  • metadata:这个pod的元信息
    • metadata.name:pod的名称 nginx
    • metadata.labels:pod的标签 即:app=nginx
  • spec:pod的详细参数配置说明

使用命令 kubectl apply 创建 pod:

bash
kubectl apply -f nginx-pod.yml

为了检查创建的 pod 的状态,执行命令:

bash
kubectl get pods nginx -o wide

可以看到 nginx pod 已处于 Running 状态,表示刚创建的 pod 已成功运行起来:

bash
NAME    READY   STATUS    RESTARTS   AGE   IP            NODE        NOMINATED NODE   READINESS GATES
nginx   1/1     Running   0          74m   10.244.1.13   k8s-node2   <none>           <none>

如果需要显示更详细的 pod 的信息,可以使用命令:

bash
kubectl describe pods nginx

为了进一步验证 nginx 已成功启动,进入 pod 中容器:

bash
kubectl exec -it nginx -- /bin/sh

进入容器后,执行命令:

bash
curl localhost

可以正常打印出 nginx 启动成功的欢迎页面 html。

进行下面的实验前,可以先将刚创建的 pod 删除:

bash
kubectl delete -f nginx-pod.yml

创建deployment

k8s deployment 用来部署应用。一个常见的 deployment 配置包括几个部分,详细可以参考官网有关介绍 Deployments

创建deployment的配置文件 nginx-dep.yml

yml
apiVersion: apps/v1
kind: Deployment
metadata:
  name: nginx-deployment
  namespace: default
spec:
  selector:
    matchLabels:
      app: nginx
  replicas: 3
  template:
    metadata:
      labels:
        app: nginx
    spec:
      containers:
      - name: nginx
        image: nginx:alpine
        ports:
        - containerPort: 80
  • metadata.name:用于定义 deployment 的名称
  • metadata.namespace:用于定义 deployment 所在的命名空间
  • spec.selector:用于定义 deployment 如何查找要管理的 pod,例如,使用在 pod 模板中定义的标签,如 app:nginx
  • spec.replicas:用于定义需要启动多少个副本
  • spec.template:用于定义 pod 的属性,例如,容器名称,容器镜像,labels 字段,等

为了创建 deployment,执行命令:

bash
kubectl apply -f nginx-dep.yml

查看 deployment 状态:

bash
kubectl get deploy -o wide

如果需要显示更详细的 pod 的信息,可以使用命令:

bash
kubectl describe deploy nginx-deployment

可以看到,刚创建的 nginx-deployment 的 3 个副本均处于 READY 状态:

bash
NAME               READY   UP-TO-DATE   AVAILABLE   AGE   CONTAINERS   IMAGES         SELECTOR
nginx-deployment   3/3     3            3           54s   nginx        nginx:alpine   app=nginx

增加pods节点从3个到4个,只需修改 nginx-dep.yml 中的.spec.replicas为4之后,再执行

bash
kubectl apply -f nginx-dep.yml

即可看到副本数量增加到了4个。

再修改 nginx-dep.yml 中的.spec.replicas为2,再执行

bash
kubectl apply -f nginx-dep.yml

即可看到副本数量减少到了2个。

执行此命令可将deployment删除,先不要执行,下面service要使用此deployment

bash
kubectl delete -f nginx-dep.yml

创建 service

k8s 使用 service 来实现服务发现,即我们将deployment创建好之后,创建上层的service来对外提供服务,外部服务只需访问[IP:Port]即可访问此服务,我们无需关心负载均衡是怎么做的,kube-proxy会自动分配转发流量。

创建service的配置文件 nginx-svc.yml

yml
apiVersion: v1
kind: Service
metadata:
  name: nginx-service
spec:
  selector:
    app: nginx
  ports:
  - protocol: TCP
    port: 80
    targetPort: 80
    nodePort: 30080
  type: NodePort
  • spec.selector:用于定义如何选择 pod
  • spec.ports:用于定义如何暴露端口,其中,nodePort 指定可以在外部访问的端口

为创建 servcie,执行命令:

bash
kubectl apply -f nginx-svc.yml

查看 service 的状态:

bash
kubectl get svc nginx-service -o wide

输出:

bash
NAME            TYPE       CLUSTER-IP      EXTERNAL-IP   PORT(S)        AGE   SELECTOR
nginx-service   NodePort   10.106.209.76   <none>        80:30080/TCP   26s   app=nginx

为了验证在外部正常访问 nginx,打开浏览器,输入地址 http://localhost:30080/,可以看到 nginx 的欢迎页面,说明 nginx-service 创建成功。

对service配置的修改和deployment的修改是一样的,修改配置文件后重新apply即可。

执行此命令可将service删除,先删除service,再删除deployment

bash
kubectl delete -f nginx-svc.yml