0

这是我在 k8s.yml 文件中定义的:

apiVersion: v1
kind: Service
metadata:
  name: myservice
  namespace: mynamespace
  labels:
    app: myservice
  annotations:
    service.beta.kubernetes.io/aws-load-balancer-internal: 0.0.0.0/0
    service.beta.kubernetes.io/aws-load-balancer-cross-zone-load-balancing-enabled: "true"
    external-dns.alpha.kubernetes.io/hostname: "myservice."
spec:
  selector:
    app: myservice
  type: LoadBalancer
  ports:
  - name: http
    port: 8080
    targetPort: 8080
    protocol: TCP

运行此命令:

kubectl describe service myservice

给我这样的“LoadBalancer Ingress”:

类型:LoadBalancer IP:
25.0.162.225 LoadBalancer 入口:internal-a9716e......us-west-2.elb.amazonaws.com

据我了解,我使用的发布类型是“LoadBalancer”,它可以帮助我将我的服务公开给外部 IP 地址(请参阅https://kubernetes.io/docs/concepts/services-networking/connect-applications-service/) . Ingress 是一个不同的东西,它位于服务的前面,我没有在我的 yml 文件中定义它。(参考:https ://medium.com/google-cloud/kubernetes-nodeport-vs-loadbalancer-vs-ingress-when-should-i-use-what-922f010849e0 )使用“LoadBalancer Ingress”我能够从集群外部访问我的服务,但我不明白为什么它被称为“LoadBalancer Ingress”?它与 Ingress 有什么关系?或者每个负载均衡器都配备了一个用于服务公开目的的入口是真的吗?

4

1 回答 1

2

Ingress 是对公开内容和方式的抽象定义。通常指的是 HTTP(S) 流量,但也可以通过一些摆弄其他模式/协议..

Ingress Controller 是一种特殊的实现,它将使用特定的软件实现您的 Ingress 定义的期望。无论是 Nginx、Traefik 还是其他一些可能专用于特定云提供商的解决方案。

他们将使用Service对象作为查找用于到达他们的特定流量的端点的手段。如果这是headless、或服务类型ClusterIP,则无关紧要。NodePortLoadBalancer

也就是说,LoadBalancer类型服务将您的服务暴露在一个令人惊讶的负载均衡器上。同样,通常与您的云提供商有关。这是一种完全不同的暴露服务的方式,就像NodePort类型一样。

于 2018-11-20T19:20:32.400 回答