Skip to content

Kubernetes 部署、维护nginx服务

1.1 配置nginx服务并通过nodeport类型的svc实现访问

首先准备好放置yaml文件的目录

mkdir -pv /opt/k8s-data/yaml/myserver/nginx

进入上一步准备好的目录,编写yaml文件

root@deploy01:/opt/k8s-data/yaml/myserver/nginx# vim nginx.yaml
kind: Deployment  #类型,是deployment控制器,kubectl explain  Deployment
apiVersion: apps/v1  #API版本,# kubectl explain  Deployment.apiVersion
metadata: #Deployment控制器的元数据信息,kubectl explain  Deployment.metadata
  labels: #自定义pod的标签,# kubectl explain  Deployment.metadata.labels
    app: myserver-nginx-deployment-label #标签名称为app值为myserver-nginx-deployment-label,后面会用到此标签 
  name: myserver-nginx-deployment #pod的名称
  namespace: myserver #pod的namespace,默认是defaule
spec: #定义deployment中容器的详细信息,kubectl explain  Deployment.spec
  replicas: 1 #创建出的pod的副本数,即多少个pod,默认值为1
  selector: #定义标签选择器
    matchLabels: #定义匹配的标签,必须要设置
      app: myserver-nginx-selector #匹配的目标标签,
  template: #定义模板,必须定义,模板是起到描述要创建的pod的作用
    metadata: #定义模板元数据
      labels: #定义模板label,Deployment.spec.template.metadata.labels
        app: myserver-nginx-selector #定义标签,等于Deployment.spec.selector.matchLabels
    spec: #定义pod信息
      containers: #定义pod中容器列表,可以多个至少一个,pod不能动态增减容器
      - name: myserver-nginx-container #容器名称
        image: registry.cn-hangzhou.aliyuncs.com/myhubregistry/nginx:1.27.0-alpine3.19 #镜像地址
        #command: ["/apps/tomcat/bin/run_tomcat.sh"] #容器启动执行的命令或脚本
        #imagePullPolicy: IfNotPresent
        imagePullPolicy: Always #拉取镜像策略
        ports: #定义容器端口列表
        - containerPort: 80 #定义一个端口
          protocol: TCP #端口协议
          name: http #端口名称
        - containerPort: 443 #定义一个端口
          protocol: TCP #端口协议
          name: https #端口名称
        env: #配置环境变量
        - name: "password" #变量名称。必须要用引号引起来
          value: "123456" #当前变量的值
        - name: "age" #另一个变量名称
          value: "18" #另一个变量的值
        resources: #对资源的请求设置和限制设置
          limits: #资源限制设置,上限
            cpu: 500m  #cpu的限制,单位为core数,可以写0.5或者500m等CPU压缩值
            memory: 2Gi #内存限制,单位可以为Mib/Gib,将用于docker run --memory参数
          requests: #资源请求的设置
            cpu: 200m #cpu请求数,容器启动的初始可用数量,可以写0.5或者500m等CPU压缩值
            memory: 512Mi #内存请求大小,容器启动的初始可用数量,用于调度pod时候使用
            
---
kind: Service #类型为service
apiVersion: v1 #service API版本, service.apiVersion
metadata: #定义service元数据,service.metadata
  labels: #自定义标签,service.metadata.labels
    app: myserver-nginx #定义service标签的内容
  name: myserver-nginx-service #定义service的名称,此名称会被DNS解析
  namespace: myserver #该service隶属于的namespaces名称,即把service创建到哪个namespace里面
spec: #定义service的详细信息,service.spec
  type: NodePort #service的类型,定义服务的访问方式,默认为ClusterIP, service.spec.type
  ports: #定义访问端口, service.spec.ports
  - name: http #定义一个端口名称
    port: 80 #service 80端口
    protocol: TCP #协议类型
    targetPort: 80 #目标pod的端口
    nodePort: 30001 #node节点暴露的端口
  - name: https #SSL 端口
    port: 443 #service 443端口
    protocol: TCP #端口协议
    targetPort: 443 #目标pod端口
    nodePort: 30043 #node节点暴露的SSL端口
  selector: #service的标签选择器,定义要访问的目标pod
    app: myserver-nginx-selector #将流量路到选择的pod上,须等于Deployment.spec.selector.matchLabels

1.2 基于deployment控制器部署维护nginx服务

1.2.1 部署

kubectl apply -f nginx.yaml

1.2.2 镜像更新

修改yaml文件中的image字段后重新kubectl apply -f nginx.yaml

1.2.3 回滚

kubectl rollout undo deployment/myserver-nginx-deployment

1.2.4 副本调整

修改配置文件中的replicas值或者直接 kubectl scale deployment myserver-nginx-deployment --replicas=<副本数量>

1.2.5 ENV环境变量传递

yaml中的env字段已经定义了环境变量,这些变量会在容器启动时传递给 Nginx 进程。 如果需要添加更多变量,可以在env列表中添加新的条目。