配置文件仓库一般建一个文件夹方便管理配置文件,其实不建文件夹也可以.
这里我就按照自己已经做好的贡献给大家,有任何疑问欢迎叨扰!
1.新建一个仓库
properties文件格式:
mysqldb.datasource.url=jdbc\:mysql\://10.12.49.115\:3366/spring-cloud-test?useUnicode\=true&characterEncoding\=utf-8 mysqldb.datasource.username=root mysqldb.datasource.password=rootconfig repository目录:(.iml是idea自动生成的文件可忽略)
2.config server目录(如上图)
(1)建一个空的maven项目
pom.xml
<?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.crazy.sc</groupId>
<artifactId>_3cloud-config-server</artifactId>
<version>1.0-SNAPSHOT</version>
<packaging>jar</packaging>
<name>_3cloud-config-server</name>
<description>cloud-config-server</description>
<!-- 上篇文章中已经介绍了该依赖,再次就不做介绍了 -->
<parent>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-parent</artifactId>
<version>Brixton.RELEASE</version>
<relativePath /> <!-- lookup parent from repository -->
</parent>
<properties>
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
<java.version>1.8</java.version>
</properties>
<dependencies>
<!-- Spring Cloud Config Sever的管理git或svn的外部配置,集中配置到所有客户端。 -->
<!-- 配置服务器的相关依赖 -->
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-config-server</artifactId>
</dependency>
</dependencies>
<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
</plugin>
</plugins>
<defaultGoal>compile</defaultGoal>
</build>
</project>
ConfigServerApplication.class
package cloud.config.server;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.config.server.EnableConfigServer;
//@Configuration
//@EnableAutoConfiguration
//@EnableDiscoveryClient 这三个注解可以代替SpringbootBootApplication注解
@SpringBootApplication
@EnableConfigServer//激活该应用为配置文件服务器即可.如此以来该应用启动后就会完成前面提到的功能,即:读取远程配置文件,转换为rest接口服务。
public class ConfigServerApplication {
public static void main(String[] args) {
SpringApplication.run(ConfigServerApplication.class, args);//spring-cloud-starter-eureka-server
}
}
注意: application.properties 和application.yml两个文件只能存在一个,都可以达到同样的效果
application.properties
#config配置服务一般设置端口8888
server.port=8888
spring.cloud.config.server.git.uri=https://gitee.com/crazy_qu/spring-cloud-simple.git
#从以下文件夹下下面查找配置文件 _2cloud-config-repo就是上面创建的文件仓库文件夹的名称,之前在这一直有疑问
spring.cloud.config.server.git.searchPaths= _2cloud-config-repo
spring.application.name=_3cloud-config-server
#其中server.port是配置当前web应用绑定8888端口,git.uri指定配置文件所在的git工程路径,
#searchPaths表示将搜索该文件夹下的配置文件(我们的配置文件放在spring-cloud-test这个工程的_2cloud-config-repo文件夹下)
application.yml
server:
#config配置服务一般设置端口8888
port: 8888
spring:
application:
name: _3cloud-config-server
cloud:
#git服务配置信息
config:
server:
git:
uri: https://gitee.com/crazy_qu/spring-cloud-simple.git
#从以下文件夹下下面查找配置文件
searchPaths: _2cloud-config-repo
如此,配置文件服务器和配置文件仓库都已经完成了.
调用请参照http://blog.csdn.net/crazy__qu/article/details/78666448
1)新建一个Properties.class,获取配置文件中的属性值
package cloud.simple.hello;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.boot.context.properties.ConfigurationProperties;
import org.springframework.boot.context.properties.EnableConfigurationProperties;
import org.springframework.context.annotation.Configuration;
/**
* Created by crazy on 2017/11/29.
*/
@Configuration
@EnableConfigurationProperties(Properties.class)
@ConfigurationProperties(prefix = Properties.prefix, ignoreUnknownFields = false)
public class Properties {
public final static String prefix = "mysqldb.datasource";//mysqldb.datasource 是配置文件中头
@Value("${"+ prefix +".url:url null}")
private String url;
@Value("${"+ prefix +".username:username null}")
private String username;
@Value("${"+ prefix +".password:password null}")
private String password;
public String getUrl() {
return url;
}
public void setUrl(String url) {
this.url = url;
}
public String getUsername() {
return username;
}
public void setUsername(String username) {
this.username = username;
}
public String getPassword() {
return password;
}
public void setPassword(String password) {
this.password = password;
}
}
2).直接在AppController中注入调用OK了
@Autowired
private Properties properties;
@ResponseBody
@RequestMapping(value = "/")
String home() {
return "测试值:" + properties.getUsername()+"/n密码:" +properties.getPassword();
}
访问路径: http://localhost:8080/
注意:如果把配置仓库放到其他服务器,在某个项目访问配置服务器的时候,在该项目的bootstrap.yml中配置uri而不能在application中 配置uri,因为加载顺序不同,会被默认的uri覆盖
spring: application: name: cloud-simple-helloword cloud: config: uri: http://10.11.43.55:8888