我想知道,对于某个入口正确配置了哪些端点。
例如,我有以下入口:
apiVersion: extensions/v1beta1
kind: Ingress
metadata:
name: dictionary
spec:
tls:
- hosts:
- dictionary.juan.com
secretName: microsyn-secret
backend:
serviceName: microsyn
servicePort: 8080
rules:
- host: dictionary.juan.com
http:
paths:
- path: /synonyms/*
backend:
serviceName: microsyn
servicePort: 8080
正在使用以下服务:
apiVersion: v1
kind: Service
metadata:
name: microsyn
spec:
ports:
- port: 8080
targetPort: 8080
protocol: TCP
name: http
selector:
app: microsyn
此服务正在公开此部署:
apiVersion: extensions/v1beta1
kind: Deployment
metadata:
name: microsyn
spec:
replicas: 1
selector:
matchLabels:
app: microsyn
template:
metadata:
labels:
app: microsyn
spec:
containers:
- name: microsyn
image: microsynonyms
imagePullPolicy: Never
ports:
- containerPort: 8080
该应用程序是一个侦听端口8080的nodejs应用程序,它在我刚刚在本地创建的docker映像中为路径“ /”打招呼,这就是它具有imagePullPolicy的原因:从不,它仅用于测试目的和学习如何创建一个入口。
因此,我从nginx-ingress创建了入口,并且该入口已启动并正在使用Nodeport进行本地环境测试,之后,我将其带入带有负载均衡器的部署中:
https://github.com/nginxinc/kubernetes-ingress/tree/master/examples/complete-example
所以我执行以下操作:
minikube service list
|---------------|----------------------|--------------------------------|
| NAMESPACE | NAME | URL |
|---------------|----------------------|--------------------------------|
| default | kubernetes | No node port |
| default | microsyn | No node port |
| kube-system | default-http-backend | http://192.168.99.100:30001 |
| kube-system | kube-dns | No node port |
| kube-system | kubernetes-dashboard | http://192.168.99.100:30000 |
| nginx-ingress | nginx-ingress | http://192.168.99.100:31253 |
| | | http://192.168.99.100:31229 |
|---------------|----------------------|--------------------------------|
我能做到的出色:
curl http://192.168.99.100:31253/synonyms
但是我得到一个:
<html>
<head><title>404 Not Found</title></head>
<body bgcolor="white">
<center><h1>404 Not Found</h1></center>
<hr><center>nginx/1.15.2</center>
</body>
</html>
所以我唯一的Nginx是这个minikube中的一个,它工作正常。但是我看不到为此入口配置了哪些端点...
我看到以下日志:
2018/08/11 16:07:05 [notice] 117#117: signal process started
I0811 16:07:05.313037 1 event.go:218] Event(v1.ObjectReference{Kind:"Ingress", Namespace:"default", Name:"dictionary", UID:"9728e826-9d80-11e8-9caa-0800270091d8", APIVersion:"extensions", ResourceVersion:"57014", FieldPath:""}): type: 'Normal' reason: 'AddedOrUpdated' Configuration for default/dictionary was added or updated
W0811 16:15:05.826537 1 reflector.go:341] github.com/nginxinc/kubernetes-ingress/nginx-controller/controller/controller.go:413: watch of *v1.ConfigMap ended with: too old resource version: 56348 (56655)
因此,这意味着字典入口已被正确处理。
但是那为什么我会得到404?
在哪里可以看到为此入口配置的端点?
我想运行一个命令,它显示nginx->您正在侦听哪些端点?
答案 0 :(得分:1)
但是那为什么我会得到404?
入口资源-或肯定是您在问题中显示的资源-使用虚拟主机路由,因此在与该URL交互时必须设置host:
标头:
curl -H 'host: dictionary.juan.com' http://192.168.99.100:31253/synonyms/something
我将不得不查询path:
语法以了解/synonyms/*
是否与/synonyms
匹配,这就是为什么我在curl
中包含斜杠和多余内容的原因。
要以非curl
的方式与其交互,您可以将host:
中的Ingress
临时更改为192.168.99.100或使用dnsmasq创建一个本地名称服务器,您可以在其中重写dictionary.juan.com
以始终返回192.168.99.100
,然后Chrome会自行发送正确的host:
标头。
在哪里可以看到为此入口配置的端点?
这个问题有点不准确,因为Endpoint
是一种正式资源,与Ingress
无关,但是答案是:
kubectl get endpoints microsyn
我想运行一个命令,它显示nginx->您正在侦听哪些端点?
首先,查找nginx-ingress Pod的名称(如果有多个,则其中的任何一个都应该执行),然后查看Pod中的nginx.conf
,以确切了解其已转换的规则将Ingress
资源放入:
kubectl exec $ingress_pod cat /etc/nginx/nginx.conf