【从入门到放弃-Kubernetes】Kubernetes入门-部署SpringBoot

本文涉及的产品
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
RDS MySQL Serverless 高可用系列,价值2615元额度,1个月
简介:

前言

在上文【从入门到放弃-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,转载请注明出处

相关实践学习
通过Ingress进行灰度发布
本场景您将运行一个简单的应用,部署一个新的应用用于新的发布,并通过Ingress能力实现灰度发布。
容器应用与集群管理
欢迎来到《容器应用与集群管理》课程,本课程是“云原生容器Clouder认证“系列中的第二阶段。课程将向您介绍与容器集群相关的概念和技术,这些概念和技术可以帮助您了解阿里云容器服务ACK/ACK Serverless的使用。同时,本课程也会向您介绍可以采取的工具、方法和可操作步骤,以帮助您了解如何基于容器服务ACK Serverless构建和管理企业级应用。 学习完本课程后,您将能够: 掌握容器集群、容器编排的基本概念 掌握Kubernetes的基础概念及核心思想 掌握阿里云容器服务ACK/ACK Serverless概念及使用方法 基于容器服务ACK Serverless搭建和管理企业级网站应用
目录
相关文章
|
1月前
|
Kubernetes Cloud Native 云计算
云原生入门:从Docker到Kubernetes的旅程
【10月更文挑战第2天】本文将带你走进云原生的世界,从基础的Docker容器技术开始,逐步深入到Kubernetes集群管理。我们将通过实际代码示例,探索如何利用这些工具构建、部署和管理现代云应用。无论你是初学者还是有经验的开发者,这篇文章都将为你提供宝贵的知识和技能,让你在云原生领域迈出坚实的一步。
76 5
|
1月前
|
Java Maven Docker
gitlab-ci 集成 k3s 部署spring boot 应用
gitlab-ci 集成 k3s 部署spring boot 应用
|
8天前
|
Kubernetes 关系型数据库 MySQL
Kubernetes入门:搭建高可用微服务架构
【10月更文挑战第25天】在快速发展的云计算时代,微服务架构因其灵活性和可扩展性备受青睐。本文通过一个案例分析,展示了如何使用Kubernetes将传统Java Web应用迁移到Kubernetes平台并改造成微服务架构。通过定义Kubernetes服务、创建MySQL的Deployment/RC、改造Web应用以及部署Web应用,最终实现了高可用的微服务架构。Kubernetes不仅提供了服务发现和负载均衡的能力,还通过各种资源管理工具,提升了系统的可扩展性和容错性。
29 3
|
12天前
|
Kubernetes Cloud Native 开发者
云原生技术入门:Kubernetes和Docker的协作之旅
【10月更文挑战第22天】在数字化转型的浪潮中,云原生技术成为推动企业创新的重要力量。本文旨在通过浅显易懂的语言,引领读者步入云原生的世界,着重介绍Kubernetes和Docker如何携手打造弹性、可扩展的云环境。我们将从基础概念入手,逐步深入到它们在实际场景中的应用,以及如何简化部署和管理过程。文章不仅为初学者提供入门指南,还为有一定基础的开发者提供实践参考,共同探索云原生技术的无限可能。
22 3
|
10天前
|
运维 Kubernetes Cloud Native
云原生入门:Kubernetes和容器化的未来
【10月更文挑战第23天】本文将带你走进云原生的世界,探索Kubernetes如何成为现代软件部署的心脏。我们将一起揭开容器化技术的神秘面纱,了解它如何改变软件开发和运维的方式。通过实际的代码示例,你将看到理论与实践的结合,感受到云原生技术带来的革命性影响。无论你是初学者还是有经验的开发者,这篇文章都将为你开启一段新的旅程。让我们一起踏上这段探索之旅,解锁云原生技术的力量吧!
|
25天前
|
数据可视化 Java 应用服务中间件
springboot打war包,成功部署
这篇文章介绍了如何将Spring Boot项目打包成WAR文件,并成功部署到Tomcat服务器的详细步骤。
72 0
springboot打war包,成功部署
|
30天前
|
Kubernetes Cloud Native Docker
云原生入门:Kubernetes和Docker的协同之旅
【10月更文挑战第4天】在这篇文章中,我们将通过一次虚拟的旅行来探索云原生技术的核心——Kubernetes和Docker。就像乘坐一艘由Docker驱动的小船启航,随着波浪(代码示例)起伏,最终抵达由Kubernetes指挥的宏伟舰队。这不仅是一段技术上的旅程,也是理解现代云架构如何支撑数字世界的冒险。让我们扬帆起航,一探究竟!
|
29天前
|
运维 Kubernetes Cloud Native
云原生时代的容器编排:Kubernetes入门与实践
【10月更文挑战第4天】在云计算的浪潮中,云原生技术以其敏捷、可扩展和高效的特点引领着软件开发的新趋势。作为云原生生态中的关键组件,Kubernetes(通常被称为K8s)已成为容器编排的事实标准。本文将深入浅出地介绍Kubernetes的基本概念,并通过实际案例引导读者理解如何利用Kubernetes进行高效的容器管理和服务部署。无论你是初学者还是有一定经验的开发者,本文都将为你打开云原生世界的大门,并助你一臂之力在云原生时代乘风破浪。
|
1月前
|
Kubernetes 网络协议 Docker
Kubernetes入门到进阶实战
Kubernetes入门到进阶实战
67 0
|
13天前
|
JSON Kubernetes 容灾
ACK One应用分发上线:高效管理多集群应用
ACK One应用分发上线,主要介绍了新能力的使用场景