一般来说,开发一个项目会实现很多个服务接口,以前的做法是可以将全部接口糅合一起对外提供服务,但在现在,越来越提倡微服务理念,这种做法明显与微服务的理念背道而驰。更合理的做法,就是对项目进行服务拆分,使项目被拆分成多个小的服务,而服务采用面向接口的编程,这将极大的有利于项目的扩展和团队分工。
使用IDEA,开发SpringBoot时,可以在一个项目下创建多个Module来进行服务拆分。每个Module可以有自己的配置,但难免会有一些配置是相同,比如数据库的配置,每个module都配置的话很麻烦而且不易于修改。所以,这篇文章里,我们要实现两个目标:
(1) 多个Module共用一套配置文件;
(2) 配置文件可以灵活切换环境,比如测试环境/开发环境,只需在共用的配置文件中切换指定的环境,就能实现多个module同时切换到指定的环境。
新建一个SpringBoot的demo工程,在该工程下分别创建三个modue:config、module_a,module_b,其中,config是共用的模块,我们把共用的配置文件部署到config中,其他模块通过依赖config来使用共用的配置。
一、共用模块的配置
首先,config模块下的启动类、测试类都删掉,配置文件一定要以application-XX的形式命名,不然其他模块无法识别。
config模块的结构如下:
其中,application-dev.properties表示开发环境下的配置:
spring.datasource.url=url_dev spring.datasource.name=name_dev
application-test.properties表示测试环境下的配置:
spring.datasource.url=url_test spring.datasource.name=name_test
application-prod.properties表示正式环境下的配置:
spring.datasource.url=url_prod spring.datasource.name=name_prod
application-config.properties是config模块的配置。
由于config模块已删除启动类及其测试类,因此需改动默认的pom文件配置:
<build> <plugins> <plugin> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-maven-plugin</artifactId> </plugin> </plugins> </build>
上面这段配置需删除掉,或者注释掉,否则打包时会报错。
然后右键pom文件,选择install,打包以备其他模块引用。
二、其他模块引用共用模块的配置文件
以模块A为例,要想引用config的配置
1、必须在pom中添加config的依赖:
<dependency> <groupId>org.stone.example</groupId> <artifactId>config</artifactId> <version>0.0.1-SNAPSHOT</version> </dependency>
2、在application.properties配置文件中包含config:
spring.profiles.include=config #激活测试环境配置 spring.profiles.active=test
强调一下,必须是spring.profiles.include!这样就可以使用config模块的公共配置了。我们来试验一下,写一个控制器:
package org.stone.example.module_a; import org.springframework.beans.factory.annotation.Value; import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.RestController; @RequestMapping("moduleA") @RestController public class ModuleAController { @Value("${spring.datasource.url}") private String url; @Value("${spring.datasource.name}") private String name; @RequestMapping("hello") public String helloModuleA() { System.out.println("url: " + url); System.out.println("name: " + name); return "Hello moduleA! url=" + url + ", name=" + name; } }
这里采用@Value
注解的方式引用配置,运行模块A的启动类ModuleAApplication,在地址栏中输入:http://127.0.0.1:8080/moduleA/hello
结果如下:
引用成功!其他模块要使用config的公共配置也遵循以上步骤即可。
摘自:https://blog.csdn.net/ganmaotong/article/details/103223009