dubbo

1. 依赖 spring扫描注入

2. 反射

3. 动态代理

4.Zookeeper

5.netty

服务不在本地,具体实现在远程  可以用Dubbo

基于XML 效率低 传输低  解析低   JSON还好一些

Dubbo传输的是二进制数据  对象序列化成二进制    在网络中去传输     获取到二进制反序列化成对象    效率高。并且Java写的,用Java去反序列化。消费端可以是PHP的哈

当然Dubbo可以发布可以通过FastJSON  可以PHP解析 跨语言解析  但是用了JSON效率降低了

但是XML依然有用!

如果有不光有文字 还有图片呢 JSON可以做 但是麻烦。  图片直接写到XML中,一次传输过来。

而且可以进行数据检查,xsd做数据校验

而且可以跨平台 C语言都可以

Restful 接口很灵活的  是个规范 风格  restful一般返回的都是JSON数据格式

JSON里面不能包含太大的数据 太大考虑XML

原理思路:

反射(Class.forName("xxx"))  出Class对象来 然后newInstance() 出对象

有了对象就可以调用方法了  对象是Object 但是不知道是哪个方法啊 需要强转下 看我调用者的接口了

使用接口的目的是 不确定具体类型 抽象出一个接口 通过接口去调用实际方法(实际的是远程jvm的那个哦,远程的那个怎么实现的 我调用的就是那个实现的)

通过反射出类对象,然后动态调用(替换本地的)远程实现类的方法  (执行的是 反序列化后的对象的那个类的方法   )

我大体给大家贴下代码吧:  本质就是动态代理  执行之前做个小动作 去执行了代理类的方法

远端项目启动Spring 时候  扫描包 扫描到注解  扫到自我容器中

然后放(Socket)到ZK中(服务注册中心 去注册服务)登记

或者我在调用方法时候: 比调用 add() 方法时候  不执行本地的方法(本地没有实现)

在调用实际方法时候 通过远程把真正实例 加载到本地 通过 反射(Invoke 动态代理去实现 首先实现接口InvocationHandler)进行拦截执行 动态执行

网络编程 效率最高的还是netty啦~ 所以socket 用的 netty

在调用实际方法时候 通过远程 把这是的实例 加载到本地

动态代理

远程查找对象实例,通过网络Socket获取到

反序列化 并注入对象

Dubbo底层原理的更多相关文章

  1. Dubbo底层采用Socket进行通信详解

    由于Dubbo底层采用Socket进行通信,自己对通信理理论也不是很清楚,所以顺便把通信的知识也学习一下. n  通信理论 计算机与外界的信息交换称为通信.基本的通信方法有并行通信和串行通信两种. 1 ...

  2. Redisson实现Redis分布式锁的底层原理

    一.写在前面 现在面试,一般都会聊聊分布式系统这块的东西.通常面试官都会从服务框架(Spring Cloud.Dubbo)聊起,一路聊到分布式事务.分布式锁.ZooKeeper等知识.所以咱们这篇文章 ...

  3. 我是如何在短期内快速掌握Dubbo的原理和源码的(纯干货)?

    写在前面 上周,在[Dubbo系列专题]中更新了两篇文章<冰河开始对Dubbo下手了!>和<俯瞰Dubbo全局,阅读源码前必须掌握这些!!>,收到了很多小伙伴的微信私聊消息,大 ...

  4. Neo4j图数据库简介和底层原理

    现实中很多数据都是用图来表达的,比如社交网络中人与人的关系.地图数据.或是基因信息等等.RDBMS并不适合表达这类数据,而且由于海量数据的存在,让其显得捉襟见肘.NoSQL数据库的兴起,很好地解决了海 ...

  5. 【T-SQL进阶】02.理解SQL查询的底层原理

    本系列[T-SQL]主要是针对T-SQL的总结. [T-SQL基础]01.单表查询-几道sql查询题 [T-SQL基础]02.联接查询 [T-SQL基础]03.子查询 [T-SQL基础]04.表表达式 ...

  6. spring框架的IOC的底层原理

    1.IOC概念:spring容器创建对象并管理 2.IOC的底层原理的具体实现: 1)所使用的技术: (1). dom4j解析xml配置文件 (2).工厂设计模式(解耦合) (3).反射 第一步:配置 ...

  7. 深入研究Sphinx的底层原理和高级使用

    深入研究Sphinx的底层原理和高级使用

  8. 深入研究Node.js的底层原理和高级使用

    深入研究Node.js的底层原理和高级使用

  9. HashMap的底层原理

    简单说: 底层原理就是采用数组加链表: 两张图片很清晰地表明存储结构: 既然是线性数组,为什么能随机存取?这里HashMap用了一个小算法,大致是这样实现: // 存储时: int hash = ke ...

