用Kubernetes(k8s)的ingress部署https应用

news/2024/7/12 3:44:06 标签: kubernetes, https, 容器

用Kubernetes的ingress部署https应用

  • 环境准备
    • Ingress安装
    • 域名证书准备
  • 部署应用
  • 通过ingress暴露应用
    • 根据ssl证书生成对应的secret
    • 创建ingress暴露部署的应用
    • 确认自己安装了ingress
    • 创建ingress
  • 访问你暴露的应用

环境准备

Ingress安装

我之前有一片文章写的是用ingress暴露应用,这篇文章接着上一片文章继续讲使用ingress暴露https的应用。请先参考上一片文章将ingress先在Kubernetes集群当中安装上:

ingress暴露应用文章地址:https://blog.csdn.net/m0_51510236/article/details/132536519

域名证书准备

因为是暴露https,所以需要域名证书。分以下两种情况:

  1. 自签证书(浏览器会显示网站不安全)

我之前写过一篇nginx自签证书相关的文章,这里就不在过多赘述。文章地址:https://blog.csdn.net/m0_51510236/article/details/124676341

  1. 购买证书(做实验推荐申请免费证书)

购买证书就比较简单了,同时你也可以申请免费证书。在证书界面直接点击下载nginx的证书即可:
https://img-blog.csdnimg.cn/664412407a414c6682971627968d940d.png#pic_center" alt="在这里插入图片描述" />

国内常见的ssl证书服务提供商有(本文章不打广告):阿里云、腾讯云、华为云、青云等

部署应用

这里部署的nginx和ingress-nginx没啥关系,你们可以改用tomcat或apache等其他web服务器

这个步骤和上篇文章一模一样,直接上yaml文件,这里就不再过多赘述(因为国外下载镜像过慢,我这里写的是我自己事先拉取下来的镜像地址,可自行修改):

apiVersion: apps/v1
kind: Deployment
metadata:
  labels:
    app: nginx-deploy
  name: nginx-deploy
spec:
  replicas: 3
  selector:
    matchLabels:
      app: nginx-deploy
  strategy: {}
  template:
    metadata:
      labels:
        app: nginx-deploy
    spec:
      containers:
      - image: registry.cn-shenzhen.aliyuncs.com/xiaohh-docker/nginx:1.21.6
        name: nginx
        ports:
        - containerPort: 80
        resources: {}
status: {}

---

apiVersion: v1
kind: Service
metadata:
  labels:
    app: nginx-deploy
  name: nginx-svc
spec:
  ports:
  - port: 80
    protocol: TCP
    targetPort: 80
  selector:
    app: nginx-deploy
  type: ClusterIP
status:
  loadBalancer: {}

可以看到应用部署成功:
https://img-blog.csdnimg.cn/94b310d2fd094f8fa504992254846efb.png#pic_center" alt="在这里插入图片描述" />

同时通过内网也是能够访问的:
https://img-blog.csdnimg.cn/654cdfc3ef6e4a9eadde1fce3338da30.png#pic_center" alt="在这里插入图片描述" />

通过ingress暴露应用

根据ssl证书生成对应的secret

根据Kubernetes官方文档我们可以看到,Secret总共有三种,分别是 docker-registrygenerictls 。这次我们要创建的就是 tls 类型的Secure:
https://img-blog.csdnimg.cn/c1e23616337844cf8290946f015e355e.png#pic_center" alt="在这里插入图片描述" />
执行命令:

kubectl create secret tls cloud-yueyang-city-tls --cert=***.pem --key=***.key --dry-run=client -o yaml

上面这段代码会生成创建secret的yaml资源文件,我们来重点介绍两个参数:

  • –cert: 证书公钥文件,一般后缀名为 .pem.crt ,此参数需要填写公钥文件的路径(绝对路径或相对路径)
  • –key: 证书私钥文件,一般后缀名为 .key ,此参数需要填写私钥文件的路径(绝对路径或相对路径)

执行完后可以查看生成的Kubernetes的yaml资源清单内容(文件过长,暂未显示全部):
https://img-blog.csdnimg.cn/61f1e4344f3c4057b5c04211be639e87.png#pic_center" alt="在这里插入图片描述" />

然后我们将其输出到一个文件当中:

kubectl create secret tls cloud-yueyang-city-tls --cert=***.pem --key=***.key --dry-run=client -o yaml > ***-tls-secret.yaml

然后我们执行它:

kubectl apply -f ***-tls-secret.yaml

可以看到secret创建成功:
https://img-blog.csdnimg.cn/60610122041c454ea04885a6712e4b19.png#pic_center" alt="在这里插入图片描述" />

创建ingress暴露部署的应用

确认自己安装了ingress

查看安装的ingressclass,执行以下命令:

kubectl get ingressclass

可以看到们已经有一个名字为 nginx 的 ingressclass 了。如果没有安装那么去我的上一片文章进行安装:https://blog.csdn.net/m0_51510236/article/details/132536519
https://img-blog.csdnimg.cn/baeba7429e5142b29ae2f546a4bccf1c.png#pic_center" alt="在这里插入图片描述" />

创建ingress

执行一下命令获取暴露应用的yaml资源清单文件:

