这篇文章主要介绍笔者一个动态依赖注入组件。具体介绍请前往github查看,这里不再过多重复赘述。本文主要以一个实际例子来演示其强大特性。
github 源码:动态依赖注入组件
这里贴一下组件的原理图:
需求背景
在大促等高峰流量场景下,我们为了能在大促期间抗住高峰流量,我们往往会给服务加机子,或者提升配置来提高服务的服务能力。在大促后,回收机子,减少资源耗费。这是常规操作。但在代码优化里,我们也往往会在大促期间针对大促的流量高峰特点,定制特定服务接口实现来提供服务,待大促后,切换为常规服务接口实现。
这种切换说白了就是动态依赖注入。那么如何实时动态依赖注入呢?这是这个组件的特性。我们接下来看看怎么实现。
编码实现
1、引入组件依赖
<dependency>
<groupId>red.honey</groupId>
<artifactId>spring-context-config-support</artifactId>
<version>1.0.0</version>
</dependency>
2、启动类打@EnableHoneySpringSupport。这里笔者用的是Nacos来演示,配置格式yaml
@SpringBootApplication
@EnableHoneySpringSupport(type = ConfigType.YAML)
public class DemoApplication {
public static void main(String[] args) {
SpringApplication.run(DemoApplication.class, args);
}
}
3、编写服务接口及其多种接口实现
public interface SomeService {
public void doSomething();
}
@Primary
@Service
public class AService implements SomeService {
private Logger log = LoggerFactory.getLogger(AService.class);
@Override
public void doSomething() {
log.info("I am A service ......");
}
}
@Service
public class BService implements SomeService {
private Logger log = LoggerFactory.getLogger(BService.class);
@Override
public void doSomething() {
log.info("I am B service .....");
}
}
@Service
public class CService implements SomeService {
private Logger log = LoggerFactory.getLogger(CService.class);
@Override
public void doSomething() {
log.info("I am C service .....");
}
}
4、新建一个controller,暴露一个say方法。添加
@RestController
@RefreshInjected
public class HoneyComponent {
private Logger log = LoggerFactory.getLogger(HoneyComponent.class);
@Autowired
@FieldRefresh(name = "service")
private SomeService service;
@GetMapping("/do")
public void say() {
service.doSomething();
}
}
5、启动服务,并调用say,成功执行Aservice的实现。(因为它是@Primary首先注入的)
6、Nacos控制台修改。添加一个key,该key的名称为与 @FieldRefresh注解的name属性一致,值value需为Ioc的所需的BeanName。
意思是动态注入Bservice这个bean,走Bservice实现。我们再请求一次
我们再改为CService,让它走CService实现,并再求一次
以上就是spring-context-config-support组件的具体使用啦。后面想到更好的特性,笔者再迭代更新
本文就到此结束了,我们下文见,谢谢
github: honey开源系列组件作者