Kubernetes服务架构

时间:2018-04-06 06:35:24

标签: nginx kubernetes google-kubernetes-engine kubernetes-service

我试图通过配置文件将NGINX直接流量连接到我应用的不同部分,但我无法解决这个问题。这是我目前的设置:

  http-service (loadbalancer)
  NGINX (port 80)
  website-service (10.27.246.107, port 8000, targetPort 8000, selector 'run: website')
  website (label 'run: website', containerPort 8000)

  NGINX Conf
  upstream website{
    server 10.27.246.107:8000
  }

这是目前使用containerPort 80的普通nginx pod。

我能以正确的方式解决这个问题吗?

1 个答案:

答案 0 :(得分:0)

将流量路由到应用程序的不同部分的最佳方法是使用Ingress。在Ingress中,您可以描述进入应用程序所有部分的所有路径。它看起来像:

apiVersion: extensions/v1beta1
kind: Ingress
metadata:
  name: test
  annotations:
    ingress.kubernetes.io/rewrite-target: /
spec:
  rules:
  - host: foo.bar.com
    http:
      paths:
      - path: /foo
        backend:
          serviceName: website1
          servicePort: 80
      - path: /bar
        backend:
          serviceName: website2
          servicePort: 3368

实际上,Ingress-controller基于Nginx,但无论如何你可以选择其他引擎,例如HAproxy。 Ingress专为在Kubernetes中使用而设计,它在Kubernetes中具有更多功能。例如,您的网站上游应该被描述为Kubernetes中的服务:

kind: Service
apiVersion: v1
metadata:
  name: website1
spec:
  selector:
    app: python-web-site
  ports:
  - protocol: TCP
    port: 80
    targetPort: 8080

无论如何,您可以通过Nginx路由流量并将其暴露给世界,但最佳做法是在Kubernetes中使用Ingress。