首先我们所有的子工程项目都是使用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学习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>
<!-- 测试包,当我们使用 mvn package 的时候该包并不会被打入,因为它的生命周期只在 test 之内 -->
<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相当于申明了这些模板方法;可以使用的。执行结果:1;具体请参考:https://projectlombok.org/;这里就不多说了。后面或许会再写一个使用方法。
再看看spring-cloud-config-server 服务搭建;在子项目中添加必要的依赖: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>
具体可以参考官网说明: https://spring.io/projects/spring-cloud
在创建配置文件:
spring.cloud.config.server.git.uri: git仓库链接
引用官方文档原文:
服务器可以使用@EnableConfigServer注释轻松嵌入到Spring Boot应用程序中。所以这个应用程序是一个配置服务器:
创建springboot启动类,添加注解 @EnableConfigServer即可。
git仓库文档结构
示例:
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
// 轻松实现配置服务器
@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}: 环境;
{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
再次刷新页面:
下一节在项目中使用配置文件。