Qatzip 壓縮器

Qatzip 壓縮器透過整合 qatlib 和 QATzip 函式庫,為 Envoy 提供更快速的硬體加速 gzip 壓縮,並與 Intel® QuickAssist Technology (Intel® QAT) 介接。

範例組態

Qatzip 壓縮器組態的範例如下:

static_resources:
  listeners:
  - address:
      socket_address:
        address: 0.0.0.0
        port_value: 10000
    filter_chains:
    - filters:
      - name: envoy.filters.network.http_connection_manager
        typed_config:
          "@type": type.googleapis.com/envoy.extensions.filters.network.http_connection_manager.v3.HttpConnectionManager
          stat_prefix: ingress_http
          route_config:
            name: local_route
            virtual_hosts:
            - name: backend
              domains:
              - "*"
              routes:
              - match:
                  prefix: "/"
                route:
                  cluster: service
          http_filters:
          - name: envoy.filters.http.compressor
            typed_config:
              "@type": type.googleapis.com/envoy.extensions.filters.http.compressor.v3.Compressor
              response_direction_config:
                common_config:
                  min_content_length: 100
                  content_type:
                  - application/octet-stream
              compressor_library:
                name: qatzip
                typed_config:
                  "@type": type.googleapis.com/envoy.extensions.compression.qatzip.compressor.v3alpha.Qatzip
                  compression_level: 3
          - name: envoy.filters.http.router
            typed_config:
              "@type": type.googleapis.com/envoy.extensions.filters.http.router.v3.Router

  clusters:
  - name: service
    connect_timeout: 0.25s
    type: STRICT_DNS
    lb_policy: ROUND_ROBIN
    load_assignment:
      cluster_name: service
      endpoints:
      - lb_endpoints:
        - endpoint:
            address:
              socket_address:
                address: 127.0.0.1
                port_value: 1234
admin:
  address:
    socket_address:
      address: 0.0.0.0
      port_value: 9901

運作方式

若啟用,Qatzip 壓縮器將會:

  • 附加 Qat 硬體

  • 為每個工作執行緒建立 Threadlocal Qat 會期上下文

當新的 HTTP 請求進入時,一個工作執行緒將使用其 Qat 會期上下文處理該請求,並將需要壓縮的資料傳送到 Qat 硬體。

安裝與使用 QATzip

關於如何建置/安裝及使用 QATzip 的資訊,請參閱 QATzip