首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >无法在Docker Desktop Kubernetes下访问本地主机的应用程序

无法在Docker Desktop Kubernetes下访问本地主机的应用程序
EN

Stack Overflow用户
提问于 2021-11-04 09:28:45
回答 1查看 916关注 0票数 1

我一直在使用k3s Kubernetes实现在服务器上成功地运行应用程序堆栈。我现在尝试在我的Windows上部署它在Desktop中。在访问本地主机上的应用程序时,我得到了一个404未找到的

  • 我尝试使用'localhost‘、' 127.0.0.1’和'kubernetes.docker.internal‘(后者由Desktop在安装时分配给127.0.0.1)--没有工作。
  • 我尝试了所有这些端口80,8000,443,8443等主机名。

我使用Traefik作为入口控制器,TLS打开后,证书由证书管理器颁发。对于本地部署,我使用证书管理器自签名选项。我也从我的入口删除了TLS规范,但没有区别。

这里是我的入口定义,使用'kubernetes.docker.internal‘作为主机:

代码语言:javascript
复制
    apiVersion: networking.k8s.io/v1
    kind: Ingress
    metadata:
      name: traefik-ingress
      annotations:
        kubernetes.io/ingress.class: "traefik"
        cert-manager.io/issuer: self-signed
    spec:
      tls:
        - secretName: s3a-tls-certificate-secret
          hosts:
            - kubernetes.docker.internal
      rules:
      - http:
          paths:
            - path: /
              pathType: Prefix
              backend:
                service:
                  name: s3a-frontend
                  port:
                    number: 80
  • 当我尝试https://kubernetes.docker.internal (隐含端口443)时,在第一次尝试时,Chrome向我展示“不安全的自签名证书,按高级继续”的内容,但当我继续时,我得到404页找不到。
  • 当我尝试普通的http://kubernetes.docker.internal (隐含端口80)时,我得到了Chrome ERR_EMPTY_RESPONSE。
  • 当我将TLS内容完全从入口移除时,它对端口http和https的操作与上面的完全相同。
  • 您将看到规范/规则没有指定特定的主机,即规范适用于所有主机。我已经尝试过将它修复为宿主“kubernetes.docker.side”,但正如预期的那样,这并没有什么区别。

目标服务“S3A-前端”正在其公开端口80上运行:我可以在直接访问它的节点端口时访问它,但不能通过入口访问它。

编辑: Traefik入口控制器附带k3s,但我手动安装在Desktop中。当我附加到traefik时,当我访问https://kubernetes.docker.internal时,我可以看到一个请求正在被记录,下面是日志。您可以看到集群健康检查(“ping@Chrome”),也可以看到我对root的请求("/"),以及Chrome对偏袒图标的请求,这两种请求都不返回响应代码。

代码语言:javascript
复制
10.1.0.1     - - [05/Nov/2021:16:36:23 +0000] "GET /ping HTTP/1.1" 200 2 "-" "-" 2141 "ping@internal" "-" 0ms
192.168.65.3 - - [05/Nov/2021:16:36:24 +0000] "GET / HTTP/2.0" - - "-" "-" 2142 "-" "-" 0ms
10.1.0.1     - - [05/Nov/2021:16:36:24 +0000] "GET /ping HTTP/1.1" 200 2 "-" "-" 2143 "ping@internal" "-" 0ms
192.168.65.3 - - [05/Nov/2021:16:36:24 +0000] "GET /favicon.ico HTTP/2.0" - - "-" "-" 2144 "-" "-" 0ms

/END编辑

我做了很多研究,包括其他东西占用80/443端口的可能性。netstat说,Docker自己正在监听这些端口:如果Docker自己正在使用这些端口,或者这是一条鲱鱼,我如何才能声明这些端口?

系统

  • Windows 10 Pro,10.0.19043
  • WSL2
  • Docker Desktop报告引擎v20.10.8
EN

回答 1

Stack Overflow用户

发布于 2021-11-12 09:11:01

我不能让这个在码头桌面上工作。我转到牧场主桌面,它成功了。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/69837005

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档