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.pswp.cn/bicheng/71822.shtml
繁體地址,請注明出處:http://hk.pswp.cn/bicheng/71822.shtml
英文地址,請注明出處:http://en.pswp.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類 客戶端類與…