千家信息网

怎么把SpringBoot应用部署到K8S上

发表于:2025-11-07 作者:千家信息网编辑
千家信息网最后更新 2025年11月07日,今天小编给大家分享一下怎么把SpringBoot应用部署到K8S上的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获
千家信息网最后更新 2025年11月07日怎么把SpringBoot应用部署到K8S上

今天小编给大家分享一下怎么把SpringBoot应用部署到K8S上的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。

之前我们都是自建的镜像仓库,这次我们换种方式,把镜像上传到Docker Hub中去。

  • 首先我们得注册个Docker Hub的账号,Docker Hub地址:https://hub.docker.com/


  • 部署应用使用之前的mall-tiny-fabric项目,先修改pom.xml文件,主要是增加Docker Hub的认证信息和修改下镜像前缀,具体内容如下;

        http://192.168.5.94:2375                                        macrodocker                        xxx                                                macrodocker/${project.name}:${project.version}              
  • 修改完成后使用package命令先把镜像打包到Linux服务器,再使用docker:push命令把镜像推送到Docker Hub中去:

  • 推送成功以后即可以在Docker Hub中看到镜像了。

接下来我们将把应用部署到K8S上去,包含SpringBoot应用的部署和MySQL的部署。

部署MySQL

  • 首先增加配置文件mysql-deployment.yaml用于创立Deployment,具体说明参考注释就可;

apiVersion: apps/v1kind: Deploymentmetadata:  # 指定Deployment的名称  name: mysql-deployment  # 指定Deployment的标签   labels:    app: mysqlspec:  # 指定创立的Pod副本数量   replicas: 1  # 定义如何查找要管理的Pod  selector:    # 管理标签app为mysql的Pod    matchLabels:      app: mysql  # 指定创立Pod的模板  template:    metadata:      # 给Pod打上app:mysql标签      labels:        app: mysql    # Pod的模板规约    spec:      containers:        - name: mysql          # 指定容器镜像          image: mysql:5.7          # 指定开放的端口          ports:            - containerPort: 3306          # 设置环境变量          env:            - name: MYSQL_ROOT_PASSWORD              value: root          # 使用存储卷          volumeMounts:            # 将存储卷挂载到容器内部路径            - mountPath: /var/log/mysql              name: log-volume            - mountPath: /var/lib/mysql              name: data-volume            - mountPath: /etc/mysql              name: conf-volume      # 定义存储卷      volumes:        - name: log-volume          # hostPath类型存储卷在宿主机上的路径          hostPath:            path: /home/docker/mydata/mysql/log            # 当目录不存在时创立            type: DirectoryOrCreate        - name: data-volume          hostPath:            path: /home/docker/mydata/mysql/data            type: DirectoryOrCreate        - name: conf-volume          hostPath:            path: /home/docker/mydata/mysql/conf            type: DirectoryOrCreate
  • 通过应用配置文件来创立Deployment;通过应用配置文件来创立Deployment

kubectl apply -f mysql-deployment.yaml
  • 运行成功后查询Deployment,发现mysql-deployment已经就绪;

[macro@linux-local k8s]$ kubectl get deploymentsNAME                      READY   UP-TO-DATE   AVAILABLE   AGEmysql-deployment          1/1     1            1           38snginx-volume-deployment   2/2     2            2           6d5h
  • 想要其余Pod可以通过服务名称访问MySQL,需要创立Service,增加配置文件mysql-service.yaml用于创立Service

apiVersion: v1kind: Servicemetadata:  # 定义服务名称,其余Pod可以通过服务名称作为域名进行访问  name: mysql-servicespec:  # 指定服务类型,通过Node上的静态端口暴露服务  type: NodePort  # 管理标签app为mysql的Pod  selector:    app: mysql  ports:    - name: http      protocol: TCP      port: 3306      targetPort: 3306      # Node上的静态端口      nodePort: 30306
  • 通过应用配置文件来创立Service

kubectl apply -f mysql-service.yaml
  • 运行成功后查询Service,发现mysql-service已经暴露在Node的30306端口上了;

[macro@linux-local k8s]$ kubectl get servicesNAME            TYPE        CLUSTER-IP       EXTERNAL-IP   PORT(S)          AGEkubernetes      ClusterIP   10.96.0.1                443/TCP          7d23hmysql-service   NodePort    10.107.189.51            3306:30306/TCP   7snginx-service   NodePort    10.101.171.181           80:30080/TCP     6d2h
  • 部署完成后需要新建mall数据库,并导入相关表,表地址: macrozheng/mall-learning/blob/master/document/sql/mall.sql

  • 这里有个比较简单的方法来导入数据库,通过Navicat创立连接,先配置一个SSH通道;

  • 之后我们即可以像在Linux服务器上访问数据库一样访问Minikube中的数据库了,直接增加Minikube中数据库IP和端口就可。

部署SpringBoot应用

  • 首先增加配置文件mall-tiny-fabric-deployment.yaml用于创立Deployment,这里我们可以通过环境变量来覆盖SpringBoot中的默认配置;