kubectl create ingress nginx-ingress --class=nginx --rule="cloud.yueyang.city/*=nginx-svc:80,tls=cloud-yueyang-city-tls" --dry-run=client -o yaml

解释一下这里面的参数:

  • --class=nginx : 这个参数表示的是使用上面我们查询出来类型名字为nginx的ingress暴露此应用
  • --rule="cloud.yueyang.city/*=nginx-svc:80,tls=cloud-yueyang-city-tls" : 暴露应用的规则,其值的格式为 域名/*=服务名:端口,tls=创建tls的secret名字
  • --dry-run=clien-o yaml : 这两个参数搭配在一起表示在客户端尝试运行并输出yaml资源清单文件内容,并不会直接创建资源

可以查看到输出内容:
https://img-blog.csdnimg.cn/d3a933cb29e74871a99d7e48aeafee9f.png#pic_center" alt="在这里插入图片描述" />

我们直接将它输出到文件当中并执行:

kubectl create ingress nginx-ingress --class=nginx --rule="cloud.yueyang.city/*=nginx-svc:80,tls=cloud-yueyang-city-tls" --dry-run=client -o yaml > ingress.yaml

最后执行它:

kubectl apply -f ingress.yaml

可以看到创建成功:
https://img-blog.csdnimg.cn/3f200085c31d46d6a8f3c5dfb46f5580.png#pic_center" alt="在这里插入图片描述" />

查看创建的ingress资源:

kubectl get ingress

查看里面有一个域名和一个IP地址:
https://img-blog.csdnimg.cn/324617d05099483a891cab86f6ef6862.png#pic_center" alt="在这里插入图片描述" />

需要确定域名的解析和IP地址是对的上的(同时你也可以通过修改你系统的hosts的配置文件来完成):
https://img-blog.csdnimg.cn/e2317c2af03a455185f9e06cc8a7d436.png#pic_center" alt="在这里插入图片描述" />

访问你暴露的应用

通过浏览器直接访问你的域名:
https://img-blog.csdnimg.cn/7187d08e6c52474189f2916c1844f95f.png#pic_center" alt="在这里插入图片描述" />

好了,通过ingress暴露https应用就完成了,下课!


http://www.niftyadmin.cn/n/4991078.html

相关文章

DOM笔试题精讲1

1 彻底搞懂HTTP协议 - 天天造轮子 - 掘金 前端面试题汇总 Issues su37josephxia/frontend-interview GitHub 如何操纵视频流 https://juejin.cn/post/6844903609000263694 语义化标签 Day22 - 语义化标签搭建wiki - 掘金 HTML5新特性 Day25 - HTML5新特性 - 掘金 innerT…

Spark 环境安装与案例演示

Spark 环境安装 一、准备工作 1、hadoop成功安装 2、防火墙关闭 二、解压安装 1、上传 spark 安装包到/tools 目录,进入 tools 下,执行如下命令: tar -zxvf spark-2.1.0-bin-hadoop2.7.tgz -C /training/由于 Spark 的脚本命令和 Hadoop…

关于“VS2022无法打开头文件<graphics.h>” 以及编译时 “没有与参数列表匹配的重载函数实例”俩个问题的解决思路

前言: 今天无聊没什么事干,突然看见一条视频梦回20年前杀马特横行的年代,炫酷而又土嗨的灯光闪烁,我又想了想之前写扫雷小游戏的时候,有的人写的游戏界面非常的炫酷,各种颜色都有,抱着没事没事干…

超声波气象站的功能和作用

超声波气象站是一种先进的测量气象要素的设备,其功能和作用在许多领域中都得到了广泛的应用。下面将从功能和作用两个方面来详细介绍超声波气象站。 一、超声波气象站的功能 ①测量各种气象要素 超声波气象站可以测量多种气象要素,包括温度、湿度、气…

用小额贷款产品微粒贷借钱靠谱方便,应急周转值得一试

平时资金周转应急,除了找亲戚朋友之外,要说用着放心靠谱的渠道,小编是相当认可微粒贷的。微粒贷作为微众银行旗下的小额贷款,正规可靠,值得信赖。接下来做个详细介绍,平时有资金应急周转需要的小伙伴&#…

Harmony数据存储工具类

使用的是mmkv 1、安装mmkv ohpm install @ohos/mmkv2、封装 import{MMKV, SerializeBase} from @ohos/mmkv/*** 数据存储工具类*/ class MMKVUtil{private filePath:string = private cachePath:string = private mmkv:MMKVprivate mmapID:string="MMKV"construct…

2023-08-31 LeetCode每日一题(一个图中连通三元组的最小度数)

2023-08-31每日一题 一、题目编号 1761. 一个图中连通三元组的最小度数二、题目链接 点击跳转到题目位置 三、题目描述 给你一个无向图,整数 n 表示图中节点的数目,edges 数组表示图中的边,其中 edges[i] [ui, vi] ,表示 ui…

FileZilla使用密钥文件连接FSTP

文件-》站点管理-》新站点 右侧协议选择SFTP 填写主机和端口号 登录类型选择:密钥文件 填写用户名 选择密钥文件即可 注: 这里密钥文件默认只能选择.ppk: 如果你的密钥文件不是这个格式(默认ssh生成的就不是)&…