自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

來一個(gè)簡單的,微服務(wù)項(xiàng)目中如何管理依賴版本號?

開發(fā) 項(xiàng)目管理
理論上,在微服務(wù)架構(gòu)中,各個(gè)獨(dú)立的微服務(wù)可以是各種語言,像我們使用的 Eureka 注冊中心,就是支持多種語言的,這樣可以充分發(fā)揮各種語言的優(yōu)勢。如果是這樣,就沒有必要從項(xiàng)目整體上進(jìn)行版本管理了,也管不了。

[[328726]]

1.微服務(wù)架構(gòu)

理論上的微服務(wù)架構(gòu)和實(shí)際應(yīng)用的微服務(wù),往往會有一些差異。

理論上,在微服務(wù)架構(gòu)中,各個(gè)獨(dú)立的微服務(wù)可以是各種語言,像我們使用的 Eureka 注冊中心,就是支持多種語言的,這樣可以充分發(fā)揮各種語言的優(yōu)勢。如果是這樣,就沒有必要從項(xiàng)目整體上進(jìn)行版本管理了,也管不了。

但是在實(shí)際操作中,考慮到團(tuán)隊(duì)的技術(shù)棧,現(xiàn)有的技術(shù)生態(tài)等因素,大部分情況下,我們可能并不會在項(xiàng)目中摻雜其他語言進(jìn)來,比如就是用 Java 開發(fā),相信大部分小伙伴都是這么做的。

既然統(tǒng)一都使用 Java 語言開發(fā),那一個(gè)需求就隨之浮出水面,就是項(xiàng)目依賴統(tǒng)一管理。

這個(gè)問題其實(shí)不是絕對的。

大型的微服務(wù)項(xiàng)目分屬不同的團(tuán)隊(duì)開發(fā),每個(gè)團(tuán)隊(duì)維護(hù)好自己的項(xiàng)目,然后通過 RPC 或者 HTTP 的方式互相之間進(jìn)行交互,這種情況下,版本號也可以交由各個(gè)團(tuán)隊(duì)自行維護(hù),這樣版本升級的時(shí)候,就不必一起升級,可以各個(gè)團(tuán)隊(duì)獨(dú)自完成,逐個(gè)升級。

但是這種方式又可能會帶來另外一個(gè)問題,就是依賴版本的碎片化,在經(jīng)過 N 多次迭代之后,可能會存在兩個(gè)項(xiàng)目所依賴的微服務(wù)版本差異非常大。

因此,在實(shí)際操作中,有的團(tuán)隊(duì)會傾向于將項(xiàng)目版本統(tǒng)一管理。

統(tǒng)一管理也很簡單,就是搞一個(gè) parent 就行了,但是有的小伙伴容易將這種 parent 和聚合工程搞混,因此松哥這里還是和大家稍微聊一下怎么統(tǒng)一管理項(xiàng)目版本號。

2.統(tǒng)一管理版本號

2.1 聚合工程

先來說一說聚合工程,這里我就不重新寫代碼了,以微人事(https://github.com/lenve/vhr)為例來和大家分享。

微人事項(xiàng)目的服務(wù)端就是一個(gè)聚合工程。

我們可以來看下 vhrserver 的 pom.xml 文件:

 

  1. <parent> 
  2.     <artifactId>vhr</artifactId> 
  3.     <groupId>org.javaboy</groupId> 
  4.     <version>1.0-SNAPSHOT</version> 
  5. </parent> 
  6. <modelVersion>4.0.0</modelVersion> 
  7. <artifactId>vhrserver</artifactId> 
  8. <packaging>pom</packaging> 
  9. <modules> 
  10.     <module>vhr-mapper</module> 
  11.     <module>vhr-model</module> 
  12.     <module>vhr-service</module> 
  13.     <module>vhr-web</module> 
  14. </modules> 

在這個(gè)聚合工程中,vhr-model 用來放實(shí)體類,vhr-mapper 用來放 Dao 層,vhr-server 用來放 Service 層,vhr-web 則是一個(gè) Spring Boot 工程。

在聚合工程中,vhr-web 作為聚合工程的一部分,是無法獨(dú)立打包的,因?yàn)樗蕾?vhr-service,vhr-service 依賴 vhr-mapper ,而 vhr-mapper 則依賴 vhr-model。我們需要從 vhrserver 處打包,這樣它會自動(dòng)解決 module 之間的依賴問題。

單獨(dú)給 vhr-web 打包會報(bào)如下錯(cuò)誤:

從 vhrserver 處統(tǒng)一打包,結(jié)果如下:

可以看到,我們需要直接打包聚合工程,內(nèi)部的依賴問題會自動(dòng)解決。

有人可能會問,既然前面報(bào) Could not find artifact org.javaboy:vhr-service:pom:1.0-SNAPSHOT 錯(cuò)誤,那我先把 vhr-service install 到本地倉庫,再去打包 vhr-web 行不行?

這個(gè)是不行的,因?yàn)檫@是聚合工程,不能這樣做,只能從聚合工程處打包。

