一文吃透微服务配置中心:SpringCloudConfig

在原有工程中创建一个moudle,命名为config,在pom.xml加入配置中心的依赖:

org.springframework.cloud

spring-cloud-config-server</ artifactId></ dependency>

common</ artifactId>com. lynn.blog

1.8-SNAPSHOT

在上述依赖中,我们加入了spring-cloud-config-server依赖,该依赖为配置中心的服务端依赖,有了它我们就可以将当前工程作为配置中心的服务端工程。

(3)创建启动类ConfigApplication:

@EnableConfigServer

public class ConfigApplication extends Application{

public static void main(String[] args){

Application.startup(ConfigApplication.class,args);

}

}

可以看到,我们添加了@EnableConfigServer注解,用来启用配置中心服务端。启动类ConfigApplication继承了Application类。

其实,Application类是一个公共的启动父类,所有工程的启动入口都继承了该类并提供了一个静态方法以调用SpringApplication。我们提供这样一个类主要是因为每个SpringCloud子工程的启动类都需要加入了@SpringCloudApplication注解,于是每个子工程的启动类只要继承了Application类,就无须再添加@SpringCloudApplication注解,Application类的代码如下:

@SpringCloudApplication

@Componentscan(basePackages = “com.lynn.blog”)public abstract class Application {

public static void startup(class<?> cls,string[] args){

SpringApplication.run(cls,args);

}

}

我们将Application 设置为抽象类,因为它无须实例化并且提供了静态方法 startup,该方法调用了SpringApplication.run方法,因此在ConfigApplication中直接调用startup方法就可以启动该应用。

读者应该也会注意到,Application类除了添加了@SpringCloudApplication 注解外,还添加了@ComponentScan注解,该注解可以在应用启动后,指定扫描的根包名。由于每个工程的根包名都不一样,比如 register工程为 com.lynn.blog.register,config 工程为 com.lynn.blog.config,而Application类是放到common工程中的,其根包名为com.lynn.blog.common,所以如果不指定扫描的包名,Spring容器会默认扫描com.lynn.blog.common包,导致每个子工程的服务和控制器都无法被扫描到,从而无法注人。虽然根包名都不一样,但是它们都处于com.lynn.blog包下,因此我们可以指定根包名为com.lynn.blog,这样Spring就可以扫描到整个项目。

(4)创建application.yml并增加如下内容:

server:

port: 8102spring:

application:

name: configcloud:

client:

ip-address:127.e.e.1config:

server:

git:

uri: https://github.com/lynnlovemin/SpringCloudActivity.git#配置存放到这个目录下

searchPaths: configusername:*password:零宗

#使用master分支的配置label: master

eureka:

instance:

prefer-ip-address: trueclient:

register-with-eureka: truefetch-registry : true

service-url:

defaultZone: http://admin: admin123@localhost:8101/eureka/

Spring Cloud Config默认的配置仓库为Git,因此无须在配置中告诉Spring Cloud Config,直接设置Git仓库的地址、用户名和密码即可。

在上述配置中,spring.config.server.git.uri为Git仓库所在的 HTTP地址,searchPaths为该仓库的根目录,username为Git仓库用户名,password为Git仓库密码,spring.config.label为分支名,本示例设置为master(主干)分支。图8-1展示了Git仓库的截图。

一文吃透微服务配置中心:SpringCloudConfig

可以看到,具体的配置文件其实是放到仓库的config目录下的,因此上述配置的searchPaths需要指定为config。

现在分别启动register和l config,并访问localhost:8101,就可以看到如图8-2所示的界面。

一文吃透微服务配置中心:SpringCloudConfig

至此,配置中心服务端搭建完成。

接下来,我们改造test工程。将工程的配置放到Git仓库中并验证程序是否能够通过配置中心将配置拉取下来。

(1)在我们的Git仓库下创建一个文件,命名为test.yml,将本地配置文件内容复制到test.yml 中并删除test工程的application.yml,如图8-3所示。

一文吃透微服务配置中心:SpringCloudConfig

(2)在resources下创建 bootstrap.yml 文件,内容如下(注意,这里必须命名为bootstrap.yml,而不是 application.yml ):

spring:

cloud :

config:

#要拉取的配置文件名,多个配置文件以逗号隔开name : test

label : masterdiscovery :

enabled: true

#配置中心spring.application.name指定的名字serviceId: config

eureka:

client:

service-url:

defaultzone: http: / / admin : admin123@localhost:8101/eureka/

