微服务架构下,常见的一些基础组件的配置问题
1. CAT
CAT 是大众点评开发的一套监控数据打点的系统,主要就是将CAT客户端集成到应用中,然后由应用异步上报系统内部服务的执行情况。
CAT本身是异步的,同时作为一个应用打点系统,需要保证无论CAT是死是活都不能影响到宿主应用。实际开发过程中,确实对应用来讲没啥影响。即使是CAT挂了,应用也照样能正常运行。但这有时候,对开发人员也头疼,尤其是想要验证自己打点逻辑对不对时,经常发现在CAT上找不到自己上报的数据!
CAT是通过一个名叫client.xml
的文件,配置CAT服务器相关的信息的。如果应用启动时找不到这个文件,默认CAT啥都不处理了,然后应用本身仍然可以正常运行。
(base) ➜ cat cat client.xml
<?xml version="1.0" encoding="utf-8"?>
<config mode="client" xmlns:xsi="http://www.w3.org/2001/XMLSchema" xsi:noNamespaceSchemaLocation="config.xsd">
<servers>
<server ip="x.x.x.x" port="2280" http-port="8080"/>
<server ip="x.x.x.x" port="2280" http-port="8080"/>
</servers>
</config>
(base) ➜ cat
CAT框架默认通过环境变量获取该参数,环境变量名为CAT_HOME
,默认找的是/data/appdatas/cat/
目录下的client.xml
文件。源代码奉上:
public static String getCatHome() {
String catHome = Properties.forString().fromEnv().fromSystem().getProperty("CAT_HOME", "/data/appdatas/cat/");
return catHome;
}
这里面比较坑的地方在于,高版本的mac系统中,/data/appdatas/cat/
这个目录的内容已经不允许普通用户进行修改了。所以,使用mac作为开发机器的同学,默认本地开发的时候,CAT是完全不生效的。
建议处理方式 :如果要验证和CAT打点特性无关的功能,CAT不生效就不生效吧;如果要验证CAT打点,可以将
client.xml
文件复制到用户目录下,然后通过应用启动时设置一下CAT_HOME
环境变量指向该文件位置。
2. Kafka
参看在 MacOS 上安装 Kafka完成本地kafka的安装。
如果应用中引入了kafka的包,则kafka会默认启动:
<dependency>
<groupId>org.springframework.kafka</groupId>
<artifactId>spring-kafka</artifactId>
</dependency>
如果应用作为kafka的消费端,一般可以使用@KafkaListener
向系统注册消费服务。如下:
@Component
public class MyKafkaListener {
@KafkaListener(id="myId",
topics = "myTopic",
autoStartup = "true",
concurrency = "10"
)
public void syncDataIntoUserProperty(String message)
...
}
但这样做比较麻烦的地方在于,只要应用启动,消费端一定会被实例化。但是,有时候我们可能不需要测试和kafka相关的功能,并不想每次启动kafka都会实例化。
那只要去掉上面那段代码的@Component
注解,改用@Configuration
加上@ConditionalOnProperty
配合使用,就可以根据配置项的值决定是否需要启用消费端了。
@Configuration
@ConditionalOnProperty(prefix = "spring.kafka.kafka-listener", name = "enabled", havingValue = "true", matchIfMissing = true)
public class KafkaListenerConfiguration {
@Bean
MyKafkaListener myKafkaListener() {
return new MyKafkaListener();
}
}
这样,只要在对应的profile
下选择性地配置spring.kafka.kafka-listener.enabled
为true
或false
,就能关闭或打开kafka消费端了。
3. Apollo
Apollo 是携程开发的用于做微服务配置中心的开源框架。这个框架相对于CAT的优势在于,携程将框架和Spring项目做了深度整合,支持基于Spring Boot的自动配置模式完成框架加载。
还有个很神奇的地方,是Apollo竟然原生集成了CAT,真是让人又爱又恨!
Apollo项目提供了ApolloAutoConfiguration
配置类,这个类可以在apollo-client
包中找到,主要用来启动Apollo相关功能。
@Configuration
@ConditionalOnProperty(PropertySourcesConstants.APOLLO_BOOTSTRAP_ENABLED)
@ConditionalOnMissingBean(PropertySourcesProcessor.class)
public class ApolloAutoConfiguration
这个上面有一个PropertySourcesConstants.APOLLO_BOOTSTRAP_ENABLED
,看一下常量值:
String APOLLO_BOOTSTRAP_ENABLED = "apollo.bootstrap.enabled";
因此,可以在配置文件中,增加apollo.bootstrap.enabled
配置项,控制Apollo的启用。