03-Ingress

2018-09-07  本文已影响226人  泛轻舟gen

ingress就是从kubernetes集群外访问集群的入口,将用户的URL请求转发到不同的service上。ingress相当于nginx反向代理服务器,它包括的规则定义就是URL的路由信息;它的实现需要部署Ingress controller(比如 traefik ingress-nginx 等),Ingress controller通过apiserver监听ingress和service的变化,并根据规则配置负载均衡并提供访问入口,达到服务发现的作用。

集群外部 -> NodePort -> K8S Service

集群外部 -> Ingress -> K8S Service

部署 Traefik

Traefik 提供了一个简单好用 Ingress controller,下文基于它讲解一个简单的 ingress部署和测试例子。请查看yaml配置 traefik-ingress.yaml,参考traefik 官方k8s例子

安装 traefik ingress-controller

kubectl create -f /etc/ansible/manifests/ingress/traefik-ingress.yaml

验证 traefik ingress-controller

# kubectl get deploy -n kube-system traefik-ingress-controller
NAME                         DESIRED   CURRENT   UP-TO-DATE   AVAILABLE   AGE
traefik-ingress-controller   1         1         1            1           4m

# kubectl get svc -n kube-system traefik-ingress-service
NAME                      TYPE       CLUSTER-IP     EXTERNAL-IP   PORT(S)                       AGE
traefik-ingress-service   NodePort   10.68.69.170   <none>        80:23456/TCP,8080:34815/TCP   4m

测试 ingress

kubectl run test-hello --image=nginx --expose --port=80
##
# kubectl get deploy test-hello
NAME         DESIRED   CURRENT   UP-TO-DATE   AVAILABLE   AGE
test-hello   1         1         1            1           56s
# kubectl get svc test-hello
NAME         TYPE        CLUSTER-IP      EXTERNAL-IP   PORT(S)   AGE
test-hello   ClusterIP   10.68.124.115   <none>        80/TCP    1m
# test-hello.ing.yaml内容
apiVersion: extensions/v1beta1
kind: Ingress
metadata:
  name: test-hello
spec:
  rules:
  - host: hello.test.com
    http:
      paths:
      - path: /
        backend:
          serviceName: test-hello
          servicePort: 80
# traefik-ui.ing.yaml内容
---
apiVersion: extensions/v1beta1
kind: Ingress
metadata:
  name: traefik-web-ui
  namespace: kube-system
spec:
  rules:
  - host: traefik-ui.test.com
    http:
      paths:
      - path: /
        backend:
          serviceName: traefik-ingress-service
          servicePort: 8080

这样在集群外部可以使用 curl -H Host:traefik-ui.test.com 192.168.1.1:23456 尝试访问WEB管理页面,返回 <a href="/dashboard/">Found</a>.说明 traefik-ui的ingress配置生效了。

在客户端主机也可以通过修改本机 hosts 文件,如上例子,增加两条记录:

192.168.1.1 hello.test.com
192.168.1.1 traefik-ui.test.com

打开浏览器输入域名 http://hello.test.com:23456http://traefik-ui.test.com:23456 就可以访问k8s的应用服务了。

部署ingress-service的负载均衡

如果你的集群根据本项目部署了高可用方案,那么可以利用LB 节点haproxy 来做,当然如果生产环境K8S应用已经部署非常多,建议还是使用独立的 nginx/haproxy集群。

修改后在 LB 主备节点,查看文件 /etc/haproxy/haproxy.cfg类似如下:

global
        log /dev/log    local0
        log /dev/log    local1 notice
        chroot /var/lib/haproxy
        stats socket /run/haproxy/admin.sock mode 660 level admin
        stats timeout 30s
        user haproxy
        group haproxy
        daemon
        nbproc 1

defaults
        log     global
        timeout connect 5000
        timeout client  50000
        timeout server  50000

listen kube-master
        bind 0.0.0.0:8443
        mode tcp
        option tcplog
        balance source
        server 192.168.1.1 192.168.1.1:6443  check inter 10000 fall 2 rise 2 weight 1
        server 192.168.1.2 192.168.1.2:6443  check inter 10000 fall 2 rise 2 weight 1

listen ingress-node
    # 先确认 LB节点80端口可用
        bind 0.0.0.0:80     
        mode tcp
        option tcplog
        balance source
        server 192.168.1.3 192.168.1.3:23456  check inter 10000 fall 2 rise 2 weight 1
        server 192.168.1.4 192.168.1.4:23456  check inter 10000 fall 2 rise 2 weight 1

如上配置访问集群MASTER_IP80端口时,由haproxy代理转发到实际的node节点暴露的nodePort端口上了。这时可以修改客户端本机 hosts文件如下:(假定 MASTER_IP=192.168.1.10)

192.168.1.10     hello.test.com
192.168.1.10    traefik-ui.test.com

打开浏览器输入域名 http://hello.test.comhttp://traefik-ui.test.com可以正常访问。

上一篇下一篇

猜你喜欢

热点阅读