amazon-web-services - 即使使用 LoadBalancer 公开后也无法访问我的 kubernetes 服务

标签 amazon-web-services ip load-balancing kubernetes

我使用以下配置在 Kubernetes 中创建了复制 Controller :

{
   "kind":"ReplicationController",
   "apiVersion":"v1",
   "metadata":{
      "name":"guestbook",
      "labels":{
         "app":"guestbook"
      }
   },
   "spec":{
      "replicas":1,
      "selector":{
         "app":"guestbook"
      },
      "template":{
         "metadata":{
            "labels":{
               "app":"guestbook"
            }
         },
         "spec":{
            "containers":[
               {
                  "name":"guestbook",
                  "image":"username/fsharp-microservice:v1",
                  "ports":[
                     {
                        "name":"http-server",
                        "containerPort":3000
                     }
                  ],
                  "command": ["fsharpi", "/home/SuaveServer.fsx"]
               }
            ]
         }
      }
   }
}

在端口3000上运行的服务的代码基本上是这样的:

#r "Suave.dll"
#r "Mono.Posix.dll"
open Suave
open Suave.Http
open Suave.Successful
open System
open System.Net
open System.Threading
open System.Diagnostics
open Mono.Unix
open Mono.Unix.Native

let app = OK "PONG"

let port = 3000us
let config =
  { defaultConfig with
     bindings = [ HttpBinding.mk HTTP IPAddress.Loopback port ]
     bufferSize = 8192
     maxOps = 10000
  }

open System.Text.RegularExpressions

let cts = new CancellationTokenSource()
let listening, server = startWebServerAsync config app
Async.Start(server, cts.Token)

Console.WriteLine("Server should be started at this point")
Console.ReadLine()

创建服务后,我可以看到 Pod:

$kubectl create -f guestbook.json
replicationcontroller "guestbook" created
$ kubectl get pods
NAME                   READY     STATUS             RESTARTS   AGE
guestbook-0b9py        1/1       Running            0          32m

我想访问我的 Web 服务并使用 type=LoadBalancer 创建服务,该服务将使用以下配置公开 3000 端口:

{
   "kind":"Service",
   "apiVersion":"v1",
   "metadata":{
      "name":"guestbook",
      "labels":{
         "app":"guestbook"
      }
   },
   "spec":{
      "ports": [
         {
           "port":3000,
           "targetPort":"http-server"
         }
      ],
      "selector":{
         "app":"guestbook"
      },
      "type": "LoadBalancer"
   }
}

结果如下:

$ kubectl create -f guestbook-service.json
service "guestbook" created
$ kubectl get services
NAME         CLUSTER-IP   EXTERNAL-IP   PORT(S)    AGE
guestbook    10.0.82.40                 3000/TCP   7s
kubernetes   10.0.0.1     <none>        443/TCP    3h
$ kubectl describe services
Name:           guestbook
Namespace:      default
Labels:         app=guestbook
Selector:       app=guestbook
Type:           LoadBalancer
IP:         10.0.82.40
LoadBalancer Ingress:   a43eee4a008cf11e68f210a4fa30c03e-1918213320.us-west-2.elb.amazonaws.com
Port:           <unset> 3000/TCP
NodePort:       <unset> 30877/TCP
Endpoints:      10.244.1.6:3000
Session Affinity:   None
Events:
  FirstSeen LastSeen    Count   From            SubobjectPath   Type        Reason          Message
  --------- --------    -----   ----            -------------   --------    ------          -------
  18s       18s     1   {service-controller }           Normal      CreatingLoadBalancer    Creating load balancer
  17s       17s     1   {service-controller }           Normal      CreatedLoadBalancer Created load balancer


Name:           kubernetes
Namespace:      default
Labels:         component=apiserver,provider=kubernetes
Selector:       <none>
Type:           ClusterIP
IP:         10.0.0.1
Port:           https   443/TCP
Endpoints:      172.20.0.9:443
Session Affinity:   None
No events.

“外部IP”列为空

我尝试使用“LoadBalancer Ingress”访问该服务,但无法解析 DNS 名称。

如果我检查 AWS 控制台 - 负载均衡器已创建(但在详细信息面板中,由于运行状况检查,会显示一条消息“0 of 2 个实例正在服务中”)。

我还尝试使用 kubectl Exposure --type=Load-Balancer 公开我的 RC,但结果是相同的。

问题是什么?

最佳答案

我修正了错误。

事情是在实际服务中。它需要监听 0.0.0.0 而不是 127.0.0.1 或 localhost。这样它将监听每个可用的网络接口(interface)。有关 0.0.0.0 和 127.0.0.1 之间差异的更多详细信息:https://serverfault.com/questions/78048/whats-the-difference-between-ip-address-0-0-0-0-and-127-0-0-1

关于amazon-web-services - 即使使用 LoadBalancer 公开后也无法访问我的 kubernetes 服务,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36803824/

相关文章:

.net - AWS DotNetCore Lambda - 一个解决方案中的多个项目

ubuntu - 在启动时通过 AWS CLI 将弹性 IP 分配给 EC2

go - 检查IP地址是否在私网空间

vb.net - 查找 MAC 地址是否在范围内的最有效方法是什么?

websocket - 在部署/崩溃期间保持 Websocket 连接的技术

apache http 服务器负载均衡器监控

javascript - 由于使用 require AND import 导致无服务器部署失败

ssl - 无法在 Elastic Load Balancer (AWS) 上使用 https

url - 我们可以使用 Opencv 通过互联网获取实时视频流吗?怎么做?

amazon-web-services - AWS 应用程序负载均衡器 Cname 连接被拒绝