文章目录
前言
一、过程调用分类
1.本地调用(Local Procedure Call,简称LPC)
2.远程调用(Remote Procedure Call,简称RPC)
二、API/SDK的区别是什么?
开发过程中,我们经常需要调用别人写的功能
三、WebClient
四、消息服务
目录
前言
一、过程调用分类
1.本地调用(Local Procedure Call,简称LPC)
a(); b(); a(){b();}: 不同的方法在同一个JVM中运行
2.远程调用(Remote Procedure Call,简称RPC)
- 服务提供者
- 服务消费者
- 通过连接对方服务器进行请求\响应交互,来实现调用效果
二、API/SDK的区别是什么?
- api: 接口(Application Programming Interface)
- 远程提供功能
- sdk:工具包(Soft Development Kit)
- 导入jar包,直接调用功能
-
开发过程中,我们经常需要调用别人写的功能
- 如果是内部微服务,可以通过依赖cloud,注册中心,openfeign等进行调用
- 依赖cloud指的是springcloud依赖
- 注册中心指的就是Nacos,微服务时代的服务管理,在微服务时代,我们所有的服务都被尽量的拆分成最小的粒度,原先所有的服务都混在一个server里,现在就被按照功能或者对象拆分成N个服务模块,这样做的好处是深度解耦,一个模块只负责自己的事情就好,能够实现快速的迭代更新.画出是服务的管理和控制变得异常复杂和繁琐,人工维护难度变大,以及排查问题和性能也变差了(因为服务调用时的网络开销)
- 注册中心干嘛的? 是进行存放和调度服务的,实现服务和注册中心,服务和服务之间的相互通信
- 没有注册中心会咋样? 将其他模块的IP和端口写死在自己的配置文件里面,甚至写死在代码里,每次要去新增或者移除1个服务的实例的时候,就得去通知其他所有相关联的服务去修改.
- OpenFeign是Spring Cloud家族的一个成员,它最核心的作用是为HTTP形式的RestAPI提供了非常简洁高效的RPC调用方式.它的用途:服务发现,负载均衡,服务调用
- 如果是外部暴露的,可以发送HTTP请求,或者遵循外部协议进行调用
- Springboot整合提供了很多方式进行远程调用
- 轻量级的客户端方式:
- RestTemplate:普通开发
- WebClient:响应式变成开发
- Http Interface:声明式编程
- spring Cloud分布式解决方案方式
- Spring Cloud OpenFeign
- 第三方框架
- Dubbo
- gRPC
- 轻量级的客户端方式:
- 如果是内部微服务,可以通过依赖cloud,注册中心,openfeign等进行调用
三、WebClient
非阻塞,响应式HTTP客户端
- 创建WebClient.create()
- WebClient.create()
- WebClient.create(String baseUrl)
- 代码举例:WebClient client = WebClient.create("https://example.org");
四、消息服务
- 消息队列场景
- 异步
- 解耦
- 削峰
- 缓冲
- 消息队列-Kafka
- 消息点对点模式
- 消息发布订阅模式
- Kafka工作原理
- 分区:海量数据分赛存储
- 副本:每个数据区都有备份
- 特点:同一个消费者里面的消费者是队列竞争模式,不同消费者组里面的消费者是发布/订阅模式,一个消费者可以消费多个分区的数据
- Kafka自动配置设置
- kafka自动配置在KafkaAutoConfiguration
- 容器中放了KafkaTemplate可以进行消息收发
- 容器中放了KafkaAdmin可以进行Kafka的管理,比如创建topic等
- kafka的配置在KafkaProperties中
- @EnableKafka可以开启基于注解的模式
总结
参考和学习文档:
微服务:注册中心的作用_Chloe_RO的博客-CSDN博客
感谢尚硅谷spring6语雀文档的学习