Ingress 每隔几秒就进行一次健康检查就绪探测
Ingress is healthchecking readiness probe every few seconds
我的入口、服务和部署:
apiVersion: extensions/v1beta1
kind: Ingress
metadata:
name: my-ingress
annotations:
kubernetes.io/ingress.global-static-ip-name: my-ip
networking.gke.io/managed-certificates: my-certificate
spec:
backend:
serviceName: my-api-nodeport
servicePort: 80
---
apiVersion: cloud.google.com/v1beta1
kind: BackendConfig
metadata:
name: my-api-backendconfig
spec:
timeoutSec: 43200
---
apiVersion: v1
kind: Service
metadata:
name: my-api-nodeport
annotations:
beta.cloud.google.com/backend-config: '{"ports": {"80":"my-api-backendconfig"}}'
spec:
type: NodePort
selector:
app: my-api
ports:
- port: 80
targetPort: 80
---
apiVersion: apps/v1
kind: Deployment
metadata:
name: my-api
spec:
replicas: 1
selector:
matchLabels:
app: my-api
template:
metadata:
labels:
app: my-api
spec:
containers:
- name: my-api
image: gcr.io/acme/api
readinessProbe:
httpGet:
path: /readinessProbe
port: 80
env:
...
ports:
- name: http
containerPort: 80
- name: https
containerPort: 443
根据 GKE UI,Ingress 健康检查间隔为 70 秒。但是在实践中,我在部署到就绪探测器时看到了很多日志,大约每隔几秒。
2019-12-08 08:42:11 [INFO] Microsoft.AspNetCore.Hosting.Diagnostics: Request starting HTTP/1.1 GET http://10.16.62.83:80/readinessProbe
2019-12-08 08:42:11 [INFO] Microsoft.AspNetCore.Hosting.Diagnostics: Request finished in 0.1037ms 200
2019-12-08 08:42:16 [INFO] Microsoft.AspNetCore.Hosting.Diagnostics: Request starting HTTP/1.1 GET http://10.128.15.222/readinessProbe
2019-12-08 08:42:16 [INFO] Microsoft.AspNetCore.Hosting.Diagnostics: Request finished in 0.11610000000000001ms 200
2019-12-08 08:42:18 [INFO] Microsoft.AspNetCore.Hosting.Diagnostics: Request starting HTTP/1.1 GET http://10.128.15.222/readinessProbe
2019-12-08 08:42:18 [INFO] Microsoft.AspNetCore.Hosting.Diagnostics: Request finished in 0.10880000000000001ms 200
2019-12-08 08:42:19 [INFO] Microsoft.AspNetCore.Hosting.Diagnostics: Request starting HTTP/1.1 GET http://10.128.15.222/readinessProbe
2019-12-08 08:42:19 [INFO] Microsoft.AspNetCore.Hosting.Diagnostics: Request finished in 0.10790000000000001ms 200
2019-12-08 08:42:21 [INFO] Microsoft.AspNetCore.Hosting.Diagnostics: Request starting HTTP/1.1 GET http://10.16.62.83:80/readinessProbe
2019-12-08 08:42:21 [INFO] Microsoft.AspNetCore.Hosting.Diagnostics: Request finished in 0.14730000000000001ms 200
2019-12-08 08:42:27 [INFO] Microsoft.AspNetCore.Hosting.Diagnostics: Request starting HTTP/1.1 GET http://10.128.0.23/readinessProbe
2019-12-08 08:42:27 [INFO] Microsoft.AspNetCore.Hosting.Diagnostics: Request finished in 0.12040000000000001ms 200
2019-12-08 08:42:27 [INFO] Microsoft.AspNetCore.Hosting.Diagnostics: Request starting HTTP/1.1 GET http://10.128.0.23/readinessProbe
2019-12-08 08:42:27 [INFO] Microsoft.AspNetCore.Hosting.Diagnostics: Request finished in 0.1153ms 200
2019-12-08 08:42:28 [INFO] Microsoft.AspNetCore.Hosting.Diagnostics: Request starting HTTP/1.1 GET http://10.128.0.23/readinessProbe
2019-12-08 08:42:28 [INFO] Microsoft.AspNetCore.Hosting.Diagnostics: Request finished in 0.1563ms 200
2019-12-08 08:42:31 [INFO] Microsoft.AspNetCore.Hosting.Diagnostics: Request starting HTTP/1.1 GET http://10.16.62.83:80/readinessProbe
2019-12-08 08:42:31 [INFO] Microsoft.AspNetCore.Hosting.Diagnostics: Request finished in 0.11900000000000001ms 200
2019-12-08 08:42:36 [INFO] Microsoft.AspNetCore.Hosting.Diagnostics: Request starting HTTP/1.1 GET http://10.128.15.195/readinessProbe
2019-12-08 08:42:36 [INFO] Microsoft.AspNetCore.Hosting.Diagnostics: Request finished in 0.113ms 200
2019-12-08 08:42:36 [INFO] Microsoft.AspNetCore.Hosting.Diagnostics: Request starting HTTP/1.1 GET http://10.128.15.195/readinessProbe
2019-12-08 08:42:36 [INFO] Microsoft.AspNetCore.Hosting.Diagnostics: Request finished in 0.1153ms 200
2019-12-08 08:42:38 [INFO] Microsoft.AspNetCore.Hosting.Diagnostics: Request starting HTTP/1.1 GET http://10.128.15.195/readinessProbe
2019-12-08 08:42:38 [INFO] Microsoft.AspNetCore.Hosting.Diagnostics: Request finished in 0.1208ms 200
2019-12-08 08:42:41 [INFO] Microsoft.AspNetCore.Hosting.Diagnostics: Request starting HTTP/1.1 GET http://10.16.62.83:80/readinessProbe
2019-12-08 08:42:41 [INFO] Microsoft.AspNetCore.Hosting.Diagnostics: Request finished in 0.10600000000000001ms 200
我可以将间隔配置为较低的速率吗?
您可以按如下方式配置就绪探测器
readinessProbe:
exec:
command:
- cat
- /tmp/healthy
initialDelaySeconds: 5
periodSeconds: 5
请参阅 link https://kubernetes.io/docs/tasks/configure-pod-container/configure-liveness-readiness-startup-probes/ 以获取更多帮助。
我的入口、服务和部署:
apiVersion: extensions/v1beta1
kind: Ingress
metadata:
name: my-ingress
annotations:
kubernetes.io/ingress.global-static-ip-name: my-ip
networking.gke.io/managed-certificates: my-certificate
spec:
backend:
serviceName: my-api-nodeport
servicePort: 80
---
apiVersion: cloud.google.com/v1beta1
kind: BackendConfig
metadata:
name: my-api-backendconfig
spec:
timeoutSec: 43200
---
apiVersion: v1
kind: Service
metadata:
name: my-api-nodeport
annotations:
beta.cloud.google.com/backend-config: '{"ports": {"80":"my-api-backendconfig"}}'
spec:
type: NodePort
selector:
app: my-api
ports:
- port: 80
targetPort: 80
---
apiVersion: apps/v1
kind: Deployment
metadata:
name: my-api
spec:
replicas: 1
selector:
matchLabels:
app: my-api
template:
metadata:
labels:
app: my-api
spec:
containers:
- name: my-api
image: gcr.io/acme/api
readinessProbe:
httpGet:
path: /readinessProbe
port: 80
env:
...
ports:
- name: http
containerPort: 80
- name: https
containerPort: 443
根据 GKE UI,Ingress 健康检查间隔为 70 秒。但是在实践中,我在部署到就绪探测器时看到了很多日志,大约每隔几秒。
2019-12-08 08:42:11 [INFO] Microsoft.AspNetCore.Hosting.Diagnostics: Request starting HTTP/1.1 GET http://10.16.62.83:80/readinessProbe
2019-12-08 08:42:11 [INFO] Microsoft.AspNetCore.Hosting.Diagnostics: Request finished in 0.1037ms 200
2019-12-08 08:42:16 [INFO] Microsoft.AspNetCore.Hosting.Diagnostics: Request starting HTTP/1.1 GET http://10.128.15.222/readinessProbe
2019-12-08 08:42:16 [INFO] Microsoft.AspNetCore.Hosting.Diagnostics: Request finished in 0.11610000000000001ms 200
2019-12-08 08:42:18 [INFO] Microsoft.AspNetCore.Hosting.Diagnostics: Request starting HTTP/1.1 GET http://10.128.15.222/readinessProbe
2019-12-08 08:42:18 [INFO] Microsoft.AspNetCore.Hosting.Diagnostics: Request finished in 0.10880000000000001ms 200
2019-12-08 08:42:19 [INFO] Microsoft.AspNetCore.Hosting.Diagnostics: Request starting HTTP/1.1 GET http://10.128.15.222/readinessProbe
2019-12-08 08:42:19 [INFO] Microsoft.AspNetCore.Hosting.Diagnostics: Request finished in 0.10790000000000001ms 200
2019-12-08 08:42:21 [INFO] Microsoft.AspNetCore.Hosting.Diagnostics: Request starting HTTP/1.1 GET http://10.16.62.83:80/readinessProbe
2019-12-08 08:42:21 [INFO] Microsoft.AspNetCore.Hosting.Diagnostics: Request finished in 0.14730000000000001ms 200
2019-12-08 08:42:27 [INFO] Microsoft.AspNetCore.Hosting.Diagnostics: Request starting HTTP/1.1 GET http://10.128.0.23/readinessProbe
2019-12-08 08:42:27 [INFO] Microsoft.AspNetCore.Hosting.Diagnostics: Request finished in 0.12040000000000001ms 200
2019-12-08 08:42:27 [INFO] Microsoft.AspNetCore.Hosting.Diagnostics: Request starting HTTP/1.1 GET http://10.128.0.23/readinessProbe
2019-12-08 08:42:27 [INFO] Microsoft.AspNetCore.Hosting.Diagnostics: Request finished in 0.1153ms 200
2019-12-08 08:42:28 [INFO] Microsoft.AspNetCore.Hosting.Diagnostics: Request starting HTTP/1.1 GET http://10.128.0.23/readinessProbe
2019-12-08 08:42:28 [INFO] Microsoft.AspNetCore.Hosting.Diagnostics: Request finished in 0.1563ms 200
2019-12-08 08:42:31 [INFO] Microsoft.AspNetCore.Hosting.Diagnostics: Request starting HTTP/1.1 GET http://10.16.62.83:80/readinessProbe
2019-12-08 08:42:31 [INFO] Microsoft.AspNetCore.Hosting.Diagnostics: Request finished in 0.11900000000000001ms 200
2019-12-08 08:42:36 [INFO] Microsoft.AspNetCore.Hosting.Diagnostics: Request starting HTTP/1.1 GET http://10.128.15.195/readinessProbe
2019-12-08 08:42:36 [INFO] Microsoft.AspNetCore.Hosting.Diagnostics: Request finished in 0.113ms 200
2019-12-08 08:42:36 [INFO] Microsoft.AspNetCore.Hosting.Diagnostics: Request starting HTTP/1.1 GET http://10.128.15.195/readinessProbe
2019-12-08 08:42:36 [INFO] Microsoft.AspNetCore.Hosting.Diagnostics: Request finished in 0.1153ms 200
2019-12-08 08:42:38 [INFO] Microsoft.AspNetCore.Hosting.Diagnostics: Request starting HTTP/1.1 GET http://10.128.15.195/readinessProbe
2019-12-08 08:42:38 [INFO] Microsoft.AspNetCore.Hosting.Diagnostics: Request finished in 0.1208ms 200
2019-12-08 08:42:41 [INFO] Microsoft.AspNetCore.Hosting.Diagnostics: Request starting HTTP/1.1 GET http://10.16.62.83:80/readinessProbe
2019-12-08 08:42:41 [INFO] Microsoft.AspNetCore.Hosting.Diagnostics: Request finished in 0.10600000000000001ms 200
我可以将间隔配置为较低的速率吗?
您可以按如下方式配置就绪探测器
readinessProbe:
exec:
command:
- cat
- /tmp/healthy
initialDelaySeconds: 5
periodSeconds: 5
请参阅 link https://kubernetes.io/docs/tasks/configure-pod-container/configure-liveness-readiness-startup-probes/ 以获取更多帮助。