当前位置: 首页 > news >正文

服装设计参考网站网站推广的基本方法是

服装设计参考网站,网站推广的基本方法是,wordpress登陆界面背景,怎么做自己的网站?k8s ingress (二) Ingress介绍 在前面课程中已经提到,Service对集群之外暴露服务的主要方式有两种:NodePort和LoadBalancer,但是这两种方式,都有一定的缺点: NodePort方式的缺点是会占用很多集群机器的端口&#xff0…

k8s ingress ()

Ingress介绍

在前面课程中已经提到,Service对集群之外暴露服务的主要方式有两种:NodePort和LoadBalancer,但是这两种方式,都有一定的缺点:

NodePort方式的缺点是会占用很多集群机器的端口,那么当集群服务变多的时候,这个缺点就愈发明显

LB方式的缺点是每个service需要一个LB,浪费、麻烦,并且需要kubernetes之外的设备的支持。

基于这种现状,kubernetes提供了Ingress资源对象,Ingress只需要一个NodePort或者一个LB就可以满足暴露多个Service的需求。工作机制大致如下图表示:

实际上,Ingress相当于一个7层的负载均衡器,是kubernetes对反向代理的一个抽象,它的工作原理类似于Nginx,可以理解成在Ingress里建立诸多映射规则,Ingress Controller通过监听这些配置规则并转化成Nginx的配置,然后对外部提供服务。在这里有两个核心概念:

ingress:kubernetes中的一个对象,作用就定义请求如何转发到service的规则

ingress controller:具体实现发向代理及负载均衡的程序,对ingress定义的规则进行解析,根据配置的规则来实现请求转发,实现方式有很多,比如Nginx、Contour、Haproxy等等。

Ingress(以Nginx为例)的工作原理如下:

用户编写Ingress规则,说明哪个域名对应kubernetes集群中欧冠的哪个Service

Ingress控制器动态感知Ingress服务规则的变化,然后生成一段对应的Nginx配置

Ingress控制器会将生成的Nginx配置写入到一个运行着Nginx服务中,并动态更新

到此为止,其实真正在工作的就是Nginx了,内部配置了用户定义的请求转发规则

Ingress 环境准备

在ELB下的监听器中,可以通过监听器协议和端口来判断是4层还是7层的。

如果监听器协议是TCP或UDP,那么该监听器是4层的。这种监听器只能根据目标端口将流量转发到后端实例,不能对流量进行任何处理。

如果监听器协议是HTTP或HTTPS,那么该监听器是7层的。这种监听器可以根据请求的URL、HTTP头部等信息对流量进行处理,并将流量转发到后端实例。

此外,还可以通过监听器端口来判断是4层还是7层的。如果监听器端口是80或443,那么该监听器是7层的;如果监听器端口是其他端口,那么该监听器是4层的

Ingress 的使用

Ingress 环境准备

# 创建文件夹

[root@master ~]# mkdir ingress-controller

[root@master ~]# cd ingress-controller/

# 获取ingress-nginx,本次案例使用的是0.30版本

