Springboot、dubbo、zk面试知识点

知识点补充

一、SpringBoot

1.1 SpringBoot的自动装配原理

从以下几个方面回答:

  1. 什么是 SpringBoot 自动装配?
  2. SpringBoot 是如何实现自动装配的?如何实现按需加载?
  3. 如何实现一个 Starter?

什么是 SpringBoot 自动装配

没有 Spring Boot 的情况下,如果我们需要引入第三方依赖,需要手动配置,非常麻烦。但是,Spring Boot 中,我们直接引入一个 starter 即可。比如你想要在项目中使用 redis 的话,直接在项目中引入对应的 starter 即可。

<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-data-redis</artifactId>
</dependency>

引入 starter 之后,我们通过少量注解和一些简单的配置就能使用第三方组件提供的功能了。

SpringBoot 是如何实现自动装配的

SpringBoot的启动类里面有一个@SpringBootApplication注解,点进去里面有三个注解:

  • @EnableAutoConfiguration:启用 SpringBoot 的自动配置机制
  • @SpringBootConfiguration:允许在上下文中注册额外的 bean 或导入其他配置类
  • @ComponentScan: 扫描被@Component (@Service,@Controller)注解的 bean,注解默认会扫描启动类所在的包下所有的类 ,可以自定义不扫描某些 bean。如下图所示,容器中将排除TypeExcludeFilterAutoConfigurationExcludeFilter

@EnableAutoConfiguration 是实现自动装配的重要注解,我们以这个注解入手。

EnableAutoConfiguration 只是一个简单地注解,自动装配核心功能的实现实际是通过 AutoConfigurationImportSelector类,AutoConfigurationImportSelector 类实现了 ImportSelector接口,也就实现了这个接口中的 selectImports方法,该方法主要用于获取所有符合条件的类的全限定类名,这些类需要被加载到 IoC 容器中

private static final String[] NO_IMPORTS = new String[0];

public String[] selectImports(AnnotationMetadata annotationMetadata) {
        // <1>.判断自动装配开关是否打开
        if (!this.isEnabled(annotationMetadata)) {
            return NO_IMPORTS;
        } else {
          //<2>.获取所有需要装配的bean
            AutoConfigurationMetadata autoConfigurationMetadata = AutoConfigurationMetadataLoader.loadMetadata(this.beanClassLoader);
            AutoConfigurationImportSelector.AutoConfigurationEntry autoConfigurationEntry = this.getAutoConfigurationEntry(autoConfigurationMetadata, annotationMetadata);
            return StringUtils.toStringArray(autoConfigurationEntry.getConfigurations());
        }
    }

selectImports方法里还调用了getAutoConfigurationEntry()方法,这个方法主负责加载自动配置类。该方法调用链如下:

img

总结

Spring Boot 通过@EnableAutoConfiguration开启自动装配,通过 SpringFactoriesLoader 最终加载META-INF/spring.factories中的自动配置类实现自动装配,自动配置类其实就是通过@ConditionalXXX按需加载的配置类(例如@ConditionalOnClass这有这个类存在的时时候才会加载)想要其生效必须引入spring-boot-starter-xxx包实现起步依赖

自己的语言:
在springboot的启动类中有一个@SpringBootApplicaiton注解,这是一个组合注解他 下面有三个比较核心的注解,分别是:springBootCon,E,C而实现 自动装配最核心的就是E注解,这个注解里面@import了一个AutoConfigurationImportSelector类,这个类实现了ImportSelector接口的selectImports方法,这个方法会返回类的全限定名的一个数组。而这个数组是怎么来的呢?继续跟代码你会发现它最终是通过SpringFactoriesLoader的loadSpringFactories方法加载了meta-info目录下的spring.factories文件。这个文件里配置了哪些需要自动装配,是否生效则取决于配置类的conditional条件是否满足,例如conditionOnClass就规定必须出现了哪个类的时候才能启动自动装配,而我们一般如果我们导入了对应的starter依赖这个条件就会激活。

二、dubbo

2.1 说一下dubbo

dubbo是一个高性能轻量级的开源Java RPC框架:它提供了三大核心能力:

  • 面向接口的远程方法调用
  • 智能容错和负载均衡
  • 以及服务自动注册于发现

什么是RPC?

英文remote produce call 翻译过来就是远程过程调用它允许我们程序像调用本地一样调用另一天服务器上的代码。里面主要有两个核心模块:一个是通信,另一个是序列化。

dubbo核心组件

  • Provider:暴露服务的服务提供方
  • Consumer:调用远程服务消费方
  • Registry:服务注册与发现注册中心
  • Monitor:监控中心和访问调用统计
  • Container:服务运行容器

三、ZooKeeper

是什么

是一个为分布式应用提供协调服务的框架,他有这么一些应用场景:统一命名服务、统一配置管理、统一集群管理、服务器节点动态上下线、软负载均衡等。如果从设计模式的角度去理解它是基于观察者设计模式设计的分布式管理框架。它负责存储和管理大家都关心的数据,然后接受观察这的注册。如果有服务发生变动则会通知观察者。

四、零碎的点

关于final关键字的使用

五、项目中技术的应用场景

ConcurrentHashMap怎么用的

ThreadLocal怎

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值