RPC(远程过程调用)与消息队列介绍

news2024/11/24 19:10:54

文章目录

前言

一、过程调用分类

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的区别是什么?

  1. api: 接口(Application Programming Interface)
    1. 远程提供功能
  2. sdk:工具包(Soft Development Kit)
    1. 导入jar包,直接调用功能
  3.   开发过程中,我们经常需要调用别人写的功能

    1. 如果是内部微服务,可以通过依赖cloud,注册中心,openfeign等进行调用
      1. 依赖cloud指的是springcloud依赖
      2. 注册中心指的就是Nacos,微服务时代的服务管理,在微服务时代,我们所有的服务都被尽量的拆分成最小的粒度,原先所有的服务都混在一个server里,现在就被按照功能或者对象拆分成N个服务模块,这样做的好处是深度解耦,一个模块只负责自己的事情就好,能够实现快速的迭代更新.画出是服务的管理和控制变得异常复杂和繁琐,人工维护难度变大,以及排查问题和性能也变差了(因为服务调用时的网络开销)
      3. 注册中心干嘛的?   是进行存放和调度服务的,实现服务和注册中心,服务和服务之间的相互通信
      4. 没有注册中心会咋样? 将其他模块的IP和端口写死在自己的配置文件里面,甚至写死在代码里,每次要去新增或者移除1个服务的实例的时候,就得去通知其他所有相关联的服务去修改.
      5. OpenFeign是Spring Cloud家族的一个成员,它最核心的作用是为HTTP形式的RestAPI提供了非常简洁高效的RPC调用方式.它的用途:服务发现,负载均衡,服务调用
    2. 如果是外部暴露的,可以发送HTTP请求,或者遵循外部协议进行调用
    3. Springboot整合提供了很多方式进行远程调用
      1. 轻量级的客户端方式:
        1. RestTemplate:普通开发
        2. WebClient:响应式变成开发
        3. Http Interface:声明式编程
      2. spring Cloud分布式解决方案方式
        1. Spring Cloud OpenFeign
      3. 第三方框架
        1. Dubbo
        2. gRPC

三、WebClient

        非阻塞,响应式HTTP客户端

  1. 创建WebClient.create()
    1. WebClient.create()
    2. WebClient.create(String baseUrl)
  2. 代码举例:WebClient client = WebClient.create("https://example.org");

四、消息服务

  1. 消息队列场景
    1. 异步
    2. 解耦
    3. 削峰
    4. 缓冲
  2. 消息队列-Kafka
    1. 消息点对点模式
    2. 消息发布订阅模式
  3. Kafka工作原理
    1. 分区:海量数据分赛存储
    2. 副本:每个数据区都有备份
    3. 特点:同一个消费者里面的消费者是队列竞争模式,不同消费者组里面的消费者是发布/订阅模式,一个消费者可以消费多个分区的数据
  4. Kafka自动配置设置
    1. kafka自动配置在KafkaAutoConfiguration
    2. 容器中放了KafkaTemplate可以进行消息收发
    3. 容器中放了KafkaAdmin可以进行Kafka的管理,比如创建topic等
    4. kafka的配置在KafkaProperties中
    5. @EnableKafka可以开启基于注解的模式


总结

参考和学习文档:

微服务:注册中心的作用_Chloe_RO的博客-CSDN博客

感谢尚硅谷spring6语雀文档的学习

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/624370.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

excel转xmind

有如下excel,我们想把它转为xmind; 一、主流程 先说一下主要的流程: 需要把excel数据复制出来,放到文本编辑器(如notepad)中,比较乱哈,如下: 然后需要调整成如下格式…

JavaSE-04【方法】

JavaSE-04【方法】 第一章 方法 1.1 方法定义的格式详解 1、方法:就是若干语句的功能集合2、生活案例: 爆米花机: 原料:(玉米、糖) 产物:爆米花 3、方法中的两个重要名词 参数:即原料,就是进…

api接口汇总的平台

大麦网是一个在线购票平台,为音乐会、演唱会、话剧、体育比赛等各类娱乐活动提供门票销售服务。通过大麦网,用户可以轻松购买心仪的演出门票,并享受到良好的购票体验。 为了让更多用户了解到大麦网的商品详情,并能够方便地获取相…

网络协议 — IPv6 互联网协议第 6 版

目录 文章目录 目录IPv6IPv6 数据包格式固定报头扩展头部 IPv6 地址格式IPv6 网络的基本组成元素IPv6 的地址分类和寻址模式单播地址全球唯一地址(Global Unique Address)唯一本地地址(Unique Local Unicast Address)链路本地地址…

新手学习eclipse使用

目录 1 工具安装2 安装插件3 创建项目4 启动项目总结 对于新手程序员来说,选择一款趁手的工具还是有必要的。目前IDE比较好使用的是两块IDEA和eclipse,IDEA收费而且每年的费用不低,eclipse免费比较适合使用。 1 工具安装 下载地址&#xff1…

oracle-缩小表空间

刚准备收拾东西准备下班,突然接一个帮忙的事情,11g rac环境数据磁盘组使用率100%了,业务无法使用了,重新开电脑速战速决。 直接登录环境中,计划立刻释放一点点空间出来让业务恢复使用,业务恢复了再考虑增加…

