使用Istio(1.6.0)的envoy lua过滤器添加自定义响应标头 [英] Adding custom response headers using Istio's (1.6.0) envoy lua filter
问题描述
我正在运行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屋!