2.2 統(tǒng)一管理版本號

上面說的聚合工程雖然也能實(shí)現(xiàn)版本號的統(tǒng)一管理,但是我們不能在微服務(wù)中采用這種方式。

你想一個(gè)微服務(wù)系統(tǒng),包含了很多子系統(tǒng),例如商品管理、交易管理、物流管理等等,要是想給商品管理打包,你還得從聚合工程處打包,打完之后,其他微服務(wù)模塊也生成了各自的包,這樣效率太低了。

但是我們還想實(shí)現(xiàn)版本號的統(tǒng)一管理,該怎么辦呢?創(chuàng)建父子工程即可。這種項(xiàng)目結(jié)構(gòu)和聚合工程很像,但是不一樣,很多小伙伴會搞混,所以這里我來給大家稍微演示一下。

首先我們定義一個(gè)普通的 Maven 工程作為父工程,我把 pom.xml 文件拎出來給大家參考下:

  1. <parent> 
  2.     <groupId>org.springframework.boot</groupId> 
  3.     <artifactId>spring-boot-starter-parent</artifactId> 
  4.     <version>2.3.0.RELEASE</version> 
  5.     <relativePath/> 
  6. </parent> 
  7. <packaging>pom</packaging> 
  8. <groupId>org.javaboy.vmall</groupId> 
  9. <artifactId>vmall</artifactId> 
  10. <version>1.0-SNAPSHOT</version> 
  11. <properties> 
  12.     <!--省略--> 
  13. </properties> 
  14. <dependencyManagement> 
  15.     <dependencies> 
  16.         <!--省略--> 
  17.     </dependencies> 
  18. </dependencyManagement> 

大家可以看到,這個(gè)父工程本身也有一個(gè) parent ,就是 Spring Boot 中的 parent。

這里的 packaging 依然是 pom,然后我們定義了 dependencyManagement,將一些不包含在 spring-boot-starter-parent 中的依賴版本進(jìn)行統(tǒng)一管理。但是大家注意,這里沒有 modules 節(jié)點(diǎn),這是一個(gè)很大的不同。

接下來,我們創(chuàng)建其他微服務(wù)項(xiàng)目,在創(chuàng)建的過程中,可以采用平鋪的方式,例如下面這樣:

也可以做成有層次結(jié)構(gòu)的父子形式,像下面這樣:

兩種方式都可以。

然后在各個(gè)微服務(wù)項(xiàng)目中,重新修改 parent 即可:

如此之后,我們就可以對各個(gè)微服務(wù)中的依賴版本進(jìn)行統(tǒng)一管理了。

這種項(xiàng)目結(jié)構(gòu)和聚合工程并不一樣,這種項(xiàng)目打包,是可以獨(dú)立打包的。

首先我們先將父工程 install 到本地倉庫:

然后再去 install vmall-common 模塊,最后給 vmall-app-manager 進(jìn)行打包,注意,現(xiàn)在的 vmall-app-manager 可以獨(dú)立打包,不需要從總的 parent 處進(jìn)行統(tǒng)一打包。微服務(wù)項(xiàng)目中如果需要對項(xiàng)目版本進(jìn)行統(tǒng)一管理,可以采用這種方式。

小伙伴們可以仔細(xì)品一品這種方式和聚合工程的差異。

3.小結(jié)

好啦,今天的內(nèi)容比較簡單,再結(jié)合前面已經(jīng)發(fā)過的兩篇文章,相信大家對于如何組織微服務(wù)項(xiàng)目的代碼已經(jīng)有一定的思路了。

本文授權(quán)轉(zhuǎn)載自公眾號「牧碼小子」。公眾號牧碼小子分享大量Java 微服務(wù)干貨,歡迎關(guān)注!

 

責(zé)任編輯:武曉燕 來源: 江南一點(diǎn)雨
相關(guān)推薦

2023-01-09 17:46:07

項(xiàng)目版本號字段

2024-07-08 13:56:12

微服務(wù)API代碼

2011-08-18 09:56:57

MozillaFirefox

2018-05-30 10:04:38

容器技術(shù)微服務(wù)

2014-12-15 14:02:48

iOS版本號蘋果

2017-03-30 16:56:43

Windows 10Windows版本號

2021-05-20 13:22:31

架構(gòu)運(yùn)維技術(shù)

2021-10-17 23:46:06

Go項(xiàng)目版本號

2019-08-06 13:37:55

微服務(wù)架構(gòu)數(shù)據(jù)

2017-02-08 14:29:04

2019-09-19 15:15:20

LinuxMint版本號

2010-06-28 10:13:17

SQL Server

2022-11-08 08:35:53

架構(gòu)微服務(wù)移動(dòng)

2023-01-03 08:26:56

2009-10-26 08:44:48

Windows 7查看版本號

2010-11-08 10:07:45

Chrome

2017-02-22 09:30:41

2010-07-09 13:01:50

SQL Server

2015-09-08 10:32:21

開源項(xiàng)目選擇方式

2015-09-11 10:29:13

開源項(xiàng)目閱讀
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號