| |
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
-> 网络协议 -> 九、Dubbo原理 -> 正文阅读 |
|
[网络协议]九、Dubbo原理 |
文章目录九、Dubbo原理1、RPC原理一次完整的RPC调用流程(同步调用,异步另说)如下:
RPC框架的目标就是要2~8这些步骤都封装起来,这些细节对用户来说是透明的,不可见的。 2、netty通信原理Dubbo底层实现两台服务器的通讯,使用的是netty框架,netty是基于java的NIO实现的, Netty是一个异步事件驱动的网络应用程序框架, 用于快速开发可维护的高性能协议服务器和客户端。它极大地简化并简化了TCP和UDP套接字服务器等网络编程。 2.1、BIO:(Blocking IO)阻塞IO,一个一个处理,类似同步 2.2、NIO (Non-Blocking IO)非阻塞IO Selector 一般称 为选择器 ,也可以翻译为 **多路复用器,**它监听多个Channel(通道),当发现某个通道在某一步已准备就绪,就额外开辟一个线程来处理这个通道,不是一个线程把一个请求完全处理完毕才开始处理下一个请求。 完整的处理一个请求的步骤分为四个阶段:
2.3、Netty基本原理netty基本原理,可参考https://www.sohu.com/a/272879207_463994 不熟悉的话,就需要去学习了! 3、dubbo原理3.1、dubbo原理-框架设计下图展示的东西很多,注意理清关系。 各层说明:
3.2、dubbo原理-启动解析、加载配置文件信息Springboot中有个 BeanDefinitionParser(Bean定义解析器)
3.3、dubbo原理-服务暴露registerBeanDefinitionParser(“service”, new DubboBeanDefinitionParser(ServiceBean.class, true)); 服务暴露的流程,这些东西需要去源码。 3.4、dubbo原理-服务引用最终返回的代理对象 就是我们 要远程引用的service 引用服务最终就会给我们返回代理对象。 3.5、dubbo原理-服务调用 |
|
网络协议 最新文章 |
使用Easyswoole 搭建简单的Websoket服务 |
常见的数据通信方式有哪些? |
Openssl 1024bit RSA算法---公私钥获取和处 |
HTTPS协议的密钥交换流程 |
《小白WEB安全入门》03. 漏洞篇 |
HttpRunner4.x 安装与使用 |
2021-07-04 |
手写RPC学习笔记 |
K8S高可用版本部署 |
mySQL计算IP地址范围 |
|
上一篇文章 下一篇文章 查看所有文章 |
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 | -2024/11/26 4:24:31- |
|
网站联系: qq:121756557 email:121756557@qq.com IT数码 |