环境
jdk1.8,maven,idea,rabbitmq,docker,码云。
配置中心
使用配置中心的目的,一个是方便维护,一个是为了配置内容的安全和权限,因为各自有各自的配置在远端git上。这样的话就进行隔离。最重要的一点是自动刷新配置。
远端git我这里用的是码云,这张图就是说config-server从远端git把配置拉下来,然后在本地git同步一份,如果远端不能使用,那么能使用本地,然后再给服务使用。
创建项目,进行配置
1,创建一个项目,作为config使用。
在启动类上添加注解
@EnableConfigServer
2,在git上创建一个项目进行提交服务的配置
3,在config-server端进行填写配置
spring:
application:
name: config-server
cloud:
config:
server:
git:
uri: git远端的url
username: 用户名
password: 密码
basedir: 存放配置的本地路径
4,在客户端进行添加依赖和配置
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-config-client</artifactId>
</dependency>
spring:
application:
name: order
cloud:
config:
# 发现配置中新的服务器端
discovery:
enabled: true
service-id: CONFIG-SERVER
# 文件名
profile: test
在这里我们应该注意,这是我们访问的格式
当远端有order.yml和order-test.yml两个配置文件的时候,优先访问order.yml,这样的话,如果两个配置了一样的文件,但是端口号不同,这个时候就会出现访问的不是你要的。
此时配置已经完成,启动Eureka和Config配置中心,直接进行访问远端的配置文件。
http://localhost:8080/order-profile.yml
这里的profile可以随意填写,上面有格式可以参考。
自动刷新配置
我们平常比较困难的一个地方就是重写配置之后进行刷新的话必须要重新运行方法。
1,运行你的rabbitmq,可以不在docker上,这里docker运行rabbitmq不做介绍。
2,服务器端配置
【application.yml】
spring:
application:
name: config-server
cloud:
config:
server:
git:
uri: git远端的url
username: 用户名
password: 密码
basedir: 存放配置的本地路径
#自动刷新
bus:
refresh:
enabled: true
rabbitmq:
host: rabbitmq的主机名
eureka:
client:
service-url:
defaultZone: http://localhost:8762/eureka/
#进行暴露服务
management:
endpoints:
web:
exposure:
include: "*"
我们可以看到这是rabbitmq的默认配置
【启动类上】
@EnableConfigServer
【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>
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>2.0.6.RELEASE</version>
<relativePath/> <!-- lookup parent from repository -->
</parent>
<groupId>com.springcloud</groupId>
<artifactId>config</artifactId>
<version>0.0.1-SNAPSHOT</version>
<name>config</name>
<description>Demo project for Spring Boot</description>
<properties>
<java.version>1.8</java.version>
<spring-cloud.version>Finchley.SR2</spring-cloud.version>
</properties>
<dependencies>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-config-server</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-bus-amqp</artifactId>
</dependency>
<dependency>
<groupId>org.projectlombok</groupId>
<artifactId>lombok</artifactId>
<optional>true</optional>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
<scope>test</scope>
</dependency>
</dependencies>
<dependencyManagement>
<dependencies>
<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>
</plugin>
</plugins>
</build>
</project>
3,客户端配置
【bootstrap.yml】
bootstrap.yml和application.yml的区别就是
bootstrap.yml先加载,bootstrap.yml 由父Spring ApplicationContext加载。
父ApplicationContext 被加载到使用 application.yml 的之前。
spring:
application:
name: order
cloud:
config:
# 发现配置中新的服务器端
discovery:
enabled: true
service-id: CONFIG-SERVER
# 文件名
profile: test
# 自动刷新
bus:
refresh:
enabled: true
rabbitmq:
host: rabbitmq的主机名
eureka:
client:
service-url:
defaultZone: http://localhost:8762/eureka
【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">
<parent>
<artifactId>order</artifactId>
<groupId>com.springcloud</groupId>
<version>0.0.1-SNAPSHOT</version>
</parent>
<modelVersion>4.0.0</modelVersion>
<artifactId>order-server</artifactId>
<dependencies>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-config-client</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
<scope>test</scope>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-data-jpa</artifactId>
</dependency>
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
</dependency>
<dependency>
<groupId>org.projectlombok</groupId>
<artifactId>lombok</artifactId>
</dependency>
<dependency>
<groupId>com.google.code.gson</groupId>
<artifactId>gson</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-openfeign</artifactId>
</dependency>
<dependency>
<groupId>com.springcloud</groupId>
<artifactId>product-common</artifactId>
<version>0.0.1-SNAPSHOT</version>
</dependency>
<dependency>
<groupId>com.springcloud</groupId>
<artifactId>product-client</artifactId>
</dependency>
<dependency>
<groupId>com.springcloud</groupId>
<artifactId>order-common</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-config-client</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-bus-amqp</artifactId>
</dependency>
</dependencies>
<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
</plugin>
</plugins>
</build>
</project>
【GirlConfig.java】
@Data
@Component
//扫描配置
@ConfigurationProperties("girl")
//刷新哪个类就在那个上面加上这个注解
@RefreshScope
public class GirlConfig {
private String name;
private Integer age;
}
【GirlController.java】
@RestController
public class GirlController {
@Autowired
private GirlConfig girlConfig;
@GetMapping("/girl/print")
public String print(){
return "name:"+girlConfig.getName()+",age:"+girlConfig.getAge();
}
}
注意
在进行配置改变刷新之前要进行一步post提交操作。我们可以在码云上进行配置一下,或者每次都进行手动提交。
【手动提交】
curl -v -X POST “http://localhost:8080/actuator/bus-refresh”。
这里的端口号是config-server的。
【自动提交】
spring cloud bus就是用来操作消息队列,config-server和product,order进行消息通信。config-server提供了消息通信后对外提供一个消息接口/bus-refresh。远端的git进行访问这个接口。Git接口一般提供webhooks这个功能。
提交之后rabbitmq会有这样的变化。
码云上配置一下。
【远端git】
坑
1,版本要一致
2,一定要写双引号""
management:
endpoints:
web:
exposure:
include: "*"