首页 > 解决方案 > 无法访问 minikube 上 pod 上的应用程序

问题描述

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

kubectl apply -f deployment.yaml

部署.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

服务.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 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

标签: nginxkubernetesservicekubectlminikube

解决方案


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

评论里的人是对的。您的端口配置存在缺陷。您需要知道的几件事可以帮助您更好地理解这个概念。我们为 Kubernetes 服务提供了几种不同的端口配置:

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

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

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

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

您可以通过以下方式查看服务的详细信息:

kubectl describe service myapp-service

调整你targetPort:80,它应该没问题。


推荐阅读