首页 > 系统相关 >教你几个部署多个nginx-ingress的注意事项

教你几个部署多个nginx-ingress的注意事项

时间:2023-12-25 15:38:18浏览次数:40  
标签:ingress name webhook nginx controller io 注意事项

本文分享自华为云社区《nginx-ingress工作原理以及多nginx-ingress部署注意事项》,作者: 可以交个朋友。

一、nginx-ingress工作原理

nginx-ingress对应的容器中有两个核心组件:nginx-ingress-controller和nginx。其中nginx-ingress-controller负责list-watch kube-apiserver监听ingress、service、endpoint、configmap资源的状态变化,转变为nginx配置,刷新给容器中nginx进程,再由nginx对外保留服务提供转发能力,大致工作流程如下:

  1. nginx-ingress实例运行,nginx-ingress-controller list-watch kube-apiserver,获取相关资源变化;
  2. 当用户创建ingress资源时,当nginx-ingress-controller开启webhook能力时,kube-apiserver根据对应的AdmissionWebhook描述调用nginx-ingress的8443端口,校验ingress资源合法性,通过后写入ETCD;
  3. nginx-ingress watch到ingress资源变化(创建新的ingress资源),获取对应的service、endpoint、configmap(如果涉及证书),转为为nginx配置,重写nginx.conf配置;
  4. 当请求访问到nginx-ingress 80或者443端口时,nginx开始处理转发请求,如果满足nginx.conf规则,nginx的lua脚本会调用kube-apiserver接口获取转发到真实后端podip;
理解nginx-ingress原理后,那么部署多个nginx-ingress的关键注意事项也就出来了:
  • 创建多个nginx-ingress,多个nginx-ingress如何标识自己?
  • 创建一个ingress资源后,在有多个nginx-ingress都在watch ingress的情况下,希望哪一个或者几个nginx-ingress““捕获”并作用?
  • 当部署了多个nginx-ingress,如果部分开启了webhook能力,当创建ingress资源后,kube-apiserver会调用哪个nginx-ingress的webhook去校验?

二、多nginx-ingress安装注意事项

2.1 多个nginx-ingress启动参数中–controller-class均不相同

nginx-ingress-a实例启动参数

教你几个部署多个nginx-ingress的注意事项_nginx


nginx-ingress-b实例启动参数

教你几个部署多个nginx-ingress的注意事项_nginx-ingress_02

2.2 通过ingress资源中spec.ingressClassName指定相关联nginx-ingress

kubernetes 1.23.x以下版本对应的apiVersion:networking.k8s.io/v1beta1

apiVersion: networking.k8s.io/v1beta1 
kind: Ingress 
metadata: 
  name: test-a
  namespace: nginx-a
  annotations: 
    kubernetes.io/ingress.class: custom-nginx-a
spec:
  rules:
  - http:
      paths:
      - backend:
          service:
            name: nginx
            port:
              number: 80
        path: /
        pathType: ImplementationSpecific
        property:
          ingress.beta.kubernetes.io/url-match-mode: STARTS_WITHSTARTS_WITH

kubernetes v1.23版本及以上apiVersion 是networking.k8s.io/v1

apiVersion: networking.k8s.io/v1 
kind: Ingress 
metadata: 
  name: test-a
  namespace: nginx-a
spec:
  ingressClassName: custom-nginx-a
  rules:
  - http:
      paths:
      - backend:
          service:
            name: nginx
            port:
              number: 80
        path: /
        pathType: ImplementationSpecific
        property:
          ingress.beta.kubernetes.io/url-match-mode: STARTS_WITH

2.3 多nginx-ingress场景下,通过admissionwebhook作用域限制单个nginx-ingress webhook作用范围

admission webhook作用域默认是全局的,如果一个集群中有多个nginx-ingress组件(通过ingressClass区域),由于有多个ValidatingAdmissionWebhook,当某个ingress资源创建时,kube-apiserver会调用多个nginx-ingress webhok能力进行校验,当某个nginx-ingress出现故障(可能与该ingress资源并不关联),将会阻塞所有的ingress的写入。

多nginx-ingress场景下建议通过admissionwebhook 自带的namespaceSelector控制每个nginx-ingress的作用域,使其作用到指定的命名空间,只教验作用域命名空间下的ingresses资源。

