Kubenetes(3)--网络通信(3)--ingress部署、域名解析、TLS、以及认证和地址重写

一、ingress简介

官网参考:https://kubernetes.github.io/ingress-nginx/

        Ingress是一种全局的、为了代理不同后端 Service 而设置的负载均衡服务,就是 Kubernetes 里的 Ingress 服务。

        Ingress的组成:Ingress controller、Ingress。

        Ingress Controller 会根据你定义的 Ingress 对象,提供对应的代理能力。业界常用的各 种反向代理项目,比如 Nginx、HAProxy、Envoy、Traefik 等,都已经为Kubernetes 专门维护了对应的 Ingress Controller。

图 1 ingress工作原理

二、ingress服务部署

参考官网:https://kubernetes.github.io/ingress-nginx/deploy/#bare-metal

##下载节点配置文件
[root@server1 ingress]# wget https://raw.githubusercontent.com/kubernetes/ingress-nginx/master/deploy/static/provider/baremetal/deploy.yaml

##修改配置文件的参数

///主要修改内容为:三个镜像的内容,名称需要和容器标签保持一致///

        image: jettech/kube-webhook-certgen:v1.2.0
        imagePullPolicy: IfNotPresent
        name: patch

        image: jettech/kube-webhook-certgen:v1.2.0
        imagePullPolicy: IfNotPresent
        name: create


        - name: LD_PRELOAD
          value: /usr/local/lib/libmimalloc.so
        image: quay.io/kubernetes-ingress-controller/nginx-ingress-controller:0.33.0
        imagePullPolicy: IfNotPresent

##使用文件创建相应服务
[root@server1 ingress]# kubectl create -f deploy.yaml

##查看ingress-nginx的所有信息
[root@server1 ingress]# kubectl get all -n ingress-nginx 

##查看ingress-nginx在那些节点上运行
[root@server1 ingress]# kubectl get pod -n ingress-nginx -o wide 

##查看服务端口
[root@server1 ingress]# kubectl get svc -n ingress-nginx 

##查看服务详情信息
[root@server1 ingress]# kubectl describe svc -n ingress-nginx ingress-nginx-controller 

图 2 修改yml配置文件-1

图 3 修改yml配置文件-2

图 4 修改yml配置文件-3

图 5 修改指定的轮询方式

图 6查看服务启动后的设置

 三、基于Nginx的ingress服务部署

官方参考文件:https://kubernetes.github.io/ingress-nginx/user-guide/basic-usage/

3.1 基本服务配置

##编写yml文件
[root@server1 ingress]# vim ingress.yml
[root@server1 ingress]# cat ingress.yml
apiVersion: extensions/v1beta1
kind: Ingress
metadata:
  name: ingress1
  annotations:
    kubernetes.io/ingress.class: "nginx"
spec:
  rules:
  - host: www1.linux.org            ##做相应的地址解析
    http:
      paths:
      - path: /
        backend:
          serviceName: myservice
          servicePort: 80

##yml文件生效
[root@server1 ingress]# kubectl apply -f ingress.yml 
ingress.extensions/ingress1 created

##查看相应的服务
[root@server1 ingress]# kubectl get svc
NAME     
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Ingress-Nginx是一种Kubernetes中的Ingress控制器,用于管理入站流量,并将流量路由到Kubernetes集群中的服务。以下是部署Ingress-Nginx的步骤: 1. 安装Ingress-Nginx控制器。 使用以下命令安装控制器: ``` kubectl apply -f https://raw.githubusercontent.com/kubernetes/ingress-nginx/controller-0.32.0/deploy/static/provider/cloud/deploy.yaml ``` 该命令将部署Ingress-Nginx维护的最新版本的控制器。 2. 验证控制器安装。 使用以下命令验证控制器是否已成功安装: ``` kubectl get pods -n ingress-nginx ``` 如果控制器已成功安装,则应看到类似于以下内容的输出: ``` NAME READY STATUS RESTARTS AGE ingress-nginx-admission-create-8gmgc 0/1 Completed 0 2m ingress-nginx-admission-patch-q8v2m 0/1 Completed 0 2m ingress-nginx-controller-5b4bcf79d8-9qz7j 1/1 Running 0 2m ``` 3. 部署应用程序。 使用以下命令部署您的应用程序: ``` kubectl apply -f your-application.yaml ``` 该命令将使用您的应用程序配置文件中指定的服务和端口部署应用程序。 4. 部署Ingress资源。 使用以下命令部署Ingress资源: ``` kubectl apply -f your-ingress.yaml ``` 该命令将使用您的Ingress配置文件中指定的规则和路径将流量路由到您的应用程序。 5. 验证Ingress是否生效。 使用以下命令验证Ingress是否已成功生效: ``` kubectl get ingress ``` 如果Ingress已成功生效,则应看到类似于以下内容的输出: ``` NAME HOSTS ADDRESS PORTS AGE your-ingress * 192.168.50.10 80 2m ``` 这意味着您的应用程序现在可以通过Ingress访问。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值