首页 > 其他分享 >Ingress的Http与Https代理

Ingress的Http与Https代理

时间:2022-12-02 15:11:07浏览次数:60  
标签:Ingress Http tomcat ingress dev nginx Https com itheima

环境准备

准备service和pod

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

img

创建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: tomcat-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

创建并查看

为了避免之前创建pod的影响,直接删除重建命名空间
[root@master ~]# kubectl delete ns dev
[root@master ~]# kubectl create ns dev

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

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

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   #访问nginx.itheima.com会跳转到nginx-service的80端口
          servicePort: 80
  - host: tomcat.itheima.com
    http:
      paths:
      - path: /
        backend:
          serviceName: tomcat-service
          servicePort: 8080

创建并观察

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

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

# 查看详情
[root@master ~]# kubectl describe ing ingress-http -n dev

...

# 接下来,在本地电脑上配置host文件,解析上面的两个域名到192.168.1.50(master)上
本机hosts地址C:\Windows\System32\drivers\etc
查看ingress-nginx暴露的端口
[root@master ~]# kubectl get svc -n ingress-nginx

访问

http://nginx.itheima.com:31067/
http://tomcat.itheima.com:31067/

Https代理
创建证书
# 生成证书
openssl req -x509 -sha256 -nodes -days 365 -newkey rsa:2048 -keyout tls.key -out tls.crt -subj "/C=CN/ST=BJ/L=BJ/O=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

创建并查看


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

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

# 查看详情
[root@master ~]# kubectl describe ing ingress-https -n dev

# 下面可以通过浏览器访问
注:因为是自签证书,所以提示不安全

https://nginx.itheima.com:31453/
https://tomcat.itheima.com:31453/

参考

黑马B站k8s课程https://www.bilibili.com/video/BV1Qv41167ck/
https://gitee.com/yooome/golang/blob/main/k8s%E8%AF%A6%E7%BB%86%E6%95%99%E7%A8%8B-%E8%B0%83%E6%95%B4%E7%89%88/k8s%E8%AF%A6%E7%BB%86%E6%95%99%E7%A8%8B.md
https://www.yuque.com/fairy-era/yg511q/xyqxge

标签:Ingress,Http,tomcat,ingress,dev,nginx,Https,com,itheima
From: https://www.cnblogs.com/gys001/p/16944498.html

相关文章

  • elastic-search HTTP请求
    elastic-search请求索引查看所有索引GET_cat/indices?v&pretty查看索引信息GETindex_name/_mapping插入索引PUTindex_name{"settings":{"n......
  • 如何解决arthas-failed-to-bind-telnet-or-http-port问题
    解决方法一台机器启用多个微服务的时候可能出现多个arthas端口冲突。可以配置为随机端口,或者配置为-112#arthas.telnet-port=-1#arthas.http-port=-1并且通过tunnels......
  • 使用HTTPCLIENT去生成静态HTML页面
    一般生成HTML页时,都会用比如freemarker等去搞,但今天看到和学到一个还应该不错的方法,是使用httpclient的get方法,去读某个动态的URL,然后把读出的内容再......
  • 第六十四章 CSP的常见问题 - 发送给浏览器的HTTP头信息是什么
    第六十四章CSP的常见问题我想使用<csp:search>标记,但是我想允许用户搜索ID以外的字段。我可以这样做吗?<csp:search>标记有一个where属性,该属性允许指定要搜索的字段的......
  • 使用Fastjson作为http消息转换器
    主要是创建 FastJsonHttpMessageConverter的实例。@BeanpublicHttpMessageConvertersfastJsonHttpMessageConverters(){//1、定义一个convert转换消......
  • IE主页被https://hao.360.cn/?a1004劫持,如何解决
    最近IE主页被https://hao.360.cn/?a1004劫持了,不管如何杀毒,更换主页地址,都是不行,包括306、火绒等工具,它就是那么的顽强,不让你更改。但是发现一个现象,那就是如果你在C:\Progr......
  • IIS put请求 报HTTP Error 405 - Method Not Allowed
    在新的服务器上部署了一个.netcore的项目,部分请求地址使用了put、delete方式,导致无法正常请求,报Error405-MethodNotAllowed。由于配置IIS时把“WebDAV发布”给勾选了......
  • HTTP
    http特点:请求应答模式灵活可扩展可靠传输无状态stateless http请求方式:  http 请求格式: http 响应格式:响应头含有对响应体的描述,如类型,长度等(请求同......
  • http响应头安全策略
    响应头文件安全策略针对当前环境下,对网络安全的要求较高,平台的搭建从各个方面都在增强安全性。以下是从http头文件的方面,利用参数设置开启浏览器的安全策略,来实现相关的......
  • OkHttp在Flutter中等价于什么
    OkHttp在Flutter中等价于什么当使用受欢迎的“http”package时,Flutter进行网络信非常简单。虽然“http”package没有实现OkHttp的所有功能,但“http”package抽象出了许......