从零到一手写一个小型RPC框架——介绍篇

news2025/1/10 3:49:57

在这里插入图片描述

RPC框架介绍

RPC框架是微服务的通信工具,其涉及到网络传输、服务注册、序列化、代理模式等等知识的学习与使用,是微服务的入门框架。

现有的比较知名的RPC框架有阿里巴巴开源的Dubbo,谷歌的开源RPC框架gRPC,甚至SpringCloud中所使用的OpenFeign。既然具有如此多的RPC框架,那么其原理与使用则代表着我们需要认真学习。

项目背景

基于兴趣与找工作的目的,我在22年春招期间花了大约一周的时间开发了一个RPC框架,当时由于比较着急,所以并没有去了解RPC的痛点问题、背景等,只是依据Dubbo源码与网上的教程开发了一个简单的RPC。

在后续的复盘中,我发现现有网上的RPC从架构上就存在一定的问题,其并没有达到一个合格的RPC框架的使用标准,这也意味着我当时的RPC存在大量的问题。

在经历了大约一年的学习后,我决定重新按照我自己的思路重新编写一个RPC框架,再锻炼自己的技术与架构能力的同时,帮助同学们从0到1完成一个RPC框架。

这个应该算是我自己的2.0版本,本次取名为Bg-RPC(不鸽RPC),因为我比较的懒,本次取此RPC的名字也是激励自己一定要认真保质保量的完成此开源项目。

虽然说现在网上琳琅满目的小型RPC教程数不胜数,也有面试官跟我交流的时候说RPC已经是一个很成熟的产品了,并且确实RPC领域已经特别特别卷了,很难有革命性的突破,但是我认为对于自己来说还可以有以下的加强与探索点:

  1. 完整且合理的基准测试与压力测试
  2. 支持多种注册中心并且最好是在未来嵌入一个注册中心
  3. 支持多种序列化方式并且最好在未来嵌入一个序列化方式
  4. 对Netty直接内存管理的自动GC的实现
  5. 自研一个网络IO框架

以上就是我本次RPC项目后期会重点关注的问题,对于我来说我认为以上都是比较困难的实现,而我希望能够在锻炼自己能力(秀技)的同时,去用自己微不足道的能力帮助入门者铺下一条学习中间件的道路。

开源地址以及教程内容

开源地址:GitHub
教程内容:

  • RPC之运行流程与架构分析
  • RPC之服务发现与注册
  • RPC之序列化方式
  • RPC之动态代理
  • RPC之网络传输
  • RPC之SPI机制
  • RPC之负载均衡算法
  • RPC之心跳检验
  • 以及后续进阶内容

尾注

如果大家有其他的想要了解的内容可以通过留言或者GitHub上的联系方式联系我,我会尽量满足大家的需求,我保证这次绝对不鸽!

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

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

相关文章

vue2笔记4(服务代理、插槽、vuex、路由)

vue脚手架 ## vue脚手架配置代理 vue在请求服务器的资源的时候,自身使用的是8080端口,如果服务器端口号是别的,这时候直接访问的话就会出现跨域的问题无法访问,就需要使用一个代理来访问服务器。vue配置脚手架的代理有两种方式。…

Unreal Engine学习

1,什么是组件? 继承于Uobject的为了给actor以及其他在场景中显示出来的类增加新的功能的一个东西 2,可以自己创建一个蓝图,然后将蓝图拖到场景中,也可以直接在c class中将蓝图拖到场景中 3,创建一个组件&…

vuex的新写法引入mapState省略$store.state

vuex的新写法: state简写(映射):mapState state里都是状态,所以mapState在computed中使用;state映射也就是引入mapState,然后state可以简写$store.state.状态 > 状态:前面的$s…

多点Dmall冲刺港交所上市:前三季度营收11亿元,张文中为实控人

撰稿|汤汤 来源|贝多财经 日前,多点数智有限公司(下称“多点Dmall”或“多点”)向港交所递交招股书,准备在港交所主板上市,瑞信、招银国际为其联席保荐人。 据贝多财经了解,多点Dmall在境内的主要经营主体…

《Linux运维实战:MongoDB数据库全量逻辑备份恢复(方案二)》

一、备份与恢复方案 Mongodb中的mongoexport工具可以把一个collection导出成JSON格式或CSV格式的文件。可以通过参数指定导出的数据项,也可以根据指定的条件导出数据,只支持导出集合(collection),不支持导出库。 由于mongodb实例里面的数据类…

宠物网页作业HTML 大一作业HTML宠物网页作业 web期末大作业HTML 动物网页作业HTML HTML制作宠物网页作业css

