Java Web开发实战与项目——Spring Boot与Spring Cloud微服务项目实战

企业级应用中,微服务架构已经成为一种常见的开发模式。Spring Boot与Spring Cloud提供了丰富的工具和组件,帮助开发者快速构建、管理和扩展微服务应用。本文将通过一个实际的微服务项目,展示如何使用Spring Boot与Spring Cloud构建微服务架构,处理微服务间调用、容错处理,并最终部署到Kubernetes集群中。


1. 构建微服务项目与数据库分离

在构建微服务项目时,通常会使用多个微服务来分担不同的业务功能,而每个微服务拥有自己的数据库,确保了数据的解耦。这种方式在提高系统可扩展性、可维护性的同时,也能有效减少数据访问的耦合度。

1.1 项目结构

假设我们构建一个在线商城系统,分为两个微服务:用户服务(User Service)和商品服务(Product Service)。每个服务都有自己的数据库,分别存储用户信息和商品信息。

  • user-service: 管理用户信息、登录、注册等功能。
  • product-service: 管理商品的展示、库存等功能。
spring-cloud-microservices/
├── user-service
│   ├── src/main/java/com/example/userservice
│   └── src/main/resources/application.yml
├── product-service
│   ├── src/main/java/com/example/productservice
│   └── src/main/resources/application.yml
└── pom.xml
1.2 用户服务(User Service)

user-service 使用 Spring Boot 和 Spring Data JPA 来与数据库交互,提供用户管理功能。

application.yml

spring:datasource:url: jdbc:mysql://localhost:3306/userdbusername: rootpassword: passworddriver-class-name: com.mysql.cj.jdbc.Driverjpa:hibernate:ddl-auto: updateshow-sql: trueserver:port: 8081

UserService.java

@Service
public class UserService {@Autowiredprivate UserRepository userRepository;public User getUserById(Long id) {return userRepository.findById(id).orElseThrow(() -> new RuntimeException("User not found"));}public User createUser(User user) {return userRepository.save(user);}
}

UserController.java

1.3 商品服务(Product Service)

product-service 也使用 Spring Boot 和 Spring Data JPA 来与数据库交互,管理商品信息。

application.yml

spring:datasource:url: jdbc:mysql://localhost:3306/productdbusername: rootpassword: passworddriver-class-name: com.mysql.cj.jdbc.Driverjpa:hibernate:ddl-auto: updateshow-sql: trueserver:port: 8082

ProductService.java

@Service
public class ProductService {@Autowiredprivate ProductRepository productRepository;public Product getProductById(Long id) {return productRepository.findById(id).orElseThrow(() -> new RuntimeException("Product not found"));}public Product createProduct(Product product) {return productRepository.save(product);}
}

ProductController.java

@RestController
@RequestMapping("/api/products")
public class ProductController {@Autowiredprivate ProductService productService;@GetMapping("/{id}")public Product getProduct(@PathVariable Long id) {return productService.getProductById(id);}@PostMappingpublic Product createProduct(@RequestBody Product product) {return productService.createProduct(product);}
}
1.4 数据库分离

如上所述,user-serviceproduct-service 使用独立的数据库来存储各自的数据。这种数据库分离的策略可以通过Spring Boot的配置文件来实现,确保每个服务拥有自己独立的数据库连接和表结构。


2. 微服务间的调用与容错处理

在微服务架构中,服务间的调用是非常常见的场景。Spring Cloud提供了丰富的工具来简化服务间的通信,如FeignRibbonHystrix等。我们将使用Feign进行服务间调用,并使用Hystrix进行容错处理。

2.1 使用Feign进行服务间调用

Feign是Spring Cloud中的一种声明式Web服务客户端。它使得微服务间的调用变得简洁、直观。

ProductServiceFeignClient.java(用户服务调用商品服务)

@FeignClient(name = "product-service", fallback = ProductServiceFallback.class)
public interface ProductServiceFeignClient {@GetMapping("/api/products/{id}")Product getProductById(@PathVariable("id") Long id);
}

ProductServiceFallback.java(商品服务降级处理)

