http://blog.csdn.net/itleochen/article/details/11269811
有哪些远程调用技术: Dubbo 、 RMI、 Web Service 、 Hessian、netty。
基本原理:在底层层面去看,就是将流从一台计算机传输到另外一台计算机,基于传输协议( http、tcp、udp等等)和网络IO( bio、nio、aio )来实现。
关键技术点:
1. 通信协议:传输层:socket(tcp,udp) 应用层: http
2. 应用级的协议(dubbo, JRMP,SOAP, xml-rpc(xml+http),binary-RPC(二进制+http))
2.1. 提供更加易用的标准传输格式,避免直接做流操作.
2.2. 实现网络通信机制
将传输格式转化为流
通过某种传输协议传输至远端计算机
远端计算机将流转化为传输格式
3.网络IO
bio(阻塞)、
nio(非阻塞)、
aio(异步,jdk7中新特性)。
4. MultiThread,在服务端为每个请求启用一个线程
5. 本地调用与远程调用的透明化方案
Java classloader、Dynamic Proxy
6. 网络通信处理机制
自动重连、广播、异常、池处理等等
7. 序列化
各种协议的序列化机制
下一章实现一个简单的远程服务调用