apiVersion: apps/v1kind: Deploymentmetadata:  name: mall-tiny-fabric-deployment  labels:    app: mall-tiny-fabricspec:  replicas: 1  selector:    matchLabels:      app: mall-tiny-fabric  template:    metadata:      labels:        app: mall-tiny-fabric    spec:      containers:        - name: mall-tiny-fabric          # 指定Docker Hub中的镜像地址          image: macrodocker/mall-tiny-fabric:0.0.1-SNAPSHOT          ports:            - containerPort: 8080          env:            # 指定数据库连接地址            - name: spring.datasource.url              value: jdbc:mysql://mysql-service:3306/mall?useUnicode=true&characterEncoding=utf-8&serverTimezone=Asia/Shanghai            # 指定日志文件路径            - name: logging.path              value: /var/logs          volumeMounts:            - mountPath: /var/logs              name: log-volume      volumes:        - name: log-volume          hostPath:            path: /home/docker/mydata/app/mall-tiny-fabric/logs            type: DirectoryOrCreate
  • 通过应用配置文件来创立Deployment

kubectl apply -f mall-tiny-fabric-deployment.yaml
  • 我们可以通过kubectl logs命令来查看应用的启动日志;

[macro@linux-local k8s]$ kubectl get podsNAME                                           READY   STATUS    RESTARTS   AGEmall-tiny-fabric-deployment-8684857dff-pnz2t   1/1     Running   0          47smysql-deployment-5dccc96ccf-sfxvg              1/1     Running   0          25mnginx-volume-deployment-6f6c89976d-nv2rn       1/1     Running   4          6d6hnginx-volume-deployment-6f6c89976d-tmhc5       1/1     Running   4          6d5h[macro@linux-local k8s]$ kubectl logs -f mall-tiny-fabric-deployment-8684857dff-pnz2t
  • 假如想要从外部访问SpringBoot应用,需要创立Service,增加配置文件mall-tiny-fabric-service.yaml用于创立Service

apiVersion: v1kind: Servicemetadata:  name: mall-tiny-fabric-servicespec:  type: NodePort  selector:    app: mall-tiny-fabric  ports:    - name: http      protocol: TCP      port: 8080      targetPort: 8080      # Node上的静态端口      nodePort: 30180
  • 通过应用配置文件来创立Service

kubectl apply -f mall-tiny-fabric-service.yaml
  • 此时服务已经暴露到了Node的30180端口上了;

[macro@linux-local k8s]$ kubectl get servicesNAME                       TYPE        CLUSTER-IP       EXTERNAL-IP   PORT(S)          AGEkubernetes                 ClusterIP   10.96.0.1                443/TCP          7d23hmall-tiny-fabric-service   NodePort    10.100.112.84            8080:30180/TCP   5smysql-service              NodePort    10.107.189.51            3306:30306/TCP   13mnginx-service              NodePort    10.101.171.181           80:30080/TCP     6d2h
  • Linux服务器上,我们可以通过curl命令来访问下项目的Swagger页面,不过只能查看到返回的一串HTML代码。

curl $(minikube ip):30180/swagger-ui.html

外部访问应用

因为使用Minikube安装的K8S Node处于Linux服务器的内网环境,无法直接从外部访问,所以我们需要安装一个Nginx反向代理商下才能访问。

  • 首先我们需要安装Nginx

  • 安装完成后增加一个Nginx的配置文件,这里我的配置路径为/mydata/nginx/conf/conf.d/,用于将mall-tiny.macrozheng.com域名的访问代理商到K8S中的SpringBoot应用中去,proxy_pass为上面curl使用的路径;

server {    listen       80;    server_name  mall-tiny.macrozheng.com; #修改域名    location / {        proxy_set_header Host $host:$server_port;        proxy_pass   http://192.168.49.2:30180; #修改为代理商服务地址        index  index.html index.htm;    }    error_page   500 502 503 504  /50x.html;    location = /50x.html {        root   /usr/share/nginx/html;    }}
  • 重启Nginx服务,再修改访问Linux服务器的本机host文件,增加如下记录;

192.168.5.94 mall-tiny.macrozheng.com
  • 之后就可直接在本机上访问K8S上的SpringBoot应用了,访问地址:http://mall-tiny.macrozheng.com/swagger-ui.html

以上就是"怎么把SpringBoot应用部署到K8S上"这篇文章的所有内容,感谢各位的阅读!相信大家阅读完这篇文章都有很大的收获,小编每天都会为大家更新不同的知识,如果还想学习更多的知识,请关注行业资讯频道。

应用 文件 服务 配置 镜像 端口 地址 数据 数据库 可以通过 服务器 路径 名称 命令 标签 知识 篇文章 存储 成功 代理商 数据库的安全要保护哪些东西 数据库安全各自的含义是什么 生产安全数据库录入 数据库的安全性及管理 数据库安全策略包含哪些 海淀数据库安全审计系统 建立农村房屋安全信息数据库 易用的数据库客户端支持安全管理 连接数据库失败ssl安全错误 数据库的锁怎样保障安全 工行软件开发中心体检结果 工行软件开发中心 交通 互联网创新科技方面 胶州专业软件开发公司电话 法律法规 数据库 通过互联网修改公司数据库什么罪 网络安全员做什么 海城市亿融网络技术服务有限公司 网络安全教育主题班会小班 数据库营销的发展趋势 网络安全教育手抄报内容清晰 华昊网络技术有限公司 山西ios软件开发新报价 网络安全和信息化l龙头股 人民医院软件开发 进入数据库mysql命令 电脑网络安全密钥怎么查到 学软件开发收费 吕梁软件开发设计 数据库的时间和空间怎么选 曙光服务器产品序号是序列号吗 战地4服务器管理员开黑 津南区数据网络技术售后服务 上海金融科技产业互联网 游戏服务器aoi 网络安全机构与实战 软件开发费用跟设计费用比例 桂阳学计算机软件开发学费 数据库状态字段 九合网络技术有限公司
0