【从入门到放弃-Kubernetes】Kubernetes入门-部署SpringBoot
前言
在上文【从入门到放弃-Kubernetes】Kubernetes入门-部署MySQL中,我们学习了如何部署MySQL,本文我们将基于上文中的内容,学习如何部署SpringBoot应用,并调用我们部署好的MySQL服务。
SpringBoot镜像准备
我们可以参考前面【从入门到放弃-Kubernetes】Kubernetes入门-应用部署中构建代码镜像的方式。
有区别的地方是nodejs中的server.js源码可以直接运行,而java需要多一步编译打包的动作。
你也可以直接用我打好的镜像:registry.cn-hangzhou.aliyuncs.com/larswang/springboot-demo:2.0,跳过这一步,直接看后面的【部署服务】章节。
准备源码
首先需要有SpringBoot项目源代码,这里使用的是我的一个demo。里面只做了简单的对MySQL数据库增删改查的动作,并对外提供了http操作接口,方便我们验证。
源码在:https://github.com/AloofJr/springboot-demo
打包
我们知道SpringBoot都是以fat jar的方式运行。
源码在开发环境测试没问题后,就可以开始准备打包了。
这里我用的maven直接打包
mvn clean && mvn package -e -X
正常运行无报错后,你会看到 ./target/目录下生成了 demo-0.0.1-SNAPSHOT.jar 文件,这就是我们打包后执行用的SpringBoot fat jar。
注意:
- 其实可以将打包的流程放在Dockerfile中,但是因为网络等原因,速度非常慢,且容易出现pom依赖下载不下来,导致打包失败的情况。
- 这里我直接在本地打包好,跟随源文件一起上传了。
- 我们在标准的开发流程中,也为了节省时间,也通常是先将项目独立编译打包好后,直接使用打包好的jar文件进行部署的。
Dockerfile
# 基于openjdk基础镜像 FROM openjdk:8-jdk-alpine # 添加bash命令 RUN apk add --no-cache bash # copy jar文件 COPY ./target/demo-0.0.1-SNAPSHOT.jar /home/admin/myapp/ # 进入工作目录 WORKDIR /home/admin/myapp/ # 暴露8080端口 EXPOSE 8080 # 运行jar,启动服务 CMD ["java", "-jar", "demo-0.0.1-SNAPSHOT.jar"]
这里我们基于openjdk:8-jdk-alpine镜像构建,dockerfile写好后,可以先在本地使用如下命令构建、启动测试一下。
# build docker image docker build -t springboot-demo . # run docker run -it -p 8080:8080 --rm --name my-running-demo springboot-demo
访问http://127.0.0.1:8080/ 出现404页面就说明镜像构建没问题了。
将dockerfile放在源代码仓库的根目录,如Dockerfile
参考构建镜像,将镜像在阿里云镜像服务仓库中构建并上传。
部署服务
准备MySQL服务
部署服务前,请保证k8s集群中,MySQL服务是启动的,如果没启动,请参考【从入门到放弃-Kubernetes】Kubernetes入门-部署MySQL部署。
在MySQL的主库中,准备我们demo中要用到的数据库及表结构。
# 进入MySQL主库的pod kubectl exec -it mysql-0 bash # 通过客户端连接 mysql -uroot -p
导入demo.sql
CREATE DATABASE IF NOT EXISTS `test` /*!40100 DEFAULT CHARACTER SET utf8 */ /*!80016 DEFAULT ENCRYPTION='N' */; USE test; CREATE TABLE IF NOT EXISTS `users` ( `id` bigint NOT NULL AUTO_INCREMENT COMMENT '主键id', `userName` varchar(32) DEFAULT NULL COMMENT '用户名', `passWord` varchar(32) DEFAULT NULL COMMENT '密码', `user_sex` varchar(32) DEFAULT NULL, `nick_name` varchar(32) DEFAULT NULL, PRIMARY KEY (`id`) ) ENGINE=InnoDB AUTO_INCREMENT=3 DEFAULT CHARSET=utf8;
这里要特别注意,因为我们的MySQL服务,在K8s集群中,提供服务的service名称为mysql,所以要注意下我们SpringBoot项目连接MySQL服务的地址和账号密码,避免连接失败导致无法读写。如果你使用的是自己的MySQL服务,请记得修改application.properties文件。
Deployment
SpringBoot服务是无状态的,我们采用Deployment的方式部署。yaml文件如下。
apiVersion: apps/v1 kind: Deployment metadata: name: springboot-deployment labels: app: springboot spec: replicas: 2 selector: matchLabels: app: springboot template: metadata: labels: app: springboot spec: containers: - name: springboot image: registry.cn-hangzhou.aliyuncs.com/larswang/springboot-demo:2.0 ports: - containerPort: 8080
apply
kubectl apply -f springboot.yaml kubectl get pods
查看pod状态,直到MySQL和SpringBoot服务都准备就绪
对外暴露服务
kubectl expose deployment springboot-deployment --name=my-springboot --type=LoadBalancer minikube tunnel
访问服务
此时访问http://127.0.0.1:8080/ 出现404页面就说明,我们的服务已经ready了。(因为我们的demo中,没有设置默认index页面,因此直接访问会404)
写入数据
访问http://127.0.0.1:8080/addUsers,是我们demo中,写入mock数据的接口。返回true。
此时查看数据库记录。
读取数据
访问http://127.0.0.1:8080/getUsersByCondition?id=3,返回数据库中的结果。
总结
本文,我们学习了SpringBoot项目的打包和构建镜像,以及如何和MySQL服务部署在同一个k8s集群中,并正常访问MySQL服务的。
操作中如果遇到问题,可以回过头翻看下之前的系列文章,值得注意的是,在SpringBoot项目中,链接MySQL用的host,一定要是service名,而不是pod名,k8s是通过service提供服务的。我在操作的时候,就因为这个点,使用了pod名mysql-0,就一直访问不通,浪费了较多时间。
至此,我们学习了无状态应用、有状态应用 以及 无状态应用和有状态应用组合部署。应该对k8s的基础用法有了比较清晰的认识。希望大家能多实际操作,多练。
更多文章
见我的博客:https://nc2era.com
written by AloofJr,转载请注明出处

