日本熟妇hd丰满老熟妇,中文字幕一区二区三区在线不卡 ,亚洲成片在线观看,免费女同在线一区二区

通過Nginx Ingress對多個應用進行HPA

多實例部署可以最大程度的保證應用的穩定性,但同時也會造成閑時資源的浪費和高額成本。手動調節方式工作量大還存在一定程度的滯后性。通過Nginx Ingress對多個應用進行HPA,可以自動根據應用的負載情況動態調整Pod副本數量,從而在保障應用穩定性和響應能力的同時,優化資源使用,降低成本。本文介紹通過Nginx Ingress對多個應用進行HPA的方法。

前提條件

通過Nginx Ingress對多個應用進行HPA前,需要將阿里云Prometheus指標轉換成HPA可用的指標,您需要部署相關組件。

背景信息

在實際的生產中,您使用請求量來自動擴縮容時,可以通過注冊http_requests_total來透出請求量指標,同時推薦使用Ingress組件自帶的指標來進行HPA。

Ingress是Kubernetes API中的標準資源類型之一。Ingress實現的功能是將客戶端請求的Host名稱或請求的URL路徑,轉發到指定的Service資源中,即將Kubernetes集群外部的請求轉發至集群內部的Service中,再被Service轉發至Pod,處理客戶端的請求。

Nginx Ingress Controller是部署于集群內部的Ingress控制器,可以為您提供性能更好,且定制性更高的使用方式。ACK集群提供的Nginx Ingress Controller在社區版本的基礎上,整合了阿里云產品的一系列功能,提供了更加便捷的使用體驗。

操作步驟