其中,sping.cloud.config.name表示要拉取的配置文件名。前面我们已经创建了test.yml,因此这里指定了文件名为test,我们也可以指定多个配置文件,中间以逗号隔开。由于不同的工程可能有相同的配置信息,所以可以考虑增加一个数据库的配置文件,在有数据库连接需求的工程上增加该配置文件。这样的话,如果数据库信息发生改变,只需要改变数据库的配置文件即可,大大提升了应用的可扩展性。

Spring.cloud.config.label指定了要拉取的分支,本示例指定为主干分支,discovery.enabled指定是否拉取配置,serviceId指定了配置中心的名字,该名字为config工程spring. application.name指定的名字。

配置中心同样支持多环境配置,增加test-dev.yml配置文件,在 bootstrap.yml中添加代码spring.cloud.config.profile=devR就会拉取test-dev.yml 的信息。

(3)启动test,可以看到控制台打印出了启动端口9999:

Tomcat initialized with port(s):9999(http)

这时如果将test.yml文件中的端口号改为9998,重启test后可以看到其启动端口已设置为9998,那么说明test已成功从Git仓库拉取了对应的配置。

对配置内容进行加密

=========

Spring Cloud Config在Git仓库下默认是以明文存在的。在某些场景下,我们需要对一些敏感数据(如数据库账号、密码等)进行加密存储。

Spring Cloud Config支持对配置内容进行加密存储,下面我们就来看一下如何使用加密功能。8.3.1安装JCE

由于Config Server依赖Java Cryptography Extension(简称JCE ),所以在使用加密功能前我们应先安装JCE。JCE的安装非常简单,只需要下载JCE包(详见 http://www.oracle.com/technetwork/javaljavase/downloads/jce8-download-2133166.html ),如图8-4所示。

一文吃透微服务配置中心:SpringCloudConfig

然后解压并替换JDK安装目录下jre/lib/security的两个jar包,如图8-5所示。

一文吃透微服务配置中心:SpringCloudConfig

如果没有security目录,则手动创建该目录。

最后需要重启IDEA,否则可能会报错:

{

“description” :“No key was installed for encryption service",“status”:“NO_KEY”

}

至此,JCE就安装完成了。Config Server同时支持对称加密和非对称加密,第4章已经介绍过两者的区别。

对称加密

Config Server默认的加密算法为对称加密算法。首先,在config 工程下新增bootstrap.yml,并设置对称加密的密钥:

encrypt:

key : springcloud

启动config,Config Server会开启encrypt和 decrypt两个端点,通过postman°可以测试其加密和l解密效果,如图8-6和图8-7所示。

一文吃透微服务配置中心:SpringCloudConfig

一文吃透微服务配置中心:SpringCloudConfig

对配置内容加密

我们可以使用{cipher}标识对配置内容进行加密,修改Git仓库的test.yml文件,增加内容如下:

data:

message: ‘{cipher} b47b603d1c5551773a2385c6dafebcebf1b5a980ed08171c47ceeb226dd9f7ed’

其中,b47b603d1c5551773a2385c6dafebcebf1b5a9800de8171c47c0eb226dd9f7ed 为前面通过postman加密后的字符串。

重启config工程,在浏览器中访问localhost:8102/test-default.yml,可以看到如图8-8所示的内容。

一文吃透微服务配置中心:SpringCloudConfig

通过图8-8可以看到,Config Server已经将我们加密的内容解密为明文了。

非对称加密

Config Server同样支持非对称加密。与对称加密方法不同,非对称加密的思想是生成两个key :公钥和私钥。公钥用于加密,私钥用于解密。因此,非对称加密安全性更高,同时效率也相对较差。

(1)进入Java安装目录通过keytool生成keystore:

keytool -genkeypair -alias serverkey -keyalg RSA -keystore D:/server.jks

根据提示输入相应内容,如图8-9所示。其中,-keystore后面紧跟密钥文件的路径。如果生成失败,请尝试用管理员权限启动cmd命令行。

一文吃透微服务配置中心:SpringCloudConfig

(2)将server.jks复制到config工程的resources目录下,如图8-10所示。

一文吃透微服务配置中心:SpringCloudConfig

(3)修改bootstrap.yml,增加以下内容:

encrypt:

keyStore:

location: classpath : server.jks

password: 111111alias: serverkeysecret: 111111

其中,password 为上面设置的密钥库口令,而secret为上面设置的密钥口令,读者一定要区分密钥库口令和密钥口令,两个口令可以相同也可以不同; location为密钥文件路径,由于Maven编译后,会将resources 的所有文件复制到classes目录下,因此这里指定classpath即可; alias为上面命令中-alias后面设置的字符串。

(4)修改pom.xml文件:

src/main/resourcestrue

**/*.jks

src/main/resourcesfalse

**/*.jks

由于第一个配置中设置了为true,Maven在编译时不会原样复制,而会做一定的处理再复制到classes下,所以为了保证密钥文件不被破坏,需要利用排除.jks结尾的文件。设置filtering为true时,Maven 会替换placeholder占位符,再复制,在第一个配置中排除了.jks文件,Maven不会复制.jks文件,因此还需要将filtering 设置为false,并通过<include〉将.jks文件包含进去,保证 Maven 会将.jks文件原样复制。

(5)启动config 工程,分别访问地址localhost:8102/encrypt 和 localhost:8102/decrypt,能够得到加密和解密后的结果,如图8-11和图8-12所示。

一文吃透微服务配置中心:SpringCloudConfig

一文吃透微服务配置中心:SpringCloudConfig

如果报以下错误,请读者用mvn clean package命令重新编译打包工程:

配置自动刷新

======

有些时候,我们可能会通过修改一些配置来达到我们的期望,如数据库地址发生变化时需要修改配置。如果不进行任何处理,那么每次修改配置都需要重启服务,而一个大型系统可能有成千上万个服务,每个服务都需要重启的话,代价无疑是很巨大的。

Spring Cloud Config 为我们提供了配置的刷新机制,不用重启服务就可以在线修改配置文件。

使用refresh端点刷新配置

我们首先研究手动刷新配置,其方法非常简单。

(1)添加Actuator依赖(Actuator自带refresh端点):

org.springframework.boot

spring-boot-starter-actuator

该依赖已在common 工程中添加,这里单独说明是为了告诉读者refresh端点依赖哪个包。(2)在test工程下创建一个控制器,便于我们测试:

@RestController

@RefreshScope

public class Testcontroller {

@Value(“$idata.message}”)private String port;

@RequestMapping(“test”)public String test(){

return port;

}

}