低调大师中文资讯倾力打造互联网数据资讯、行业资源、电子商务、移动互联网、网络营销平台。
持续更新报道IT业界、互联网、市场资讯、驱动更新,是最及时权威的产业资讯及硬件资讯报道平台。
转载内容版权归作者及来源网站所有,本站原创内容转载请注明来源。
- 上一篇
pacebox-springboot 1.0.3 发布,紧急 BUG 修复版
pacebox-springboot 融合封装已发布,旨在提供快速开发脚手架、打造更好的开源生态环境。希望有志同道合的朋友一起维护该软件、打造一款快速应用开发级生态框架。 案例 inter-boot-demo springboot版demo(spring boot+权限管理+elasticsearch日志+数据加解密+分布式追踪(基于opentracing) inter-micro-demo springcloud版demo(spring cloud nacos+sentinel体系+权限管理+elasticsearch日志+数据加解密+分布式追踪(基于opentracing)) inter-boot-generator 代码在线生成平台 inter-boot-fastdfs FastDFS权限文件管理(后续改名attachment、支持所有文件种类) BUG修复 修复使用pacebox-springboot若不使用trace模块数据无应答问题
- 下一篇
如何使用MaxCompute Spark读写阿里云Hbase
背景 Spark on MaxCompute可以访问位于阿里云VPC内的实例(例如ECS、HBase、RDS),默认MaxCompute底层网络和外网是隔离的,Spark on MaxCompute提供了一种方案通过配置spark.hadoop.odps.cupid.vpc.domain.list来访问阿里云的vpc网络环境的Hbase。Hbase标准版和增强版的配置不同,本文通过访问阿里云的标准版和增强版的Hbase简单的描述需要加的配置。 Hbase标准版 环境准备Hbase的网络环境是存在vpc下的,所以我们首先要添加安全组开放端口2181、10600、16020.同时Hbase有白名单限制我们需要把对应的MaxCompute的IP加入到Hbase的白名单。设置对应vpc的安全组找到对应的vpc id然后添加安全组设置端口 添加Hb
相关文章
文章评论
共有0条评论来说两句吧...
文章二维码
点击排行
推荐阅读
最新文章
- CentOS8安装MyCat,轻松搞定数据库的读写分离、垂直分库、水平分库
- CentOS7编译安装Gcc9.2.0,解决mysql等软件编译问题
- Docker使用Oracle官方镜像安装(12C,18C,19C)
- CentOS7,8上快速安装Gitea,搭建Git服务器
- CentOS7编译安装Cmake3.16.3,解决mysql等软件编译问题
- Docker快速安装Oracle11G,搭建oracle11g学习环境
- SpringBoot2全家桶,快速入门学习开发网站教程
- Jdk安装(Linux,MacOS,Windows),包含三大操作系统的最全安装
- MySQL8.0.19开启GTID主从同步CentOS8
- CentOS8编译安装MySQL8.0.19