本教程包含兩個ClusterIP型服務,通過Nginx Ingress實現對外的流量路由。基于nginx_ingress_controller_requests指標,為應用配置HPA,以實現隨著流量的變化為Pod擴縮容的功能。

  1. 使用以下YAML文件創建業務Deployment和對應的Service。

    1. 創建nginx1.yaml文件。然后執行命令kubectl apply -f nginx1.yaml,創建應用test-app和對應的Service。

      apiVersion: apps/v1
      kind: Deployment
      metadata:
        name: test-app
        labels:
          app: test-app
      spec:
        replicas: 1
        selector:
          matchLabels:
            app: test-app
        template:
          metadata:
            labels:
              app: test-app
          spec:
            containers:
            - image: skto/sample-app:v2
              name: metrics-provider
              ports:
              - name: http
                containerPort: 8080
      ---
      apiVersion: v1
      kind: Service
      metadata:
        name: test-app
        namespace: default
        labels:
          app: test-app
      spec:
        ports:
          - port: 8080
            name: http
            protocol: TCP
            targetPort: 8080
        selector:
          app: test-app
        type: ClusterIP
    2. 創建nginx2.yaml文件。然后執行命令kubectl apply -f nginx2.yaml,創建應用sample-app和對應的Service。

      apiVersion: apps/v1
      kind: Deployment
      metadata:
        name: sample-app
        labels:
          app: sample-app
      spec:
        replicas: 1
        selector:
          matchLabels:
            app: sample-app
        template:
          metadata:
            labels:
              app: sample-app
          spec:
            containers:
            - image: skto/sample-app:v2
              name: metrics-provider
              ports:
              - name: http
                containerPort: 8080
      ---
      apiVersion: v1
      kind: Service
      metadata:
        name: sample-app
        namespace: default
        labels:
          app: sample-app
      spec:
        ports:
          - port: 80
            name: http
            protocol: TCP
            targetPort: 8080
        selector:
          app: sample-app
        type: ClusterIP
  2. 創建ingress.yaml文件。然后執行kubectl apply -f ingress.yaml命令,部署Ingress資源。

    apiVersion: networking.k8s.io/v1
    kind: Ingress
    metadata:
      name: test-ingress
      namespace: default
    spec:
      ingressClassName: nginx
      rules:
        - host: test.example.com
          http:
            paths:
              - backend:
                  service:
                    name: sample-app
                    port:
                      number: 80
                path: /
                pathType: ImplementationSpecific
              - backend:
                  service:
                    name: test-app
                    port:
                      number: 8080
                path: /home
                pathType: ImplementationSpecific
    • host:指定服務訪問域名。本示例使用test.example.com

    • path:指定訪問的URL路徑。請求到來之后會根據路由規則匹配相應的Service,然后通過Service訪問相應的Pod。

    • backend:由Service名稱和Service端口組成,指定當前path轉發的Service。

  3. 執行以下命令,獲取Ingress資源。

    kubectl get ingress -o wide

    預期輸出:

    NAME           CLASS   HOSTS              ADDRESS       PORTS   AGE                                                  
    test-ingress   nginx   test.example.com   10.10.10.10   80      55s
  4. 部署成功后,可以通過//home兩個路徑分別訪問Host地址。Nginx Ingress Controller會根據上方配置分別訪問sample-app和test-app。通過阿里云Prometheus查詢指標nginx_ingress_controller_requests,可以獲取各應用的請求情況。

  5. 修改組件alibaba-cloud-metrics-adapter中的adapter.config文件,將Prometheus中的指標轉換成HPA可用的指標。

    說明

    在進行本步驟前,請確保已完成了組件alibaba-cloud-metrics-adapter的部署和prometheus.url的配置。

    1. 登錄容器服務管理控制臺,在左側導航欄選擇集群

    2. 集群列表頁面,單擊目標集群名稱,然后在左側導航欄,選擇應用 > Helm

    3. 單擊ack-alibaba-cloud-metrics-adapter

    4. 資源區域,單擊adapter-config

    5. adapter-config頁面,單擊頁面右上角的YAML 編輯

    6. 用以下代碼替換中的代碼,然后單擊頁面下方的確定

      關于以下配置項詳解,請參考基于阿里云Prometheus指標的容器水平伸縮

      rules:
      - metricsQuery: sum(rate(<<.Series>>{<<.LabelMatchers>>}[2m]))
        name:
          as: ${1}_per_second
          matches: ^(.*)_requests
        resources:
          namespaced: false
          overrides:
            controller_namespace:
              resource: namespace
        seriesQuery: nginx_ingress_controller_requests
  6. 執行以下命令,查看指標輸出。

    kubectl get --raw "/apis/external.metrics.k8s.io/v1beta1/namespaces/*/nginx_ingress_controller_per_second" | jq .

    查詢指標結果如下:

    {
      "kind": "ExternalMetricValueList",
      "apiVersion": "external.metrics.k8s.io/v1beta1",
      "metadata": {},
      "items": [
        {
          "metricName": "nginx_ingress_controller_per_second",
          "metricLabels": {},
          "timestamp": "2022-03-31T10:11:37Z",
          "value": "0"
        }
      ]
    }
  7. 創建hpa.yaml文件。然后執行kubectl apply -f hpa.yaml命令,對業務應用sample-app和test-app分別部署HPA。

    apiVersion: autoscaling/v2beta2
    kind: HorizontalPodAutoscaler
    metadata:
      name: sample-hpa
    spec:
      scaleTargetRef:
        apiVersion: apps/v1
        kind: Deployment
        name: sample-app
      minReplicas: 1
      maxReplicas: 10
      metrics:
        - type: External
          external:
            metric:
              name: nginx_ingress_controller_per_second
              selector:
                matchLabels:
    #可以通過這個字段對指標進行過濾,這里設置的字段會傳入adapter.config中的<<.LabelMatchers>>標簽。
                  service: sample-app
    #External指標類型下只支持Value和AverageValue類型的目標值。
            target:
              type: AverageValue
              averageValue: 30
    ----------
    apiVersion: autoscaling/v2beta2
    kind: HorizontalPodAutoscaler
    metadata:
      name: test-hpa
    spec:
      scaleTargetRef:
        apiVersion: apps/v1
        kind: Deployment
        name: test-app
      minReplicas: 1
      maxReplicas: 10
      metrics:
        - type: External
          external:
            metric:
              name: nginx_ingress_controller_per_second
              selector:
                matchLabels:
    #可以通過這個字段對指標進行過濾,這里設置的字段會傳入adapter.config中的<<.LabelMatchers>>標簽。
                  service: test-app
    #External指標類型下只支持Value和AverageValue類型的目標值。
            target:
              type: AverageValue
              averageValue: 30
  8. 執行以下命令,查看HPA部署情況。

    kubectl get hpa

    預期輸出:

    NAME         REFERENCE               TARGETS       MINPODS   MAXPODS   REPLICAS   AGE
    sample-hpa   Deployment/sample-app   0/30 (avg)   1         10        1          74s
    test-hpa     Deployment/test-app     0/30 (avg)   1         10        1          59m
  9. HPA部署成功后,進行壓測實驗,觀察業務應用是否會隨著請求增大而擴容。

    1. 執行以下命令,對Host下的/home路徑進行壓測。

      ab -c 50 -n 5000 test.example.com/home
    2. 執行以下命令,查看HPA情況。

      kubectl get hpa

      預期輸出:

      NAME         REFERENCE               TARGETS           MINPODS   MAXPODS   REPLICAS   AGE
      sample-hpa   Deployment/sample-app   0/30 (avg)        1         10        1          22m
      test-hpa     Deployment/test-app     22096m/30 (avg)   1         10        3          80m
    3. 執行以下命令,對Host的根路徑進行壓測。

      ab -c 50 -n 5000 test.example.com/
    4. 執行以下命令,查看HPA情況。

      kubectl get hpa

      預期輸出:

      NAME         REFERENCE               TARGETS           MINPODS   MAXPODS   REPLICAS   AGE
      sample-hpa   Deployment/sample-app   27778m/30 (avg)   1         10        2          38m
      test-hpa     Deployment/test-app     0/30 (avg)        1         10        1          96m

      從上述結果可以看到,業務應用在請求量增大超過閾值的情況下成功擴容。

相關文檔

  • 多可用區均衡是數據類型業務在高可用場景下常用的部署方式。當業務壓力增大時,有多可用區均衡調度策略的應用希望可以自動擴容出多個可用區的實例來滿足集群的調度水位。詳細信息,請參見多可用區同時快速彈性擴容

  • 構建自定義操作系統鏡像以提高復雜場景下彈性伸縮的便捷性,請參見彈性優化之自定義鏡像