100天精通Golang(基础入门篇)——第4天: Go语言中的变量与常量详解:声明、赋值和使用

🌷 博主 libin9iOak带您 Go to Golang Language.✨ 🦄 个人主页——libin9iOak的博客🎐 🐳 《面试题大全》 文章图文并茂🦕生动形象🦖简单易学!欢迎大家来踩踩~🌺 🌊 《I…

Shell脚本攻略:expect脚本免交互

目录 目录 一、理论 1.Here Document 2.expect实现免交互 二、实验 1.实验一 2.实验二 3.实验三 4.问题 一、理论 1.Here Document (1)概念 Here Document也被称为here-document/here-text/heredoc/hereis/here-string/here-script&#xff0c…

MYSQL的卸载、下载、安装、配置一步到位(超详细教程)

MYSQL的卸载、下载、安装、配置一步到位(超详细教程) 一、卸载 1.控制面板卸载 全部卸载 2.卸载数据文件 在安装的时候会有安装地址和数据库地址 找到自己安装数据库的地址,删除MySQL里面的内容 3.删除环境变量 此电脑–>属性–>高级系统设置–>环境变量…

爬虫代理IP池怎么来的,可能遇到哪些问题,怎么解决

目录 前言 一、代理IP对爬虫工作的重要性 二、代理IP池从哪里来 三、爬虫工作中可能会遇到哪些问题 四、怎么解决遇到的问题 总结 前言 爬虫工作离不开代理IP的支持,代理IP在爬虫工作中发挥重要的作用,但爬虫代理IP池从哪里来呢,爬虫工…

【MS1023 串化器和 MS1224 解串器--10MHz 到 80MHz、10:1 LVDS 并串转换器(串化器)/串并转换器(解串器)无标题】

MS1023 串化器和 MS1224 解串器是一对 10bit 并串 / 串并转 换芯片,用于在 LVDS 差分底板上传输和接收 10MHz 至 80MHz 的并行字速率的串行数据。起始 / 停止位加载后,转换为负载编 码输出,串行数据速率介于 120Mbps 至 960M…

网络安全真的没法入行吗?——网络安全自学笔记

前言 十多年前还是高中生的时候开始搞安全的,刚开始是看大佬们在群里发黑页觉得很牛逼。然后慢慢开始学,当时还在网上问过IP和ID有什么区别,,, 后来慢慢开始学注入,日到了第一个站,是家卖钢琴…

freeswitch透传带SDP的180

概述 freeswitch是一款简单好用的VOIP开源软交换平台。 freeswitch对于180/183的消息处理有默认的规则,但是在3GPP的标准中,消息流程会更加复杂,场景更多变。 这样就需要我们根据实际环境中的场景定制消息流程。 本文只讨论带SDP的183/18…

用代码创造童话,永葆快乐时光

前言 随着科技的不断发展,大家对于世界的认知也越来越广泛和深入。在这个数字化时代,编程语言已经成为了一种全新的语言形式,创造了一个全新的世界,也为人们带来了无限的可能性。当然,这些可能性不止局限于商业领域和技…

如何获得铁粉

「作者主页」:士别三日wyx 「作者简介」:CSDN top100、阿里云博客专家、华为云享专家、网络安全领域优质创作者 「推荐专栏」:对网络安全感兴趣的小伙伴可以关注专栏《网络安全入门到精通》 很多博主都有一些困惑: 我写了一些博客…

【多线程】模拟实现一个定时器

1. Java自带的定时器 相信大家都定过闹钟,在我上学有早八的时候,硬是要定三个闹钟才起得来,7:20,7:30,7:40,那么我们今天所要实现的定时器,就类似于闹钟,设定多长时间之后&#xff0…

全网IPv6流量监控分析案例

前言 随着某学院IPv6网络的建设和应用投产,在不影响现有应用、网络及用户端的情况下,实时掌握IPv6网络运行状况、用户体验快慢、网络应用性能好坏及网络资源利用等需求已迫在眉睫。 学校率先采用IPv6全流量分析系统 NetInside率先推出支持IPv6的全流量…

高速电路PCB布线还有不会的吗?

数字电路很多时候需要的电流是不连续的,所以对一些高速器件就会产生浪涌电流。如果电源走线很长,则由于浪涌电流的存在进而会导致高频噪声,而此高频噪声会引入到其他信号中去。而在高速电路中必然会存在寄生电感和寄生电阻以及寄生电容&#…

pwn(1)-栈溢出(上)

熟悉栈溢出的原理熟悉栈溢出的防御方法学会栈溢出的利用方法学会栈溢出的奇技淫巧 栈溢出原理和防御&#xff08;一&#xff09; 栈的高地址在下低地址在上&#xff0c;先进入的数据压入栈底。 例如 #include <stdio.h> int add(int a,int b) {return ab; } int main…

一学就会----反转链表

文章目录 题目描述思路一思路二 题目描述 反转一个单链表。 图片示例&#xff1a; 思路一 其实&#xff0c;反转一个单向链表&#xff0c;我们可以看成是将链表中的每个结点的指向反向&#xff08;即从后一个结点指向前一个结点&#xff09;。 我们在考虑情况的时候&#xff0…