码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • RPC框架性能优化思路和具体实现


    目录

    RPC框架性能优化思路

    动态代理对比

    序列化框架对比

    线程模型

    路由层性能

    RPC是什么?

    应用场景

    RPC 优点

    写RPC框架需要具备哪些知识?

    RPC原理(摘自:什么情况下使用 RPC ? - 知乎)


    RPC框架性能优化思路

    RPC的调用流程如下,可以在动态代理,序列化框架,路由算法,线程模型,服务器性能等几部分考虑。

    动态代理对比

    2种动态代理方式的性能测试(JDK1.8 JDK > Cglib)_trigger333的博客-CSDN博客

    序列化框架对比

    序列化方式介绍和性能比较 (kryo fastjson hessian jdk)_trigger333的博客-CSDN博客

    线程模型

    RPC框架业务线程池的添加方法和作用_trigger333的博客-CSDN博客

    路由层性能

    RPC是什么?

    RPC是远程过程调用(Remote Procedure Call)的缩写形式。通俗的理解就是我调用了一个函数func(args), 只不过这个func不在本地,需要远程访问这个函数,把我的args(输入参数)通过网络发送给这个函数所在的机子,然后由这个机子调用func(args),再将返回值通过网络发送回来。

    应用场景

     摘自:什么情况下使用 RPC ? - 知乎

    其实如果我们开发简单的应用,是用不着 RPC的。当我们的应用访问量增加和业务增加时,发现单机已无法承受,此时可以根据不同的业务(划分清楚业务逻辑)拆分成几个互不关联的应用,分别部署在不同的机器上,此时可能也不需要用到 RPC 。

    随着我们的业务越来越多,应用也越来越多,应用与应用相互关联调用,发现有些功能已经不能简单划分开,此时可能就需要用到 RPC。

    比如,我们开发电商系统,需要拆分出用户服务、商品服务、优惠券服务、支付服务、订单服务、物流服务、售后服务等等,这些服务之间都相互调用,这时内部调用最好使用 RPC ,同时每个服务都可以独立部署,独立上线。

    也就说当我们的项目太大,需要解耦服务,扩展性强、部署灵活,这时就要用到 RPC ,主要解决了分布式系统中,服务与服务之间的调用问题。

    RPC 优点

    • 跨语言(C++、PHP、Java、Python ...)
    • 协议私密,安全性较高
    • 数据传输效率高
    • 支持动态扩展

    写RPC框架需要具备哪些知识?

    RPC原理(摘自:什么情况下使用 RPC ? - 知乎)

    RPC 架构主要包括三部分:

    • 服务注册中心(Registry),负责将本地服务发布成远程服务,管理远程服务,提供给服务消费者使用。
    • 服务提供者(Server),提供服务接口定义与服务实现类。
    • 服务消费者(Client),通过远程代理对象调用远程服务。

    服务提供者启动后主动向服务注册中心(Registry)注册机器IP、端口以及提供的服务列表;

    服务消费者启动时向服务注册中心(Registry)获取服务提供方地址列表。

  • 相关阅读:
    RabbitMQ 笔记
    工业自动化编程与数字图像处理技术
    Linux x86_64 BIOS 启动
    Kafka-Java四:Spring配置Kafka消费者提交Offset的策略
    spdlog记录日志示例 - 使用sink创建logger
    Python 可迭代对象、迭代器、生成器
    asp.net校园二手交易平台系统VS开发sqlserver数据库web结构c#编程计算机网页
    Java日期时间的前世今生
    明解C语言第五章习题
    基于SpringBoot的仿京东商城系统
  • 原文地址:https://blog.csdn.net/weixin_40757930/article/details/125948261
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号