如何解决如何在 minikube 中启动和访问服务
我在 minikube 中部署了一个网络应用。
部署:
apiVersion: apps/v1
kind: Deployment
metadata:
name: myapp
spec:
replicas: 3
selector:
matchLabels:
app: maypp
template:
metadata:
labels:
app: myapp
spec:
containers:
- name: myapp
image: myapp
imagePullPolicy: Never
ports:
- containerPort: 8080
restartPolicy: Always
服务:
apiVersion: v1
kind: Service
metadata:
name: myservice
spec:
type: NodePort
ports:
- port: 8080
在 kubectl apply -f .
部署后,它们都在运行。
kubectl get po
NAMESPACE NAME READY STATUS RESTARTS AGE
default myapp-5d042b65c8-h7kag 1/1 Running 0 10m
kubectl get svc
NAMESPACE NAME TYPE CLUSTER-IP EXTERNAL-IP PORT(S) AGE
default myservice NodePort 10.102.128.35 <none> 8080:32212/TCP 10m
运行 minikube service
在浏览器中打开服务:
minikube service myservice
|----------------|--------------------|-------------|---------------------------|
| NAMESPACE | NAME | TARGET PORT | URL |
|----------------|--------------------|-------------|---------------------------|
| default | myservice | 8080 | http://192.168.49.2:32212 |
|----------------|--------------------|-------------|---------------------------|
? Starting tunnel for service myservice.
|----------------|--------------------|-------------|------------------------|
| NAMESPACE | NAME | TARGET PORT | URL |
|----------------|--------------------|-------------|------------------------|
| default | myservice | | http://127.0.0.1:55401 |
|----------------|--------------------|-------------|------------------------|
? Opening service default/myservice in default browser...
在浏览器中,我无法同时使用 http://192.168.49.2:32212
和 http://127.0.0.1:55401
访问我的应用。甚至 http://127.0.0.1:8080
。
从 pod 的日志来看,容器中的 web 服务器正在运行:
kubectl logs -f myapp-5d042b65c8-h7kag
...
____________________________________O/_______
O\
⇨ http server started on [::]:8080
但是没有得到正确访问端点的方法。所以没有发生任何交通。
如果我使用 docker 部署容器,它可以与 http://127.0.0.1:8080
一起使用。
解决方法
问题在于 selector
中缺少 Service
字段。
apiVersion: v1
kind: Service
metadata:
name: myservice
spec:
type: NodePort
selector:
app: myapp
ports:
- port: 8080
服务根据服务规范中定义的与 pod 上定义的标签匹配的选择器将流量路由到 pod。
来自文档的 defining-a-service 部分:
Service 选择器的控制器持续扫描 Pod 匹配其选择器,然后将任何更新发布到端点 对象也名为“my-service”。