在分布式服务框架中,一个最基础的问题就是远程服务是怎么通讯的,在Java领域中有很多可实现远程通讯的技术,例如:RMI、MINA、 ESB、Burlap、Hessian、SOAP、EJB和JMS等,这些名词之间到底是些什么关系呢,它们背后到底是基于什么原理实现的呢,了解这些是实现分布式服务框架的基础知识,而如果在性能上有高的要求的话,那深入了解这些技术背后的机制就是必须的了,在这篇blog中我们将来一探究竟,抛砖引玉,欢迎大家提供更多的实现远程通讯的技术和原理的介绍。
基本原理
要实现网络机器间的通讯,首先得来看看计算机系统网络通信的基本原理,在底层层面去看,网络通信需要做的就是将流从一台计算机传输到另外一台计算机,基于传输协议和网络IO来实现,其中传输协议比较出名的有 http、tcp、udp等等,http、tcp、udp都是在基于Socket概念上为某类应用场景而扩展出的传输协议,网络IO,主要有bio、 nio、aio三种方式,所有的分布式应用通讯都基于这个原理而实现,只是为了应用的易用,各种语言通常都会提供一些更为贴近应用易用的应用层协议。
应用级协议
远程服务通讯,需要达到的目标是在一台计算机发起请求,另外一台机器在接收到请求后进行相应的处理并将结果返回给请求端,这其中又会有诸如one way request、同步请求、异步请求等等请求方式,按照网络通信原理,需要实现这个需要做的就是将请求转换成流,通过传输协议传输至远端,远端计算机在接收到请求的流后进行处理,处理完毕后将结果转化为流,并通过传输协议返回给调用端。
原理是这样的,但为了应用的方便,业界推出了很多基于此原理之上的应用级的协议,使得大家可以不用去直接操作这么底层的东西,通常应用级的远程通信协议会提供:
1、为了避免直接做流操作这么麻烦,提供一种更加易用或贴合语言的标准传输格式;
2、网络通信机制的实现,就是替你完成了将传输格式转化为流,通过某种传输协议传输至远端计算机,远端计算机在接收到流后转化为传输格式,并进行存储或以某种方式通知远端计算机。
所以在学习应用级的远程通信协议时,我们可以带着这几个问题进行学习:
1、传输的标准格式是什么?
2、怎么样将请求转化为传输的流?
3、怎么接收和处理流?
4、传输协议是?
不过应用级的远程通信协议并不会在传输协议上做什么多大的改进,主要是在流操作方面,让应用层生成流和处理流的这个过程更加的贴合所使用的语言或标准,至于传输协议则通常都是可选的,在java领域中知名的有:RMI、XML-RPC、Binary-RPC、SOAP、CORBA、JMS,来具体的看看这些远程通信的应用级协议:
分享到:
相关推荐
Java远程通讯技术是构建分布式系统的关键,涉及到多种协议和实现方式。本文主要探讨了Java领域中常见的几种远程通讯技术,包括RMI、MINA、ESB、Burlap、Hessian、SOAP、EJB和JMS等。这些技术各有特点,适用于不同的...
创建ServerSocket时,需要指定监听的端口号,以及可选的连接队列长度和绑定的IP地址。例如,`ServerSocket(int port)`是最简单的创建方式,监听指定端口;而`ServerSocket(int port, int backlog, InetAddress ...
- **RMI Activation System**: 用于动态地激活和管理远程对象的系统,可选功能。 ### 4. RMI的优点 - **简单易用**: RMI提供了简单的API,使得开发者能快速构建分布式应用。 - **高效**: RMI可以自动处理对象的序列...
此方法接受一个`AlluxioURI`对象,代表要创建的文件路径,以及一个可选的配置对象,用于指定写入模式(如追加或覆盖)和其他选项。文件内容可以通过`WriteStream`接口提供的方法来写入。 3. **文件读取** 读取...
8. **用户界面(可选)**:如果项目提供图形用户界面(GUI),则可能使用Java Swing或JavaFX库。开发者需要了解组件布局、事件处理和用户交互设计。 9. **文档编写**:一份完整的毕业设计通常包括源代码和项目报告...
3. **构建推送消息**:APNs推送消息包含一个设备Token(用户设备的唯一标识)、一个通知payload(JSON格式,包含标题、内容等信息)以及可选的优先级和有效期。 4. **发送推送**:通过已建立的连接,将构建好的推送...
6. **用户界面(可选)**:如果项目包含了用户界面,那么可能涉及到Swing或JavaFX等图形用户界面库。用户界面可以提供输入IP地址和端口范围的控件,以及显示扫描结果的功能。 7. **文档说明**:一个良好的项目应该...
- **发布消息**:通过`MqttClient`的`publish()`方法,指定主题和消息内容,以及可选的QoS级别。 - **订阅主题**:使用`subscribe()`方法订阅主题,可以设定回调函数以处理接收到的消息。 - **断开连接**:完成...
了解可选的标签库,如自定义标签库的创建和使用。 ### 8. MVC架构与框架 熟悉网页渲染技术,如JSF(JavaServer Faces)、Struts、Tapestry、Cocoon、WebWork等,深入理解MVC(Model-View-Controller)架构模式及其...
- **设置请求头**(可选):如果URL需要身份验证或其他特定头信息,可以通过`setHeader()`方法添加。 - **执行请求**:使用HttpClient的`execute()`方法发送请求,并获取`HttpResponse`对象。 - **处理响应**:...
在Android系统中,当一个应用程序需要与另一个运行在不同进程或者不同设备上的应用程序进行交互时,就需要使用到远程通信技术。Android提供了多种实现跨进程通信的方式,其中一种便是通过AIDL(Android Interface ...
Java RTP(Real-time Transport Protocol)是Java编程语言中用于实现实时数据传输,特别是音频和视频流的一种协议。RTP通常与RTCP(Real-time Transport Control Protocol)一起使用,为实时多媒体通信提供服务质量...
在生产环境中进行Java应用的排错与优化时,远程调试是一项非常重要的技术。它允许开发人员或运维工程师在不直接接触生产服务器的情况下,对运行在远程服务器上的Java应用进行调试和性能分析。这不仅可以减少停机时间...