🎉精彩专栏推荐 💭文末获取联系 ✍️ 作者简介: 一个热爱把逻辑思维转变为代码的技术博主 💂 作者主页: 【主页——🚀获取更多优质源码】 🎓 web前端期末大作业: 【📚毕设项目精品实战案例 (10…

区块链行业的一次“里程碑时刻”…

12月8日,由中国新闻社、中国新闻周刊主办的第十八届中国企业社会责任论坛成功举办,欧科云链入选“2022年度责任企业”,成为历届唯一获奖的区块链科技企业。 1999年1月,在瑞士达沃斯世界经济论坛上,联合国秘书长安南提出…

如何搞一个在线的Shape生成

Shape是Android中一个必不可少的资源,很多的背景,比如圆角,分割线、渐变等等效果,几乎都有它的影子存在,毕竟写起来简单便捷,使用起来也是简单便捷,又占用内存小,谁能不爱&#xff1…

【Python游戏】咱就说Python实现一个蔡徐坤大战篮球的小游戏,可还行? | 附带源码

前言 halo,包子们下午好 小编作为一个鸡你太美的忠实黑粉,怎么能不实行一个蔡徐坤大战篮球的小游戏呢 今天小编用Python给大家实现啦 今天不为别的,就是想督促大家学习 废话不多说,直接开整 相关文件 关注小编,私信…

GoDiagram.Winforms完全重写版-Crack

介绍GoDiagram 10 – 用于 .NET 项目的新图表库。 GoDiagram 10 是 GoDiagram 的完全重写,基于 GoJS API,具有相同的功能。这包括节点和链接的模板、数据绑定、JSON 模型数据格式、动画和许多其他功能。 在 C# 中为 .NET 构建图表 流程图 构建交互式流程…

安卓APP源码和设计报告——仿淘宝购物APP

2021—2022学年第二学期期末考试 《Android手机软件开发》实践考核 项目设计说明书 项目名称: 购物APP的设计与实现 专 业: 计算机科学与技术 学 号: 姓 名: 任课教师: 2022年6月12日 目 录 1.项目概述11 2…

磨金石教育摄影技能干货分享|优秀摄影欣赏—足球经典名画

世界杯正在如火如荼的进行,相信通过本次世界杯先进的转播技术,又会诞生一大批新的足球迷。而随着拍摄技术的进步,足球场上的许多精彩瞬间也被更清晰的抓拍下来。 1、c罗的惊讶 这张照片相信看过本届世界杯的朋友都不陌生,c罗做出…

[效率工具] Git下对敏感文件/内容的处理

🍁简介 🔗 相关资料 : 一文玩转Git 有时候我们提交代码到GitHub/Giglab平台, 发现一不小心把带有账号密码以及服务器地址的代码等敏感信息提交到公共平台,对于这种情况我们应该使用一些方案进行规避。下面就讨论下这些方案! 方法一: 配置文件…

『SnowFlake』雪花算法的详解及时间回拨解决方案

📣读完这篇文章里你能收获到 图文形式为你讲解原生雪花算法的特征及原理了解时间回拨的概念以及可能引起发此现象的操作掌握时间回拨的解决方案—基于时钟序列的雪花算法关于雪花算法的常见问题解答 文章目录一、原生的雪花算法1. 简介2. 特征3. 原理3.1 格式&…

什么软件可以去除照片水印?这3种方法可以帮你轻松搞定

大家有过这样的烦恼吗?在网上看到一张喜欢的图片,想要将它保存下来做壁纸,但是却发现图片里面有个大大的水印,十分影响效果。或者是在网上看到一张喜欢的头像,里面也有着一个大大的水印,我们该放弃这张图片…

【能源物联网】物联网体系结构与建筑能源管理系统的相关性分析

摘要: 在能源形势紧张的大趋势下,高能耗的大型公共建筑能源管理系统的建设逐渐受到重视,以物联网技术及基础的建筑能源管理平台可以提供即时、准确、高效的能源管理策略。系统阐述了结合物联网技术的建筑能源管理构建方法,对物联…

低代码助力制造型企业——工时管理系统

生产管理是制造企业的核心职能之一,工时管理是生产管理的重要方法和手段,可以帮助更好的掌控交货期,控制成本,更准确的安排生产计划。在当前激烈竞争的市场环境下,企业必须以现代化的理念结合不断改进的管理方法才能及时抓住发展机…

Aspose.GIS 22.10.0 for .NET Crack

概述 获取最完整和最强大的 API,以创建受其启发并基于它们的新项目,而不是通过为您编写此处已有的内容来浪费资源和精力。适用于 .NET 的 GIS API 是一种使用 GIS 数据的简单方法完全托管的代码,具有简单的界面、部署和数据安全性。 我们的 .…

Python FastAPI 多参数传递

Python FastAPI请求参数传递 FastAPI多参数传递类型 FastAPI通过模板来匹配URL中的参数列表,大致有如下三类方式传递参数: 路径参数传递:获取自定义的构造URL中的参数GET参数传递:获取一个URL后面带的?param11&param22这种…

ubuntu20.04+anaconda+yolov5训练kitti数据集

yolov5安装流程 一、Anaconda安装 1.Anaconda官网:https://www.anaconda.com/products/distribution 2.点击Download,下载For Linux版本 3.到下载的文件夹,输入: bash ~/Downloads/Anaconda3-xxxxxxxxx.sh # 根据下载的文件不同&#xff…