springcloud技術選型
由于springcloud管理的微服務架構衆多,為了讓自己不用在項目後期解決環境沖突問題,請嚴格按照官網給出的 boot 與cloud 對應關系進行選型。
springcloud官網
粗略對應關系圖
以 Hoxton.SR12版為例,檢視細粒度的版本對應關系
由官網可知,與Hoxton.SR12最為搭配的是 boot 2.3.12.REKEASE 版本
建立父工程
建立maven父工程 ,選擇一個最簡單的 site模闆
建立完成後,删除src等目錄,隻留下pom檔案
添加打包類型标簽
<packaging>pom</packaging>
最終的pom檔案
版本号嚴格按照技術選型的接過來
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<groupId>com.li</groupId>
<artifactId>springcloud-h</artifactId>
<version>1.0-SNAPSHOT</version>
<packaging>pom</packaging>
<properties>
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
<spring.cloud-version>Hoxton.SR12</spring.cloud-version>
<spring.boot-version>2.3.12.RELEASE</spring.boot-version>
</properties>
<!--dependencyManagement 是隻管理版本,不引入依賴
聚德版本号寫在 properties 标簽中
子module不用寫 groupId 和 version
-->
<dependencyManagement>
<!--spring boot 主版本控制 2.3.12.RELEASE-->
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-dependencies</artifactId>
<version>${spring.boot-version}</version>
<type>pom</type>
<scope>import</scope>
</dependency>
<!--spring cloud 主版本管理 Hoxton.SR12 -->
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-dependencies</artifactId>
<version>${spring.cloud-version}</version>
<type>pom</type>
<scope>import</scope>
</dependency>
</dependencies>
</dependencyManagement>
<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
<configuration>
<fork>true</fork>
<addResources>true</addResources>
</configuration>
</plugin>
</plugins>
</build>
</project>
聚合版本依賴,dependencyManagement 隻聲明依賴,并不實作引入,是以子項目還需要寫要引入的依賴。如果不在子項目中聲明依賴,是不會從服項目中繼承下來的,且子項目中不明确版本号才會從父工程繼承(version和scope)。後面如果需要添加需要管理的依賴,則分别在dependencyManagement标簽和properties标簽中補充即可。
好處: 不用每個子子產品都寫版本号, 且父工程中版本号 一處修改,處處生效。
如下這個依賴無論是父工程還是子工程都不要引入
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>2.1.4.RELEASE</version>
<relativePath/> <!-- lookup parent from repository -->
</parent>
子項目建立以及父工程依賴的引用
選擇 new -> module->maven 不要選擇任何模闆
改pom
隻需要在子項目的pom檔案中添加父工程坐标版本即可
子子產品中不用寫 groupId 和 version,隻需要寫artifactId。
建立成功的子子產品的pom檔案
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<parent>
<artifactId>springcloud-h</artifactId>
<groupId>com.li</groupId>
<version>1.0-SNAPSHOT</version>
</parent>
<modelVersion>4.0.0</modelVersion>
<artifactId>euraka8002</artifactId>
</project>
引入springboot項目的一些依賴 如web依賴
直接增加一個對應标簽即可,
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
</dependencies>
子項目完整的pom依賴
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<parent>
<artifactId>springcloud-h</artifactId>
<groupId>com.li</groupId>
<version>1.0-SNAPSHOT</version>
</parent>
<modelVersion>4.0.0</modelVersion>
<artifactId>euraka8002</artifactId>
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
</dependencies>
</project>
建立好的工程目錄
這時候我們補充一個主啟動類以及一個application配置檔案
添加主啟動類
package com.li;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
@SpringBootApplication
public class Euraka8002Application {
public static void main(String[] args) {
SpringApplication.run(Euraka8002Application.class, args);
}
}
添加application配置檔案
引入一個空檔案即可 全部使用預設配置啟動
子項目啟動測試
啟動成功,并且springboot的版本号成功從父類那兒繼承過來