@Component
public class ProductServiceFallback implements ProductServiceFeignClient {@Overridepublic Product getProductById(Long id) {// 进行降级处理,返回默认的商品数据return new Product(id, "Fallback Product", 0);}
}
2.2 使用Hystrix进行容错处理

Hystrix是Spring Cloud的一部分,它提供了服务的容错、降级、超时控制等能力。在微服务间调用时,如果某个服务不可用,Hystrix可以触发一个回调方法(即降级逻辑),以保证系统的健壮性。

user-service中配置Hystrix:

application.yml

spring:cloud:feign:hystrix:enabled: true

UserService.java

@Component
public class ProductServiceFallback implements ProductServiceFeignClient {@Overridepublic Product getProductById(Long id) {// 进行降级处理,返回默认的商品数据return new Product(id, "Fallback Product", 0);}
}

这样,当product-service不可用时,Hystrix会触发ProductServiceFallback中的方法,防止系统崩溃。


3. 部署到Kubernetes集群

Kubernetes是现代微服务架构中流行的容器编排平台,提供了高可用性、自动伸缩和负载均衡等功能。下面将演示如何将Spring Boot与Spring Cloud构建的微服务部署到Kubernetes集群。

3.1 创建Docker镜像

首先,我们需要将user-serviceproduct-service打包成Docker镜像,并推送到Docker Hub或私有镜像仓库。

Dockerfile(用户服务)

FROM openjdk:11-jre-slim
COPY target/user-service-1.0.0.jar /app/user-service.jar
ENTRYPOINT ["java", "-jar", "/app/user-service.jar"]

Dockerfile(商品服务)

FROM openjdk:11-jre-slim
COPY target/product-service-1.0.0.jar /app/product-service.jar
ENTRYPOINT ["java", "-jar", "/app/product-service.jar"]

使用以下命令构建Docker镜像并推送:

docker build -t username/user-service .
docker build -t username/product-service .
docker push username/user-service
docker push username/product-service
3.2 Kubernetes部署配置

创建Kubernetes部署配置文件来部署user-serviceproduct-service

user-service-deployment.yml

apiVersion: apps/v1
kind: Deployment
metadata:name: user-service
spec:replicas: 3selector:matchLabels:app: user-servicetemplate:metadata:labels:app: user-servicespec:containers:- name: user-serviceimage: username/user-service:latestports:- containerPort: 8081
---
apiVersion: v1
kind: Service
metadata:name: user-service
spec:selector:app: user-serviceports:- port: 8081targetPort: 8081

product-service-deployment.yml

apiVersion: apps/v1
kind: Deployment
metadata:name: product-service
spec:replicas: 3selector:matchLabels:app: product-servicetemplate:metadata:labels:app: product-servicespec:containers:- name: product-serviceimage: username/product-service:latestports:- containerPort: 8082
---
apiVersion: v1
kind: Service
metadata:name: product-service
spec:selector:app: product-serviceports:- port: 8082targetPort: 8082

使用以下命令部署到Kubernetes集群:

kubectl apply -f user-service-deployment.yml
kubectl apply -f product-service-deployment.yml

总结

本文展示了如何使用Spring Boot和Spring Cloud构建微服务架构,包括数据库分离、微服务间调用与容错处理,以及如何将微服务部署到Kubernetes集群中。通过实践这些步骤,你可以创建一个高度可扩展且具有容错能力的微服务应用,为生产环境的部署和维护做好准备。

关于作者:

15年互联网开发、带过10-20人的团队,多次帮助公司从0到1完成项目开发,在TX等大厂都工作过。当下为退役状态,写此篇文章属个人爱好。本人开发期间收集了很多开发课程等资料,需要可联系我

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/bicheng/71822.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

VMware建立linux虚拟机

本文适用于初学者,帮助初学者学习如何创建虚拟机,了解在创建过程中各个选项的含义。 环境如下: CentOS版本: CentOS 7.9(2009) 软件: VMware Workstation 17 Pro 17.5.0 build-22583795 1.配…

Linux8-互斥锁、信号量

一、前情回顾 void perror(const char *s);功能:参数: 二、资源竞争 1.多线程访问临界资源时存在资源竞争(存在资源竞争、造成数据错乱) 临界资源:多个线程可以同时操作的资源空间(全局变量、共享内存&a…

LD_PRELOAD 绕过 disable_function 学习

借助这位师傅的文章来学习通过LD_PRELOAD来绕过disable_function的原理 【PHP绕过】LD_PRELOAD bypass disable_functions_phpid绕过-CSDN博客 感谢这位师傅的贡献 介绍 静态链接: (1)举个情景来帮助理解: 假设你要搬家&#x…

【无人集群系列---无人机集群编队算法】

【无人集群系列---无人机集群编队算法】 一、核心目标二、主流编队控制方法1. 领航-跟随法(Leader-Follower)2. 虚拟结构法(Virtual Structure)3. 行为法(Behavior-Based)4. 人工势场法(Artific…

Oracle Fusion Middleware更改weblogic密码

前言 当用户忘记weblogic密码时,且无法登录到web界面中,需要使用服务器命令更改密码 更改方式 1、备份 首先进入 weblogic 安装目录,备份三个文件:boot.properties,DefaultAuthenticatorInit.ldift,Def…

MongoDB 复制(副本集)

MongoDB 复制(副本集) 引言 MongoDB是一个高性能、可扩展、易于使用的文档存储系统。它以JSON-like的文档存储结构,支持灵活的数据模型。在分布式系统中,为了提高数据可用性和系统稳定性,常常需要实现数据的备份和冗余。MongoDB提供了副本集…

【Erdas实验教程】009:非监督分类及分类后评价

文章目录 一、分类过程二、分类评价ERDAS 的 ISODATA 算法是基于最小光谱距离来进行的非监督分类,聚类过程始于任意聚类平均值或一个已有分类模板的平均值;聚类每重复一次,聚类的平均值就更新一次,新聚类的均值再用于下次聚类循环。这个过程不断重复,直到最大的循环次数已…

一周学会Flask3 Python Web开发-Jinja2模板访问对象

锋哥原创的Flask3 Python Web开发 Flask3视频教程: 2025版 Flask3 Python web开发 视频教程(无废话版) 玩命更新中~_哔哩哔哩_bilibili 如果渲染模板传的是对象,如果如何来访问呢? 我们看下下面示例: 定义一个Student类 cla…

git 命令 设置别名

在Git中,您可以通过以下命令查看所有的alias(别名): git config --get-regexp alias 这个命令会列出所有配置的alias,例如: alias.st.status alias.co.checkout alias.br.branch ... 如果您想查看某个特定a…

React Router v5 vs v6 路由配置对比

React Router v5 vs v6 路由配置对比 React Router 是 React 中最常用的路由库,从 v5 到 v6 版本,发生了较大变化。本文对比 React Router v5 和 React Router v6 的配置方式,帮助开发者顺利迁移。 1. 安装依赖 React Router v5 npm inst…

机器学习,我们主要学习什么?

机器学习的发展历程 机器学习的发展历程,大致分为以下几个阶段: 1. 起源与早期探索(20世纪40年代-60年代) 1949年:Hebb提出了基于神经心理学的学习机制,开启了机器学习的先河1950年代:机器学习的…

全面理解-深拷贝与浅拷贝

在 C 中,深拷贝(Deep Copy) 和 浅拷贝(Shallow Copy) 是两种完全不同的对象拷贝策略,主要区别在于对指针和动态分配资源的处理方式。正确理解二者的区别是避免内存泄漏、悬空指针和程序崩溃的关键。 一、核…

蓝桥杯第十六届嵌入式模拟编程题解析

由硬件框图可以知道我们要配置LED 和按键 LED 先配置LED的八个引脚为GPIO_OutPut,锁存器PD2也是,然后都设置为起始高电平,生成代码时还要去解决引脚冲突问题 按键 按键配置,由原理图按键所对引脚要GPIO_Input 生成代码&#xf…

在 JavaScript 中,[](空数组)不是假值,它是“真值”(truthy)

文章目录 语法解释!this.form.productPhotos 的含义在代码中的作用具体判断 实际上下文总结当前代码的局限 在你的父组件代码中,出现了 !this.form.productPhotos 这样的表达式,具体是在 handleSubmit 方法中: private handleSubmit() {if (…

【Springboot3】Springboot3 搭建RocketMQ 最简单案例

说来也奇怪,RocketMQ 不能很好的兼容Springboot3,刚开始上手Springboot3集成RocketMQ会发现总是不能实例化RocketMQTemplate,老是启动时报错。本项目采用Springboot3,JDK21 ,Maven 3.9,提供一个非常简单的示…

抓包工具 wireshark

1.什么是抓包工具 抓包工具是什么?-CSDN博客 2.wireshark的安装 【抓包工具】win 10 / win 11:WireShark 下载、安装、使用_windows抓包工具-CSDN博客 3.wireshark的基础操作 Wireshark零基础使用教程(超详细) - 元宇宙-Meta…

w~视觉~合集13

我自己的原文哦~ https://blog.51cto.com/whaosoft/13384038 #xxx w视觉合集13~17没了.... #ViTAR 作者提出了一种新颖的架构:任意分辨率的视觉 Transformer (ViTAR)。ViTAR中的自适应标记合并功能使模型能够自适应地处理可变分辨率图像…

漏洞文字版表述一句话版本(漏洞危害以及修复建议),通常用于漏洞通报中简洁干练【持续更新中】

漏洞文字版表述一句话版本(漏洞危害以及修复建议) SQL注入漏洞 危害描述: SQL注入漏洞允许攻击者通过构造恶意的SQL语句,绕过应用程序的安全检查,直接访问或操作数据库。这可能导致数据泄露、数据篡改、甚至数据库被删除等严重后果&#xf…

scp工具

scp 简介选项将远程电脑上的文件复制到本地将本地文件复制到远程电脑 简介 ​​scp​​​是 secure copy 的缩写,是基于​​ssh​​的文件传输 命令/工具。 scp 是加密的,rcp 是不加密的,scp 是 rcp 的加强版。 Windows系统中,sc…

微服务即时通信系统---(三)框架学习

目录 brpc RPC框架 核心概念 工作原理 介绍 安装 头文件包含和编译时指明库 类与接口介绍 日志输出类与接口 protobuf类与接口 Closure类 RpcController类 服务端类与接口 ServerOptions类 Server类 ClosureGuard类 HttpHeader类 Controller类 客户端类与…