无法访问 minikube 上的 pod 上的应用程序

Unable to access application on pod on minikube

我使用以下简单的 yaml 文件创建了一个部署

kubectl apply -f deployment.yaml

deployment.yaml

apiVersion: apps/v1
kind: Deployment
metadata:
  name: my-deployment
  labels:
    tier: frontend
    app: myapp
spec:
  selector:
    matchLabels:
      app: myapp
  replicas: 3
  template:
    metadata:
      name: nginx-pod
      labels:
        app: myapp
    spec:
      containers:
        - name: nginx-pod
          image: nginx

然后使用下面的 yaml 文件为它创建一个服务

kubectl apply -f service.yaml

service.yaml

apiVersion: v1
kind: Service
metadata:
  name: myapp-service
spec:
  type: NodePort
  ports:
    - port: 89
      targetPort: 89
      nodePort: 30009
  selector:
    app: myapp

现在当我运行

minikube service myapp-service

它给了我

$ minikube service myapp-service
|-----------|---------------|-------------|-------------------------|
| NAMESPACE |     NAME      | TARGET PORT |           URL           |
|-----------|---------------|-------------|-------------------------|
| default   | myapp-service |          89 | http://172.17.0.2:30009 |
|-----------|---------------|-------------|-------------------------|
  Starting tunnel for service myapp-service.
|-----------|---------------|-------------|------------------------|
| NAMESPACE |     NAME      | TARGET PORT |          URL           |
|-----------|---------------|-------------|------------------------|
| default   | myapp-service |             | http://127.0.0.1:52289 |
|-----------|---------------|-------------|------------------------|
  Opening service default/myapp-service in default browser...
❗  Because you are using a Docker driver on darwin, the terminal needs to be open to run it.

当我尝试访问给定的 http://127.0.0.1:52289 时,出现“无法访问此站点”错误。

yaml文件有什么问题吗?我正在使用

minikube 版本:v1.12.1

$ kubectl version
Client Version: version.Info{Major:"1", Minor:"18", GitVersion:"v1.18.0", GitCommit:"9e991415386e4cf155a24b1da15becaa390438d8", GitTreeState:"clean", BuildDate:"2020-03-25T14:58:59Z", GoVersion:"go1.13.8", Compiler:"gc", Platform:"darwin/amd64"}
Server Version: version.Info{Major:"1", Minor:"18", GitVersion:"v1.18.3", GitCommit:"2e7996e3e2712684bc73f0dec0200d64eec7fe40", GitTreeState:"clean", BuildDate:"2020-05-20T12:43:34Z", GoVersion:"go1.13.9", Compiler:"gc", Platform:"linux/amd64"}

Docker版本

$ docker version
Client: Docker Engine - Community
 Version:           19.03.8
 API version:       1.40
 Go version:        go1.12.17
 Git commit:        afacb8b
 Built:             Wed Mar 11 01:21:11 2020
 OS/Arch:           darwin/amd64
 Experimental:      false

Server: Docker Engine - Community
 Engine:
  Version:          19.03.8
  API version:      1.40 (minimum version 1.12)
  Go version:       go1.12.17
  Git commit:       afacb8b
  Built:            Wed Mar 11 01:29:16 2020
  OS/Arch:          linux/amd64
  Experimental:     false
 containerd:
  Version:          v1.2.13
  GitCommit:        7ad184331fa3e55e52b890ea95e65ba581ae3429
 runc:
  Version:          1.0.0-rc10
  GitCommit:        dc9208a3303feef5b3839f4323d9beb36df0a9dd
 docker-init:
  Version:          0.18.0
  GitCommit:        fec3683

这是一个社区 Wiki 答案,旨在总结评论中的信息以及更多详细信息和解释。

评论中的小伙伴们是对的。您的端口配置存在缺陷。您需要了解一些可以帮助您更好地理解这个概念的事情。我们有几种不同的 Kubernetes 服务端口配置:

  • Port: 在集群内的指定端口上公开 Kubernetes 服务。集群中的其他 pods 可以通过指定端口与此服务器通信。

  • TargetPort: 是服务将请求发送到的端口,您的 pod 将监听该端口。您在容器中的应用程序也需要侦听此端口。

  • NodePort: 通过目标节点 IP 地址和 NodePort 向集群外部公开服务。如果未指定端口字段,则 NodePort 为默认设置。

从上面的示例中,myapp-service 服务将在内部暴露给端口 89 上的集群应用程序,并在外部暴露给 30009 节点 IP 地址上的集群。它还将请求转发到 pods在端口 89 上带有标签“app: my-app”。

您可以通过以下方式查看您的服务详情:

kubectl describe service myapp-service

将你的 targetPort: 调整为 80 应该没问题。