CAT、Kafka 以及 Apollo

微服务架构下,常见的一些基础组件的配置问题

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.enabledtruefalse,就能关闭或打开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的启用。

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

镜悬xhs

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值