使用Istio(1.6.0)的envoy lua过滤器添加自定义响应标头 [英] Adding custom response headers using Istio's (1.6.0) envoy lua filter

查看:965
本文介绍了使用Istio(1.6.0)的envoy lua过滤器添加自定义响应标头的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我正在运行Istio 1.6.0. 我想向源自我的服务的所有出站响应添加一些自定义标头.因此,我试图使用lua envoyfilter 来实现这一目标.但是,我看不到代理配置正确.

I am running Istio 1.6.0. I wanted to add some custom headers to all the outbound responses originating from my service. So I was trying to use lua envoyfilter to achieve that. However, I don't see my proxy getting properly configured.

我要使用的特使过滤器配置是

The envoy filter config that I'm trying to use is

kind: EnvoyFilter
metadata:
  name: lua-filter
  namespace: istio-system
spec:
  workloadSelector:
    labels:
      istio: ingressgateway
  configPatches:
  - applyTo: HTTP_FILTER
    match:
      context: GATEWAY
      listener:
        filterChain:
          filter:
            name: "envoy.http_connection_manager"
            subFilter:
              name: "envoy.router"
    patch:
      operation: INSERT_BEFORE
      value:
       name: envoy.lua
       typed_config:
         "@type": "type.googleapis.com/envoy.config.filter.http.lua.v2.Lua"
         inlineCode: |
            function envoy_on_response(response_handle)
                response_handle:logInfo(" ========= XXXXX ========== ")
                response_handle:headers():add("X-User-Header", "worked")
            end

我的入口网关Pod确实在istio-system名称空间中运行

I do have my ingress-gateway pods running in the istio-system namespace

❯ kgp -l istio=ingressgateway -n istio-system
NAME                              READY   STATUS    RESTARTS   AGE
ingress-gateway-b4b5cffc9-wz75r   1/1     Running   0          3d12h
ingress-gateway-b4b5cffc9-znx9b   1/1     Running   0          28h

我希望在卷曲服务时会看到X-User-Header. 不幸的是,我没有看到任何自定义标题.

I was hoping that I would see X-User-Header when I curl for my service. Unfortunately, I'm not seeing any custom headers.

我尝试检查istio系统中入口网关Pod的proxy-configs,但我完全看不到envoy.lua的配置.我不确定是否调试正确.

I tried checking the proxy-configs of the ingress-gateway pod in the istio-system, and I don't see the envoy.lua configured at all. I'm not sure whether I'm debugging it correctly.

 istioctl proxy-config listener ingress-gateway-b4b5cffc9-wz75r.istio-system  -n istio-system --port 443 -o json | grep "name"
        "name": "0.0.0.0_443",
                        "name": "istio.stats",
                        "name": "envoy.tcp_proxy",
                        "name": "istio.stats",
                        "name": "envoy.tcp_proxy",
                "name": "envoy.listener.tls_inspector",

请让我知道我缺少什么或配置错误. 关于如何进一步调试的任何建议也将非常有帮助.

Please let me know what is that I'm missing or incorrectly configured. Any advice on how to debug further also would be really helpful.

非常感谢您.

推荐答案

据我检查版本1.6.3和1.6.4的istio群集时,您的示例运行正常.看看下面来自我集群的代码.

As far as I checked on my istio cluster with version 1.6.3 and 1.6.4 your example works just fine. Take a look at below code from my cluster.

我用卷发检查了

$ curl -s -I -X HEAD x.x.x.x/
HTTP/1.1 200 OK
server: istio-envoy
date: Mon, 06 Jul 2020 08:35:37 GMT
content-type: text/html
content-length: 13
last-modified: Thu, 02 Jul 2020 12:11:16 GMT
etag: "5efdcee4-d"
accept-ranges: bytes
x-envoy-upstream-service-time: 2
x-user-header: worked

AND

我在istio入口网关容器中使用config_dump对其进行了检查.

I checked it with config_dump in istio ingress-gateway pod.

我在那里执行

kubectl exec -ti istio-ingressgateway-78db9f457d-xfhl7  -n istio-system -- /bin/bash 

config_dump的结果

Results from config_dump

curl 0:15000/config_dump | grep X-User-Header
  % Total    % Received % Xferd  Average Speed   Time    Time     Time  Current
                                 Dload  Upload   Total   Spent    Left  Speed
100  128k    0  128k    0     0  9162k      0 --:--:-- --:--:-- --:--:-- 9162k
               "inline_code": "function envoy_on_response(response_handle)\n    response_handle:logInfo(\" ========= XXXXX ========== \")\n    response_handle:headers():add(\"X-User-Header\", \"worked\")\nend\n"

因此,您可以看到它起作用了,将标头添加到请求中,并且该功能在istio入口网关中处于活动状态.

So as you can see it works, header is added to request and function is active in istio ingress gateway.

您能否尝试再次检查上述弯曲度,检查istio ingress-gateway tcp_dump并让我知道它是否对您有用?

Could you try to check it again with above curl, check istio ingress-gateway tcp_dump and let me know if it works for you?

这篇关于使用Istio(1.6.0)的envoy lua过滤器添加自定义响应标头的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