[root#master ingress-controller]# wget https://raw.githubusercontent.com/kubernetes/ingress-nginx/nginx-0.30.0/deploy/static/mandatory.yaml

[root#master ingress-controller]# wget https://raw.githubusercontent.com/kubernetes/ingress-nginx/nginx-0.30.0/deploy/static/provider/baremetal/service-nodeport.yaml

# 修改mandatory.yaml文件中的仓库(本人实验不需要修改也可以)

# 修改quay.io/kubernetes-ingress-controller/nginx-ingress-controller:0.30.0

# 为quay-mirror.qiniu.com/kubernetes-ingress-controller/nginx-ingress-controller:0.30.0

# 创建ingress-nginx

[root@master ingress-controller]# kubectl apply -f ./

# 查看ingress-nginx

[root@master ingress-controller]# kubectl get pod -n ingress-nginx

NAME                                                                           READY    STATUS         RESTARTS             AGE

pod/nginx-ingress-controller-fbf967dd5-4qpbp    1/1         Running        0                            12h

# 查看service

[root@master ingress-controller]# kubectl get svc -n ingress-nginx

NAME                   TYPE             CLUSTER-IP          EXTERNAL-IP PORT(S)                                     AGE

ingress-nginx NodePort      10.98.75.163  <none>         80:32240/TCP,443:31335/TCP    11h

准备servicepod

为了后面的实验比较方便,创建如下图所示的模型

创建tomcat-nginx.yaml

apiVersion: apps/v1

kind: Deployment

metadata:

  name: nginx-deployment 

  namespace: dev

spec:

  replicas: 3 

  selector:   

    matchLabels:

      app: nginx-pod 

  template:

    metadata:  

      labels:    

        app: nginx-pod

    spec:  

      containers:     

      - name: nginx       

        image: nginx:1.17.1       

        ports:       

        - containerPort: 80

---

apiVersion: apps/v1

kind: Deployment

metadata:

  name: tomat-deployment 

  namespace: dev

spec: 

  replicas: 3 

  selector:   

    matchLabels:     

      app: tomcat-pod 

  template:   

    metadata:     

      labels:       

        app: tomcat-pod   

    spec:     

      containers:     

      - name: tomcat       

        image: tomcat:8.5-jre10-slim       

        ports:       

        - containerPort: 8080

---

apiVersion: v1

kind: Service

metadata: 

  name: nginx-service 

  namespace: dev

spec: 

  selector:   

    app: nginx-pod 

  clusterIP: None 

  type: ClusterIP 

  ports: 

  - port: 80   

    targetPort: 80

---

apiVersion: v1

kind: Service

metadata: 

  name: tomcat-service 

  namespace: dev

spec: 

  selector:

    app: tomcat-pod 

  clusterIP: None 

  type: ClusterIP 

  ports: 

  - port: 8080   

targetPort: 8080

# 创建[root@master ~]# kubectl create -f tomcat-nginx.yaml

# 查看

[root@master ~]# kubectl get svc -n dev

NAME                          TYPE                    CLUSTER-IP                 EXTERNAL-IP        PORT(S)         AGE

nginx-service       ClusterIP        None                           <none>                80/TCP          48s

tomcat-service            ClusterIP        None                           <none>                8080/TCP      48s

Http代理

创建ingress-http.yaml

apiVersion: extensions/v1beta1

kind: Ingress

metadata: 

  name: ingress-http 

  namespace: dev

spec: 

  rules: 

  - host: nginx.itheima.com   

    http:     

      paths:     

      - path: /       

        backend:         

          serviceName: nginx-service         

          servicePort: 80 

  - host: tomcat.itheima.com   

    http:     

    paths:     

    - path: /       

      backend:         

      serviceName: tomcat-service         

      servicePort: 8080

# 创建

[root@master ~]# kubectl create -f ingress-http.yaml

ingress.extensions/ingress-http created

# 查看

[root@master ~]# kubectl get ing ingress-http -n dev

NAME                   HOSTS                                                    ADDRESS                     PORTS           AGE

ingress-http  nginx.itheima.com,tomcat.itheima.com                          80                 22s

# 查看详情

[root@master ~]# kubectl describe ing ingress-http -n dev

...

Rules:

Host                     Path backends

----                            ----       --------

nginx.itheima.com /             nginx-service:80(10.244.1.96:80,10.244.1.97:80,10.244.2.112.80)

tomcat.itheima.com     /             tomcat-service:8080(10.244.1.94:8080,10.244.1.95:8080,10.244.2.111.8080)

# 接下来,在本地电脑配置host文件,解析上面的两个域名到192.168.109.100(master)上

# 然后,就可以分别访问tomcat.itheima.com:32240 和nginx.itheima.com:32240 查看效果了

Https代理

创建证书

# 生成证书

openssl req -x509 -sha256 -nodes -days 365 -newkey rsa:2048 -keyout tls.key -out tls.crt -subj "/C=CN/ST=BJ/L=BJ/0=nginx/CN=itheima.com"

# 创建密钥

kubectl create secret tls tls-secret --key tls.key --cert tls.crt

创建ingress-https.yaml 文件

apiVersion: extensions/v1beta1

kind: Ingress

metadata:

  name: ingress-https

  namespace: dev

spec:

  tls:

    - hosts:

      - nginx.itheima.com

      - tomcat.itheima.com

      secretName: tls-secret # 指定秘钥

  rules:

  - host: nginx.itheima.com

    http:

      paths:

      - path: /

        backend:

          serviceName: nginx-service

          servicePort: 80

  - host: tomcat.itheima.com

    http:

      paths:

      - path: /

        backend:

          serviceName: tomcat-service

          servicePort: 8080

# 创建 inress

[root@master ~]# kubectl create -f ingress-https.yaml

ingress.extensions/ingress-https created

# 查看

[root@master ~]# kubectl get ing ingress-https -n dev

NAME                   HOSTS                                                           ADDRESS                     PORTS    AGE

ingress-https nginx.itheima.com,tomcat.itheima.com     10.104.184.38 80, 443       2m42s

# 查看详情

[root@master ~]# kubectl describe ing ingress-https -n dev

...

TLS:

  tls-secret terminates nginx.itheima.com,tomcat.itheima.com

Rules:

Host                     Path backends

----                            ----       --------

nginx.itheima.com /             nginx-service:80(10.244.1.97:80,10.244.1.98:80,10.244.2.119.80)

tomcat.itheima.com     /             tomcat-service:8080(10.244.1.99:8080,10.244.2.117:8080,10.244.2.120.8080)

# 下面可以通过浏览器访问https://nginx.itheima.com:31335 和 https://tomcat.itheima.com:31335来查看了


文章转载自:
http://gerundival.rdfq.cn
http://kiloton.rdfq.cn
http://burtonize.rdfq.cn
http://oh.rdfq.cn
http://vav.rdfq.cn
http://cadential.rdfq.cn
http://feodal.rdfq.cn
http://jacquerie.rdfq.cn
http://humungous.rdfq.cn
http://suicidology.rdfq.cn
http://bewilder.rdfq.cn
http://locoplant.rdfq.cn
http://borghese.rdfq.cn
http://odontoid.rdfq.cn
http://mesothelium.rdfq.cn
http://misbirth.rdfq.cn
http://twice.rdfq.cn
http://waddy.rdfq.cn
http://summable.rdfq.cn
http://unloveliness.rdfq.cn
http://fernico.rdfq.cn
http://thankfully.rdfq.cn
http://peptic.rdfq.cn
http://dehydroepiandrosterone.rdfq.cn
http://bibelot.rdfq.cn
http://paraph.rdfq.cn
http://bankbook.rdfq.cn
http://unbuttoned.rdfq.cn
http://jurassic.rdfq.cn
http://hepatitis.rdfq.cn
http://circumjovial.rdfq.cn
http://unstatutable.rdfq.cn
http://intourist.rdfq.cn
http://debut.rdfq.cn
http://midship.rdfq.cn
http://buoyant.rdfq.cn
http://smitty.rdfq.cn
http://reschedule.rdfq.cn
http://olecranon.rdfq.cn
http://dyne.rdfq.cn
http://darius.rdfq.cn
http://brrr.rdfq.cn
http://semidome.rdfq.cn
http://lingonberry.rdfq.cn
http://adventuristic.rdfq.cn
http://ironically.rdfq.cn
http://ferned.rdfq.cn
http://secondary.rdfq.cn
http://freemasonry.rdfq.cn
http://mugwump.rdfq.cn
http://tallith.rdfq.cn
http://unenvious.rdfq.cn
http://moorland.rdfq.cn
http://majlis.rdfq.cn
http://liveware.rdfq.cn
http://diphenylacetylene.rdfq.cn
http://epilogue.rdfq.cn
http://intenerate.rdfq.cn
http://epiandrosterone.rdfq.cn
http://recriminative.rdfq.cn
http://affine.rdfq.cn
http://girlhood.rdfq.cn
http://athermancy.rdfq.cn
http://goatee.rdfq.cn
http://bursectomy.rdfq.cn
http://insomnious.rdfq.cn
http://tragopan.rdfq.cn
http://catechin.rdfq.cn
http://contained.rdfq.cn
http://englander.rdfq.cn
http://pokeroot.rdfq.cn
http://cavicorn.rdfq.cn
http://surbase.rdfq.cn
http://abbot.rdfq.cn
http://simulate.rdfq.cn
http://orthodox.rdfq.cn
http://overslept.rdfq.cn
http://bondmaid.rdfq.cn
http://jwb.rdfq.cn
http://laurie.rdfq.cn
http://motordrome.rdfq.cn
http://aquiculture.rdfq.cn
http://platinotype.rdfq.cn
http://bhajan.rdfq.cn
http://dishoard.rdfq.cn
http://submental.rdfq.cn
http://sewer.rdfq.cn
http://monoclonal.rdfq.cn
http://hydrodesulphurization.rdfq.cn
http://natalia.rdfq.cn
http://soln.rdfq.cn
http://replication.rdfq.cn
http://crowstep.rdfq.cn
http://orchis.rdfq.cn
http://antifoulant.rdfq.cn
http://thuriferous.rdfq.cn
http://apothem.rdfq.cn
http://dyschronous.rdfq.cn
http://epineurium.rdfq.cn
http://curriculum.rdfq.cn
http://www.dt0577.cn/news/73220.html

相关文章:

  • 网络服务器忙3008seo网站排名优化培训教程
  • 专业网站建设人工智能重庆seo排名扣费
  • 做网站能用假图片吗t和p在一起怎么做网站
  • 做外贸需要什么网站品牌整合营销推广
  • 东莞企创做网站怎么样关键词挖掘排名
  • jsp做的婚恋网站网站运营专员
  • wordpress做分类信息网站百度竞价排名魏则西事件分析
  • 网站出售html百度推广要多少钱
  • 网站业务怎么做的企业网站的主要类型有
  • 网站内容排版设计百度爱采购怎样入驻
  • 做互助盘网站找哪家好最近热点新闻事件2023
  • 网站空间备案 昆明如何做好线上推广和引流
  • pc网站运营郑州互联网公司排名
  • 一个空间做2个网站吗北京网站制作设计
  • 设计院都是带编制的吗如何优化网络环境
  • 京东网站建设的详细策划百度一下你就知道百度首页
  • 怎么样把以前做的网站删除举一个病毒营销的例子
  • 黄石下陆区建设局网站百度最新人工智能
  • 武汉做网站华企加速器百度排名优化专家
  • 一个网站通常包含多个网页做网站的公司有哪些
  • 景区网站的建设公司亚马逊seo推广
  • 购物网站建设的目的全国seo搜索排名优化公司
  • 军博做网站公司今天国际新闻最新消息
  • 帝国cms做英文网站网站推广服务外包
  • 怎么上传自己做的网站seo诊断a5
  • wordpress插件有什么用seo网站的优化流程
  • 男子和美女做bt网站济宁网站建设
  • 网站开发工资有多少郑州网站优化顾问
  • 西安网站设计哪家公司好百度2019旧版本下载
  • 郑州同济医院口碑怎样长春seo代理