1. 概述

老话说的好:有可能性就不要放弃,要敢于尝试。

言归正传,之前我们聊了一下如何在 Kubernetes(K8s)中部署容器,今天我们来聊一下如何将 SpringCloud 的服务部署到 Kubernetes(K8s)中。

2. 有状态应用和无状态应用 

我们先来了解两个概念,有状态应用 和 无状态应用。

有状态应用:简单说就是不能简单的实现负载均衡的服务,例如:有数据产生的服务,Redis、MySql、RabbitMQ、ES等,这些服务必须通过一些较复杂的配置才能做到负载均衡。

无状态应用:就是没有数据的应用,可以简单的实现负载均衡,复制一个节点即可,例如:SpringCloud中的业务服务。

无状态的应用适合部署在 Kubernetes(K8s)中或者容器中。

有状态的应用,建议直接在物理机部署,方便管理、维护。

Eureka 服务,也属于有状态应用,因为 Eureka 服务集群需要每个节点去注册除自己之外的其他Eureka服务,配置文件有差异,因此每个节点是不一样的。

这里我们只部署一个Eureka节点,就也使用容器部署。

3. 场景说明

使用之前搭建的 Kubernetes(K8s)集群,搭建的过程可参见我之前的文章《使用国内的镜像源搭建 kubernetes(k8s)集群》(https://www.cnblogs.com/w84422/p/15596883.html)。

在 Kubernetes(K8s)集群中,搭建1个 Eureka 节点,搭建2个 Gateway 负载均衡节点,搭建2个 Eureka Client  负载均衡节点,提供一个简单的接口。

搭建成功后,我们通过调用 Gateway 来访问 Eureka Client 的这个简单接口。

4. 部署 SpringCloud 服务

4.1 部署 Eureka 服务

4.1.1 Eureka 服务 application.yml 配置

spring:
application:
name: my-eureka
server:
port: 35000
eureka:
instance:
hostname: my-eureka
client:
register-with-eureka: false # 是否发起服务注册
fetch-registry: false # 是否拉取服务注册表
server:
enable-self-preservation: false # 是否开启自我保护,建议关闭,开启自我保护机制后,实例宕机也被不会剔除
eviction-interval-timer-in-ms: 10000 # 每隔多久触发一次服务剔除,默认是60秒

4.1.2 生成 Eureka 服务的 Docker 镜像

简单起见,这里这里直接在 Kubernetes(K8s)的数据节点创建镜像,然后本地拉取,不上传到远程 Docker 仓库了。

# vi Dockerfile

FROM java:8
ADD my-eureka-0.0.1-SNAPSHOT.jar my-eureka-0.0.1-SNAPSHOT.jar
ENTRYPOINT ["java","-jar","my-eureka-0.0.1-SNAPSHOT.jar"]

# docker build -t myeureka:1.0 .

4.1.3 Eureka 服务 Deployment 部署

在 Kubernetes(K8s)Master 节点执行

# vi eureka-deployment.yml

apiVersion: apps/v1
kind: Deployment
metadata:
name: my-eureka
spec:
replicas: 1
selector:
matchLabels:
app: my-eureka
template:
metadata:
labels:
app: my-eureka
spec:
containers:
- name: my-eureka
image: myeureka:1.0

# kubectl apply -f eureka-deployment.yml

4.1.4 Eureka 服务 Service 部署

由于需要在浏览器打开 Eureka 控制台,并且其他服务需要向 Eureka 注册,因此需要部署 Service 。

在 Kubernetes(K8s)Master 节点执行

# vi eureka_service.yml

apiVersion: v1
kind: Service
metadata:
name: my-eureka-svc
spec:
type: NodePort
selector:
app: my-eureka
ports:
- protocol: TCP
nodePort: 35000
port: 35000
targetPort: 35000

# kubectl apply -f eureka_service.yml

4.2 部署 Eureka Client 服务

4.2.1 Eureka Client 服务的简单接口

@RestController
@RequestMapping("/eurekaClient")
public class EurekaClientController { @GetMapping("/hello")
public String hello() {
return "eurekaClient hello";
}

4.2.2 Eureka Client 服务 application.yml 配置

spring:
application:
name: my-eureka-client
server:
port: 36000
eureka:
client:
service-url:
defaultZone: http://my-eureka-svc:35000/eureka/
healthcheck:
enabled: true # 开启健康检查, 依赖于 spring-boot-starter-actuator
instance:
lease-renewal-interval-in-seconds: 5 # 发出续约指令的间隔,默认30秒
lease-expiration-duration-in-seconds: 30 # 租期到期时间,默认90秒
instance-id: ${spring.cloud.client.ip-address}.${server.port}
prefer-ip-address: true

注:在 Kubernetes(K8s)中,容器间可以使用 Service 中的 metadata.name + “:” + spec.ports.port 访问服务,因此 Eureka Client 服务可以使用 my-eureka-svc:35000 访问 Eureka 服务

4.2.3 生成 Eureka Client 服务的 Docker 镜像

# vi Dockerfile

FROM java:8
ADD my-eureka-client-0.0.1-SNAPSHOT.jar my-eureka-client-0.0.1-SNAPSHOT.jar
ENTRYPOINT ["java","-jar","my-eureka-client-0.0.1-SNAPSHOT.jar"]

# docker build -t myeurekaclient:1.0 .

4.2.4 Eureka Client 服务 Deployment 部署

# vi eurekaclient-deployment.yml

apiVersion: apps/v1
kind: Deployment
metadata:
name: my-eureka-client
spec:
replicas: 2
selector:
matchLabels:
app: my-eureka-client
template:
metadata:
labels:
app: my-eureka-client
spec:
containers:
- name: my-eureka-client
image: myeurekaclient:1.0

# kubectl apply -f eurekaclient-deployment.yml

4.3 部署 Gateway 服务

4.3.1 Gateway 服务 application.yml 配置

这里用简单的路由规则,按照服务的 string.application.name 小写的形式路由

server:
port: 44000 spring:
application:
name: my-gateway
cloud:
gateway:
discovery:
locator:
enabled: true
lower-case-service-id: true # service-id 是否用小写
eureka:
client:
service-url:
defaultZone: http://my-eureka-svc:35000/eureka/
healthcheck:
enabled: true # 开启健康检查, 依赖于 spring-boot-starter-actuator
instance:
lease-renewal-interval-in-seconds: 5 # 发出续约指令的间隔,默认30秒
lease-expiration-duration-in-seconds: 30 # 租期到期时间,默认90秒
instance-id: ${spring.cloud.client.ip-address}.${server.port}
prefer-ip-address: true

4.3.2 生成 Gateway 服务的 Docker 镜像

# vi Dockerfile

FROM java:8
ADD my-gateway-0.0.1-SNAPSHOT.jar my-gateway-0.0.1-SNAPSHOT.jar
ENTRYPOINT ["java","-jar","my-gateway-0.0.1-SNAPSHOT.jar"]

# docker build -t mygateway:1.0 .

4.3.3 Gateway 服务 Deployment 部署

# vi gateway-deployment.yml

apiVersion: apps/v1
kind: Deployment
metadata:
name: my-gateway
spec:
replicas: 2
selector:
matchLabels:
app: my-gateway
template:
metadata:
labels:
app: my-gateway
spec:
containers:
- name: my-gateway
image: mygateway:1.0

# kubectl apply -f gateway-deployment.yml

4.3.4 Gateway 服务 Service 部署

# vi gateway_service.yml

apiVersion: v1
kind: Service
metadata:
name: my-gateway-svc
spec:
type: NodePort
selector:
app: my-gateway
ports:
- protocol: TCP
nodePort: 44000
port: 44000
targetPort: 44000

# kubectl apply -f gateway_service.yml

4.4 验证

4.4.1 浏览器访问 Eureka

http://192.168.1.12:35000/

可以看到有2个 my-eureka-client 服务 和 2个 my-gateway 服务 注册到了 Eureka。

192.168.1.12 是 kubernetes(k8s)Master 节点的IP地址。

4.4.2 浏览器访问接口

http://192.168.1.12:44000/my-eureka-client/eurekaClient/hello

接口可以正常访问,代表验证成功。

5. 综述

今天聊了一下 kubernetes(k8s)集群上是如何部署SpringCloud服务的,希望可以对大家的工作有所帮助。

欢迎帮忙点赞、评论、转发、加关注 :)

关注追风人聊Java,每天更新Java干货。

6. 个人公众号

追风人聊Java,欢迎大家关注

Kubernetes(K8s)部署 SpringCloud 服务实战的更多相关文章

  1. 微服务探索之路03篇-docker私有仓库Harbor搭建+Kubernetes(k8s)部署私有仓库的镜像

    ❝ 目录: 微服务探索之路01篇.net6.0项目本地win10系统docker到服务器liunx系统docker的贯通 微服务探索之路02篇liunx ubuntu服务器部署k8s(kubernet ...

  2. 【K8S】K8S部署Metrics-Server服务

    写在前面 在新版的K8S中,系统资源的采集均使用Metrics-Server服务,可以通过Metrics-Server服务采集节点和Pod的内存.磁盘.CPU和网络的使用率等信息. 读者可参考< ...

  3. Kubernetes K8S之Service服务详解与示例

    K8S之Service概述与代理说明,并详解所有的service服务类型与示例 主机配置规划 服务器名称(hostname) 系统版本 配置 内网IP 外网IP(模拟) k8s-master Cent ...

  4. .Net Core 商城微服务项目系列(十二):使用k8s部署商城服务

    一.简介 本篇我们将会把商城的服务部署到k8s中,同时变化的还有以下两个地方: 1.不再使用Consul做服务的注册和发现,转而使用k8s-dns来实现. 2.不再使用Ocelot作为业务网关,使用T ...

  5. Kubernetes(k8s)部署redis-cluster集群

    Redis Cluster 提供了一种运行 Redis 安装的方法,其中数据 在多个 Redis 节点之间自动分片. Redis Cluster 还在分区期间提供了一定程度的可用性,这实际上是在某些节 ...

  6. 使用k8s部署springcloud解决三大问题

    1.正式环境使用的话启动时需要指定使用正式的配置文件,这个要咋处理? 解决办法 文章地址:https://www.cnblogs.com/sanduzxcvbnm/p/13262411.html 分析 ...

  7. 利用Kubernetes(K8S)部署JAVA项目

    一.jar包和war包区别 首先简单介绍一下jar包和war包区别,当时就没分清,导致部署总是傻傻分不清楚. jar包:jar包就是java的类进行编译生成的class文件就行打包的压缩包.里面是一些 ...

  8. k8s中部署springcloud

    安装和配置数据存储仓库MySQL 1.MySQL简介 2.MySQL特点 3.安装和配置MySQL 4.在MySQL数据库导入数据 5.对MySQL数据库进行授权 1.MySQL简介 MySQL 是一 ...

  9. SpringCloud微服务实战——搭建企业级开发框架(三十四):SpringCloud + Docker + k8s实现微服务集群打包部署-Maven打包配置

      SpringCloud微服务包含多个SpringBoot可运行的应用程序,在单应用程序下,版本发布时的打包部署还相对简单,当有多个应用程序的微服务发布部署时,原先的单应用程序部署方式就会显得复杂且 ...

随机推荐

  1. Java版人脸检测详解上篇:运行环境的Docker镜像(CentOS+JDK+OpenCV)

    欢迎访问我的GitHub https://github.com/zq2599/blog_demos 内容:所有原创文章分类汇总及配套源码,涉及Java.Docker.Kubernetes.DevOPS ...

  2. mybatis学习笔记(2)基本原理

    引言在mybatis的基础知识中我们已经可以对mybatis的工作方式窥斑见豹(参考:<MyBatis----基础知识>).但是,为什么还要要学习mybatis的工作原理?因为,随着myb ...

  3. [对对子队]会议记录4.10(Scrum Meeting 1)

    本次每日例会的开会时间是4月10日晚上20:00,使用腾讯会议作为开会工具. 今天已完成的工作 何瑞 ​ 工作内容:制作UI界面的指令编辑系统,已大致实现指令的衔接 ​ 相关issue:实现用户指令编 ...

  4. 手把手教你学Dapr - 2. 必须知道的概念

    Sidecar 边车 Dapr API提供Http和gRPC两种通讯方式. 运行方式则可以是容器也可以是进程(Windows开发推荐使用Self Hosted,后续会解释). 这样的好处是与运行环境无 ...

  5. redis中lua脚本的简单使用

    一.背景 在使用redis的过程中,发现有些时候需要原子性去操作redis命令,而redis的lua脚本正好可以实现这一功能.比如: 扣减库存操作.限流操作等等. redis的pipelining虽然 ...

  6. 2021.7.27考试总结[NOIP模拟25]

    罕见的改完了题 T1 random 一堆概率,一堆函数,一堆递归,一眼不可做, 但它只有一个参数,所以.. 熠神本着"只有20太难看"的心态,通过样例三个出规律,口胡了一波$\fr ...

  7. cadence 技巧

    pcb中如何选中完整的一条网络? 1 edit  properties  右边 find nets 2 cadence 选中不同的网络高亮 display--->assign color在opt ...

  8. 基于屏幕空间的实时全局光照(Real-time Global Illumination Based On Screen Space)

    目录 Reflective Shadow Maps(RSM) RSM 的重要性采样 RSM 的应用与缺陷 Screen Space Ambient Occulsion(SSAO) SSAO Blur ...

  9. P1231 教辅的组成(最大流)

    P1231 教辅的组成 这个题一看便知是网络流量,(三分图??滑稽..) 就一个小细节,如果我们仅仅将所有的点分成三部分跑网络流的话会有点小问题.. 因为这可能导致一本书被重复利用,就是有两条流经过同 ...

  10. 第10课 OpenGL 3D世界

    加载3D世界,并在其中漫游: 在这一课中,你将学会如何加载3D世界,并在3D世界中漫游.这一课使用第一课的代码,当然在课程说明中我只介绍改变了代码. 这一课是由Lionel Brits (βtelge ...