服务注册与调用入门

  1. 为什么要将服务注册到Nacos?(为了更好的查找这些服务)
  2. 在Nacos中服务提供者是如何向Nacos注册中心(Registry)续约的?(5秒心跳包)
  3. 对于Nacos来讲它是如何判断服务实例的状态?(检测心跳包 ,15,30)
  4. 服务消费方是如何调用服务提供方的服务的?(RestTemplate)

服务负载均衡设计及实现

  1. @Bean注解的作用?(一般用于配置类内部,描述相关方法,用于告诉spring此方法的返回值要交给spring容器管理,bean的名字默认为方法名,假如需要指定名字可以@Bean("bean的名字"),最多的应用场景是整合第三方资源-对象)
  2. @Autowired注解的作用?(此注解用于描述属性,构造方法,set方法等,用于告诉sprin框架,按照一定的规则为属性进行DI操作,默认按属性,方法参数类型查找对应的对象。假如只找到一个,则直接注入,类型多个时还会按照属性名或方法参数名进行值的注入,加入名字也不同,就会报错)
  3. Nacos中的负载均衡底层是如何实现的?(通过Ribbon实现,Ribbon中定义了一些负载均衡算法,然后基于这些算法从服务实例中获取一个实例为消费方法提供服务)
  4. Ribbon是什么?(Netflix公司提供的负载均衡客户端,一般应用于服务的消费方法)
  5. Ribbon可以解决什么问题?(基于负载均衡策略进行服务调用,所有策略都会实现IRule接口)
  6. Ribbon内置的负载均衡策略有哪些?(8种,可以通过查看IRule接口的实现类进行分析)
  7. @LoadBalanced的作用是什么?(描述RestTemplate对象,用于告诉spring框架,在使用RestTemplate进行服务调用时,这个调用过程会被一个拦截器进行拦截,然后在拦截器内部启动负载均衡策略)
  8. 我们可以自己定义负载均衡策略吗?(可以,基于IRule接口进行策略定义,也可以参考NacosRule进行实现)

基于Feign的远程服务调用

  1. 为什么使用feign?(基于Feign可以更加友好的实现服务调用,简化服务消费方对服务提供方方法的调用)
  2. FeignClient注解的作用是什么?(告诉Feign Starte,在项目启动时,为此注解描述的接口创建实现类-代理类)
  3. Feign方式的调用,,底层负载均衡是如何实现的?(Ribbon)
  4. EnableFeignClients注解的作用是什么?(描述配置类,例如启动类)

配置中心

  1. 什么是配置中心?(存储项目配置信息的一个服务)
  2. 为什么要使用配置中心?(集中管理配置信息,动态发布配置信息)
  3. 市场有哪些主流的配置中心?(Apollo,Nacos,.....)

配置中心快速入门

  1. 配置中心一般都会配置什么内容?(可能会经常变化的配置信息,例如连接池,日志,线程池,限流熔断规则)
  2. 什么信息一般不会写到配置中心?(服务端口,服务名,服务的注册地址,配置中心)
  3. 项目中为什么要定义bootstrap.yml文件?(此文件被读取的优先级比较高,可以在服务启动时读取配置中心的数据)
  4. Nacos配置中心宕机了,我们的服务还可以读取到配置信息吗?(可以从内存,客户端获取配置中心的配置信息以后,会将配置信息在本地存储一份)
  5. 微服务应用中我们的客户端如何从配置中心获取信息?(我们的服务一般会先从内存中读取配置信息,同时我们的微服务还可以定时向nacos配置中心发请求拉取(pull)更新的配置信息)
  6. 微服务应用中客户端如何感知配置中心的数据变化?(1.4.x版本以后nacos客户端会基于长轮询机制从nacos获取配置信息,所谓的长轮询就是没有配置更新时,会在nacos服务端的队列进行等待)
  7. 服务启动后没有从配置中心获取我们的配置数据是什么原因?(依赖,配置文件名字bootstrap.yml,配置中心的DataId名字是否正确,缩进关系是否正确,假如是动态发布,类上是否有@RefreshScope注解)
  8. 你项目中使用的日志规范是什么?(SLF4J)
  9. 你了解项目中的日志级别吗?(debug,info,error,可以基于日志级别控制日志的输出)

Nacos配置管理模型

  1. Nacos配置管理模型背景?(环境不同,配置不同)
  2. Nacos配置中的管理模型是怎样的?(namespace,group,service/data-id)
  3. Nacos客户端是否可以读取共享配置?(可以)