本来想测跨域问题,结果参数配置过去之后一直没生效,经过了解说是gateway才是设置跨域参数的核心,所以需要让流量通过gateway,捣鼓了半天记录一下
第一步,测试服务是否正常
通过get svc、pod等,发现各pod都是正常running状态的,排除没有成功运行
测试服务是否正常运行
kubectl run curl-test --image=curlimages/curl --image-pull-policy=IfNotPresent -it --rm --restart=Never -- /bin/sh
curl 10.244.170.197:8080 # ip是pod的ip,因为我没有特意新建服务
# 正常返回,我的是:Hello World from Python in Kubernetes!
访问gateway,端口是我之前新建集群预留的31309,要了解新建集群看我之前博客,这个端口本来是直接给foo-python这个pod暴露给外部访问的,现在改一改给gateway用
# kubectl edit svc higress-gateway -n higress-systemspec:clusterIP: 10.96.188.48clusterIPs:- 10.96.188.48externalTrafficPolicy: ClusterinternalTrafficPolicy: ClusteripFamilies:- IPv4ipFamilyPolicy: SingleStackports:- name: http2nodePort: 31309 # 修改http协议的端口为31309port: 80protocol: TCPtargetPort: 80- name: httpsnodePort: 31720port: 443protocol: TCPtargetPort: 443
创建higress转发规则
[root@localhost foo]# cat foo-python-ingress.yaml
# foo-python-ingress.yaml
apiVersion: networking.k8s.io/v1
kind: Ingress
metadata:name: foo-python-ingressannotations:higress.io/backend-protocol: "HTTP" # 明确后端协议higress.io/path-case-sensitive: "false"
spec:ingressClassName: higress # 明确指定使用 Higress的控制器,别用上nginx或者别的rules:- host: foo.local # 必须与curl测试的Host头一致http:paths:- path: /pathType: Prefixbackend:service:name: foo-pythonport: number: 8080 # 必须等于Service的port字段,我原本是写的80,后面发现搞错了端口查了半天,这个端口是我的python脚本里面写的
kubectl apply -f foo-python-ingress.yaml
测试:
# 转发到foo服务的情况
[root@localhost foo]# curl -v -H "Host: foo.local" http://192.168.64.20:31309/
* Trying 192.168.64.20:31309...
* Connected to 192.168.64.20 (192.168.64.20) port 31309 (#0)
> GET / HTTP/1.1
> Host: foo.local
> User-Agent: curl/7.76.1
> Accept: */*
>
* Mark bundle as not supporting multiuse
< HTTP/1.1 200 OK
< server: istio-envoy
< date: Mon, 28 Apr 2025 19:42:15 GMT
< content-type: text/html; charset=utf-8
< content-length: 39
< req-cost-time: 2
< req-arrive-time: 1745869335017
< resp-start-time: 1745869335020
< x-envoy-upstream-service-time: 1
<
Hello World from Python in Kubernetes!
* Connection #0 to host 192.168.64.20 left intact# 不转发到foo服务的情况
[root@localhost foo]# curl http://192.168.64.20:31309/
<!DOCTYPE html>
<html>
<head><title>Welcome to Higress!</title><style>html {background-color: #121316;color: rgb(235, 236, 239);}body {width: 35em;margin: 0 auto;font-family: Tahoma, Verdana, Arial, sans-serif;}a:visited, a:hover, a:active {color: #f0f0f0;}</style>
</head>
<body>
<h1>Thanks for using Higress!</h1>
<p>Higress is successfully installed and is functioning properly.Higress Console is available for further configuration.
</p>
<p>For online documentation, please visit <a href="https://higress.cn/" target="_blank">higress.cn</a>or <a href="https://github.com/alibaba/higress" target="_blank">alibaba/higress on GitHub</a>.
</p>
<p><em>Happy Higressing!</em></p>
<p style="text-align: center"><a href="https://github.com/alibaba/higress" target="_blank"><img alt="Higress" style="width: 100px; margin-top: 20px"src=""></a>
</p>
</body>
</html>
(reverse-i-search)`svc ': kubectl get ^Cc -n higress-system higress-gateway