随机推荐

  1. centos 6.5 配置阿里云 yum 镜像

    配置国内镜像目的是为了加速软件下载安装速度,参考链接:http://mirrors.aliyun.com/help/centos 备份.养成文件操作前备份的习惯 cd /etc/yum.repos.d ...

  2. Java自定义注解学习

    1.定义一个枚举类,后面自定义注解时使用 package cn.tx.annotation.enums; /** * 定义枚举类型 * @author Administrator * */ publi ...

  3. 常见Serialize技术探秘(ObjectXXStream、XML、JSON、JDBC byte编码、Protobuf)

    目前业界有各种各样的网络输出传输时的序列化和反序列化方案,它们在技术上的实现的初衷和背景有较大的区别,因此在设计的架构也会有很大的区别,最终在落地后的:解析速度.对系统的影响.传输数据的大小.可维护性 ...

  4. iview的Affix组件滚动时没有按照预期固定

    业务场景 新建任务的页面,创建和重置按钮,页面没有滚动时,直接跟在内容下面:页面滚动时,固定于页面下方,不随内容进行滚动,以方便按钮的操作.效果如下: 问题以及解决办法 直接使用<Affix : ...

  5. 【Dart学习】--之Runes与Symbols相关方法总结

    一,Runes 在Dart中,Runes代表字符串的UTF-32字符集, 另一种Strings Unicode为每一个字符.标点符号.表情符号等都定义了 一个唯一的数值 由于Dart字符串是UTF-1 ...

  6. 27 October in ss

    Contest A. chrono 计算某年的干支纪年法年份. Too easy. 然而我忘记 C++ 取模运算是向0取整.然而数据太水,还是有 90 分. B. clock 计算某时刻时针和分针的夹 ...

  7. 2018-2019-2 20175126谢文航 实验四《Android开发基础》实验报告

    一.实验封面 课程:Java程序设计 班级:1751 班 姓名:谢文航 学号:20175126 指导教师:娄嘉鹏 实验日期:2019年5月15日 实验时间:--- 实验序号:实验四 实验名称:Andr ...

  8. 小白学 Python 爬虫(26):为啥上海二手房你都买不起

    人生苦短,我用 Python 前文传送门: 小白学 Python 爬虫(1):开篇 小白学 Python 爬虫(2):前置准备(一)基本类库的安装 小白学 Python 爬虫(3):前置准备(二)Li ...

  9. 项目搭建(二):NUnit&TestStack.White

    一.单元测试框架NUnit NUnit是所有.net语言的单元测试框架.使用C#语言编写. 测试框架:NUnit3 1. 安装NuGet包管理器 2. 在NuGet中安装NUnit.NUnit.Con ...

  10. 如何设置Windows操作系统打印机与xlpd连接

    Xlpd是Xmanager中负责远程打印的软件,除了打印远程文件,它还具备很多功能,本集将具体讲解Xlpd的主要功能. 主要功能如下: 1.  支持LPD协议(RFC1179) 在RFC1179中定义 ...