admissionwebhook:
   namespaceSelector: 
      matchExpressions:
      - key: kubernetes.io/metadata.name #需要教验的namespace含有的标签key
        operator: In
        values: ["${namespace}"] # namespace含有的标签value(默认命名空间本身)
    rules:
    - operations: ["CREATE","UPDATE"]
      apiGroups: ["*"]
      apiVersions: ["*"]
      resources: ["ingresses"] #限制作用资源
      scope: "*" #由于限制了作用资源ingresses,无需配置
    objectSelector: {}

如果集群版本在1.28及以上,可以通过matchConditions匹配请求,直接筛选ingressClassName字段,官网详情

三、安装部署多个nginx-ingress
  1. 登录到集群,将ingress-controller helm包下载到集群

    wget https://github.com/kubernetes/ingress-nginx/releases/download/helm-chart-4.3.0/ingress-nginx-4.3.0.tgz
  2. 新建myvalue.yaml文件,内容如下;安装时指定此配置文件,其它未进行指定的参数会使用安装包中value.yaml默认配置值。

    imagePullSecrets: {}   #若仓库开启认证需要配置该字段
    controller: 
      name: controller #自定义controller名称,不可重复
      image:    
        repository: swr.cn-north-4.myhuaweicloud.com/hwofficial/nginx-ingress     # controller镜像地址设定 
        tag: "v1.2.1" 
      ingressClass: custom-nginx    # 设定ingress-class值,不可重复
      ingressClassResource: 
        name: custom-nginx          #设定ingressClass资源名称,不可重复
        controllerValue: k8s.io/custom-nginx   #设定监测ingressClass资源的controller,不可重复
      # 设定controller要使用的loadbalancer service,本例中使用的是独享型ELB 
      service:  
        annotations: { 
        #  kubernetes.io/elb.class: performance  #开启后turbo集群直通pod(仅限独享型elb) 
        kubernetes.io/elb.id: 3660aa3c-xxxx-xxxx-xxxx-xxxxff97xxxx     #ELB ID,不可重复
        } 
      # 设定controller的资源限制 
      resources: 
        requests: 
          cpu: 200m 
          memory: 200Mi     
      # 挂载节点上的/etc/localtime文件,进行时区同步 
      extraVolumeMounts: 
        - name: localtime 
          mountPath: /etc/localtime 
          readOnly: true 
      extraVolumes: 
        - name: localtime 
          hostPath: 
            path: /etc/localtime 
      admissionWebhooks: 
        enabled: true 
        failurePolicy: Fail 
        port: 8443 
        certificate: "/usr/local/certificates/cert" 
        key: "/usr/local/certificates/key" 
        namespaceSelector:  
          matchExpressions: 
          - key: kubernetes.io/metadata.name 
            operator: In 
            values: ["${namespace}"] # ${namespace}修改为业务负载所在的命名空间,逗号分割 
        rules: 
        - operations: ["CREATE","UPDATE"] 
          apiGroups: ["*"] 
          apiVersions: ["*"] 
          resources: ["ingresses"] 
          scope: "*" 
        networkPolicyEnabled: false 
        service: 
          servicePort: 443 
          type: ClusterIP 
        createSecretJob: 
          resources: 
            limits: 
              cpu: 20m 
              memory: 40Mi 
            requests: 
              cpu: 10m 
              memory: 20Mi 
        patch: 
          enabled: true 
          image: 
            registry: registry.k8s.io                   # registry.k8s.io,webhook官网镜像仓库需要替换成自己镜像所在仓库地址 
            image: ingress-nginx/kube-webhook-certgen   # ingress-nginx/kube-webhook-certgen 
            tag: v1.1.1                                 # v20220916-gd32f8c343 
            pullPolicy: IfNotPresent 
          nodeSelector: 
            kubernetes.io/os: linux 
          securityContext: 
            runAsNonRoot: true 
            runAsUser: 2000 
            fsGroup: 2000 
    defaultBackend: 
      enabled: false # 关闭defaultBackend

    value配置文件注解如下:

    1. 部署多个nginx-ingress场景下,不可重复字段的值需配置不同
    2. 文件中开启admissionWebhooks功能,通过配置admissionwebhook,避免了因配置错误导致ingress-controller不必要的reload。开启此特性后,如需卸载重装ingress-controller,会有webhook对应的secret残留,如果再部署同名的ingress-controller有可能造成controller不可用,需要注意手动清理。
  3. 将ingress-controller部署到指定的命名空间${namespace}

    helm install ingress-nginx-controller -f myvalue.yaml ./ingress-nginx-a -n ${namespace}
  4. 部署多套nginx-ingress重复以上2-3即可

效果展示

查看controller实例是否部署成功