可以发现,在TestController中新加入了@RefreshScope注解,作用是告诉refresh端点刷新该类所引用的配置。

(3)在Git仓库的test.yml中开启refresh端点,并将data.message 的值修改为test1:

management:

endpoints :

web:

exposure:

include: refresh,health,info

在Spring Boot 2.0以后,Actuator默认只启动health和info两个端点,无法自动开启refresh端点,需要额外增加配置。

(4)测试。

①分别启动register、config和 test三个工程。②访问localhost:9999/test,返回数据testl。

③修改test.yml,将data.message的值改为test2,并重新执行步骤②,发现返回数据并未发生改变。

④用postman请求refresh端点,如图8-13所示。

一文吃透微服务配置中心:SpringCloudConfig

自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数Java工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年Java开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Java开发知识点,真正体系化!

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!

如果你觉得这些内容对你有帮助,可以扫码获取!!(备注Java获取)

img

最后

面试题文档来啦,内容很多,485页!

由于笔记的内容太多,没办法全部展示出来,下面只截取部分内容展示。

1111道Java工程师必问面试题

MyBatis 27题 + ZooKeeper 25题 + Dubbo 30题:

Elasticsearch 24 题 +Memcached + Redis 40题:

Spring 26 题+ 微服务 27题+ Linux 45题:

Java面试题合集:

《互联网大厂面试真题解析、进阶开发核心学习笔记、全套讲解视频、实战项目源码讲义》点击传送门即可获取!
oom: 33%;" />

最后

面试题文档来啦,内容很多,485页!

由于笔记的内容太多,没办法全部展示出来,下面只截取部分内容展示。

1111道Java工程师必问面试题

[外链图片转存中…(img-kZ2SXPH3-1713433049025)]

MyBatis 27题 + ZooKeeper 25题 + Dubbo 30题:

[外链图片转存中…(img-pf9EAkfH-1713433049025)]

Elasticsearch 24 题 +Memcached + Redis 40题:

[外链图片转存中…(img-CM91tfBs-1713433049025)]

Spring 26 题+ 微服务 27题+ Linux 45题:

[外链图片转存中…(img-PO17wZJk-1713433049026)]

Java面试题合集:

[外链图片转存中…(img-YoXK4rN6-1713433049026)]

《互联网大厂面试真题解析、进阶开发核心学习笔记、全套讲解视频、实战项目源码讲义》点击传送门即可获取!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值