使用Istio将流量限制到外部服务
我安装了带Istio的Kubernetes 我试图限制主机的外部流量(例如checkip.amazonaws.com)。这将应用于命名空间中的所有服务(示例中为konta)。所有的吊舱都已经注入了侧车代理 我使用了以下配置,但没有成功使用Istio将流量限制到外部服务,istio,Istio,我安装了带Istio的Kubernetes 我试图限制主机的外部流量(例如checkip.amazonaws.com)。这将应用于命名空间中的所有服务(示例中为konta)。所有的吊舱都已经注入了侧车代理 我使用了以下配置,但没有成功 apiVersion: config.istio.io/v1alpha2 kind: handler metadata: name: quotahandler namespace: konta spec: compiledAdapter: memquo
apiVersion: config.istio.io/v1alpha2
kind: handler
metadata:
name: quotahandler
namespace: konta
spec:
compiledAdapter: memquota
params:
quotas:
- name: requestcountquota.instance.konta
maxAmount: 5
validDuration: 60s
rateLimitAlgorithm: ROLLING_WINDOW
---
apiVersion: config.istio.io/v1alpha2
kind: instance
metadata:
name: requestcountquota
namespace: konta
spec:
compiledTemplate: quota
params:
dimensions:
#source: "unknown"
source: request.headers["x-forwarded-for"] | "unknown"
#destination:
#destination: destination.labels["app"] | destination.service.name | "unknown"
#destinationVersion: destination.labels["version"] | "unknown"
---
apiVersion: config.istio.io/v1alpha2
kind: QuotaSpec
metadata:
name: request-count
namespace: konta
spec:
rules:
- quotas:
- charge: 1
quota: requestcountquota
---
apiVersion: config.istio.io/v1alpha2
kind: QuotaSpecBinding
metadata:
name: request-count
namespace: konta
spec:
quotaSpecs:
- name: request-count
namespace: konta
services:
- service: '*' # Uncomment this to bind *all* services to request-count
---
apiVersion: config.istio.io/v1alpha2
kind: rule
metadata:
name: quota
namespace: konta
spec:
# quota only applies if you are not logged in.
# match: match(request.headers["cookie"], "user=*") == false
match: match(destination.service.host, "checkip.amazonaws.com") == true
actions:
- handler: quotahandler
instances:
- requestcountquota
我正在用一个简单的旋涡吊舱进行测试
kubectl run -i --tty get-ip-address --image=dwdraju/alpine-curl-jq --restart=Never -n konta
及
Obs:我的出口流量没有通过Istio出口网关您是否通过服务入口将
checkip.amazonaws.com
加入Istio mesh?
curl checkip.amazonaws.com