首先我們所有的子工程項目都是使用SpringBoot做快速啟動框架浮创。所在直接在總工程pom.xml文件引入jar包即可。示例:
<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.study.springcloud</groupId>
<artifactId>spring-cloud-study</artifactId>
<version>0.0.1-SNAPSHOT</version>
<packaging>pom</packaging>
<description>springcloud學(xué)習(xí)DEMO</description>
<modules>
<module>study-1-spring-cloud-config</module>
</modules>
<properties>
<!-- 字符編碼 -->
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
<project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
<!-- JDK版本 -->
<java.version>1.8</java.version>
<!-- maven打包插件-->
<maven-jar-plugin.version>2.6</maven-jar-plugin.version>
</properties>
<!-- Inherit defaults from Spring Boot -->
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>2.0.5.RELEASE</version>
</parent>
<dependencies>
<!-- 熱部署 -->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-devtools</artifactId>
<optional>true</optional>
</dependency>
<!-- 測試包,當(dāng)我們使用 mvn package 的時候該包并不會被打入,因為它的生命周期只在 test 之內(nèi) -->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
<scope>test</scope>
</dependency>
<!-- 簡化簡單實體getter,setter -->
<dependency>
<groupId>org.projectlombok</groupId>
<artifactId>lombok</artifactId>
<scope>provided</scope>
</dependency>
</dependencies>
<build>
<plugins>
<plugin>
<groupId>org.apache.maven.plugin</groupId>
<artifactId>maven-compiler-plugin</artifactId>
<version>2.1</version>
<configuration>
<skip>true</skip>
</configuration>
</plugin>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-surefire-plugin</artifactId>
<configuration>
<skip>true</skip>
</configuration>
</plugin>
</plugins>
</build>
</project>
使用的是springboot2.0.5.RELEASE版本。這樣所有子項目不需要單獨依賴了矿辽。
簡單說明一下<artifactId>lombok</artifactId> 用于簡化模板化代碼的。例如:
package bertram.springcloud.study.test;
import org.junit.Test;
import lombok.Data;
/**
* <p> <p>
* @Author Bertram.Wang
* @Date 2019年3月12日
*/
@Data
public class User {
private Integer id;
@Test
public void test1() {
User user = new User();
user.setId(1);
System.out.println(user.getId());
}
}
沒有看到申明方法:getId,setId挽铁;@Data相當(dāng)于申明了這些模板方法伟桅;可以使用的。執(zhí)行結(jié)果:1叽掘;具體請參考:https://projectlombok.org/楣铁;這里就不多說了。后面或許會再寫一個使用方法更扁。
再看看spring-cloud-config-server 服務(wù)搭建盖腕;在子項目中添加必要的依賴:pom.xml文件示例:
<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>
<parent>
<groupId>com.study.springcloud</groupId>
<artifactId>spring-cloud-study</artifactId>
<version>0.0.1-SNAPSHOT</version>
</parent>
<artifactId>study-1-spring-cloud-config</artifactId>
<dependencies>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-config-server</artifactId>
</dependency>
</dependencies>
<dependencyManagement>
<dependencies>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-dependencies</artifactId>
<version>Finchley.SR2</version>
<type>pom</type>
<scope>import</scope>
</dependency>
</dependencies>
</dependencyManagement>
</project>
注意版本號的兼容性;<version>Finchley.SR2</version>
具體可以參考官網(wǎng)說明: https://spring.io/projects/spring-cloud
在創(chuàng)建配置文件:
spring.cloud.config.server.git.uri: git倉庫鏈接
引用官方文檔原文:
服務(wù)器可以使用@EnableConfigServer注釋輕松嵌入到Spring Boot應(yīng)用程序中浓镜。所以這個應(yīng)用程序是一個配置服務(wù)器:
創(chuàng)建springboot啟動類溃列,添加注解 @EnableConfigServer即可。
git倉庫文檔結(jié)構(gòu)
示例:
server:
# 指定端口號
port: 8888
servlet:
context-path: /config
---
spring:
application:
name: spring-cloud-config
cloud:
config:
server:
git:
uri: https://git.coding.net/wangpp/fileManage.git
# 指定目錄
search-paths: API
啟動類 Application.java
package bertram.springcloud.study;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.config.server.EnableConfigServer;
/**
* <p>啟動類<p>
* @Author Bertram.Wang
* @Date 2019年3月12日
*/
@SpringBootApplication
// 輕松實現(xiàn)配置服務(wù)器
@EnableConfigServer
public class Application {
public static void main(String[] args) {
SpringApplication.run(Application.class, args);
}
}
就是簡單的啟動類添加注解@EnableConfigServer膛薛;
啟動訪問鏈接:http://localhost:8888/config/app/dev/master
就是訪問一下文件听隐。
API
...app-dev.yml
{app}: 項目;
{dev}: 環(huán)境哄啄;
{master}: 主分支遵绰;
提示異常: 需要身份驗證,但沒有注冊任何任憑增淹。
org.eclipse.jgit.api.errors.TransportException: https://git.coding.net/wangpp/fileManage.git: Authentication is required but no CredentialsProvider has been registered
修改配置文件添加用戶名和密碼即可椿访。
uri: https://git.coding.net/wangpp/fileManage.git
search-paths: API
username: 18170146395@163.com
password: XXXXXXXX
再次刷新頁面:
下一節(jié)在項目中使用配置文件。