教你几个部署多个nginx-ingress的注意事项_容器_03

ingressclasses资源

教你几个部署多个nginx-ingress的注意事项_nginx-ingress_04

查看访问入口ELB地址

教你几个部署多个nginx-ingress的注意事项_容器_05

创建测试工作负载、service和ingress资源

教你几个部署多个nginx-ingress的注意事项_nginx-ingress_06

访问测试

教你几个部署多个nginx-ingress的注意事项_容器_07

点击关注,第一时间了解华为云新鲜技术~

标签:ingress,name,webhook,nginx,controller,io,注意事项
From: https://blog.51cto.com/u_15214399/8968759

相关文章

  • BOSHIDA DC电源模块有哪些注意事项和使用技巧?
    BOSHIDADC电源模块有哪些注意事项和使用技巧?DC电源模块的注意事项和使用技巧包括以下几点: 1.选择适当的电源模块:根据需要选择合适的电源模块,考虑电压、电流和功率等参数。确保模块能够满足所需的电力要求。2.输入电压范围:注意检查模块的输入电压范围,以确保输入电压在其工......
  • 教你几个部署多个nginx-ingress的注意事项
    本文分享自华为云社区《nginx-ingress工作原理以及多nginx-ingress部署注意事项》,作者:可以交个朋友。一、nginx-ingress工作原理nginx-ingress对应的容器中有两个核心组件:nginx-ingress-controller和nginx。其中nginx-ingress-controller负责list-watchkube-apiserver监听ingr......
  • Nginx 常用配置汇总
    Nginx 是开源、高性能、高可靠的Web和反向代理服务器,而且支持热部署,同时也提供了IMAP/POP3/SMTP服务,可以不间断运行,提供热更新功能。占用内存少、并发能力强,最重要的是,Nginx 是免费的并可以商业化,配置使用都比较简单。Nginx特点高并发、高性能模块化架构使得它的扩展性非常......
  • docker部署nginx服务:
    docker部署nginx服务:dockerrun-d--namenginx-server-v/opt/fuwu/nginx-server:/usr/share/html/index.html:ronginx:latestUnabletofindimage'nginx:latest'locallylatest:Pullingfromlibrary/nginxaf107e978371:Pullcomplete336ba1f05c3e:Pul......
  • Nginx 下将 http 改为 https
    将服务从HTTP变为HTTPS,需要进行SSL证书的配置。需要完成一下步骤:获取SSL证书安装SSL证书配置Nginx支持HTTPS重启NginxHTTP到HTTPS的重定向(可选)1.获取SSL证书(自签名证书)对于SSL/TLS证书,一般来说,它们是基于域名进行颁发的,而不是IP地址。这是因为S......
  • 极速搭建Nginx文件服务器攻略
    目录本地系统安装搭建配置文件有效示例如下注意配置nginx本地认证参考文档问题百宝箱在selinux开启时,访问显示403Forbiden利用Docker容器搭建Nginx文件服务器debian12的apt仓库配置如下在容器内执行如下命令其他本地系统安装搭建Nginx安装包一般都存在于系......
  • nginx:413 Request Entity Too Large
    修改配置文件nginx.conf,根据自己的实际情况修改大小http{client_max_body_size10m;}配置完成后重启nginx参考文章解决413RequestEntityTooLarge(请求实体太大)......
  • centos7安装nginx
    首先安装nginx所需要的第三方库和编译工具# yuminstall-ygccgcc-c++autoconfautomakemake# yuminstallzlibzlib-developensslopenssl-develpcrepcre-develwgethttpd-toolsvim-ynginx官网:https://nginx.org/进入download页面下载稳定版本Stableversion:下......
  • 使用Docker和Nginx部署单页面应用
    使用Docker和Nginx部署单页面应用一、简介1.背景Docker是一个容器引擎,它使用Linux内核功能(如命名空间和控制组)在操作系统之上创建容器DockerCompose是一个命令行工具,可以简化容器镜像的构建以及容器的运行,将命令行的选项翻译成配置文件Nginx是一个高性能的HTTP和反向代理......
  • 通过 Nginx 来实现封杀恶意访问
    安装geoip2扩展依赖[root@fxkj~]#yuminstalllibmaxminddb-devel-y下载ngx_http_geoip2_module模块[root@fxkjtmp]#gitclonehttps://github.com/leev/ngx_http_geoip2_module.git[rotmp]#解压模块到指定路径我这里解压到/usr/local目录下[root@fxkjtmp]#mvngx_h......