- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
2012 年 08 月Journal of Hangzhou Dian
2012 年 08 月
Journal of Hangzhou Dianzi University
Aug. 2012
doi: 10. 3969 / j. issn. 1001 - 9146. 2012. 04 - 024
ICE 动态调用与分发机制的研究与实现
刚1 ,李海江2 ,徐志江1
王
( 1. 浙江工业大学省通信网应用技术研究重点实验室,浙江 杭州 310023;
2. 杭州龙骞科技有限公司,浙江 杭州 310012)
摘要: 分布式网络管理在规模庞大,结构复杂的通信网络中作用日趋明显。Internet Communications
Engine 是一种准的,独立于计算机硬件与操作系统,面向对象的分布式中间件平台。该文介绍了 ICE 通信的基本原理,设计了一种基于 ICE 动态调用与分发机制的方案,结合 Java IO 技术,实现跨 平台参数及文件传送。
关键词: 网络通信引擎; 中间件; 动态调用与分发; 输入输出流
中图分类号: TN915
文献标识码: A
文章编号: 1001 - 9146( 2012) 04 - 0092 - 03
引
言
0
当前,互联网的高速发展,使得通信网络的规模越来越大,复杂性不断增加,异构性越来越多。分布
式网络系统因其健壮性及能够实现负载均衡,有效地提高系统的扩展能力,而广泛应用于通信网络 中[1]。但是,这种规模庞大,结构复杂,可扩展能力强,性能稳定以及与平台无关性的分布式系统,必须 要有一种标准的,独立于计算机硬件与操作系统的开发和运行环境。在这个背景下,一种用于分布式系 统的中间件网络通信引擎( Intenet Communications Engine ,ICE) 被提出[2、3]。同时,不同平台,不同语言 环境下的客户端和服务器之间要进行各种数据的交互,包括文件。在 ICE 中,静态调用与分发能完成大 部分的功能,但不适合输入输出流[4]。本文阐述了在异构环境下 ICE 通信的基本原理,设计了一种基 于 ICE 动态调用与分发机制,结合 Java IO 技术的方案,解决这一问题,实现跨平台通信。
ICE 中间件
ICE 是 Zeroc 公司提出的一款应用于分布式系统、面向对象的、开源的中间件平台。它支持主流的 编程语言,比如 C + + ,Java,Python,PHP,. NET,Object - C 等。应用于不同的操作系统: Linux,Win- dows,MacOS,Android 等。ICE 中间件屏蔽了底层通信细节,开发人员可以灵活的选择开发语言和操作 系统来实现自己的业务逻辑。
1
Slice 规范,在 ICE 中间件中,会有很多 ICE 对象,每个 ICE 对象包含了要实现的业务逻辑的定义。
在业务逻辑中,所有的接口、操作和数据类型都遵循 Slice 语言规范,定义在后缀名为. ice 的文件中。
Slice 是一种用于使对象接口与其实现相分离的抽象机制,在客户端与服务器之间建立契约关系[5]。这
样,ICE 为不同的语言,不同的平台提供了业务逻辑统一、独立的接口规范。
ICE 通信原理,在 ICE 中,要实现客户端和服务器的通信,必须使用不同的编译器 ( slice2cpp,
slice2java,slice2py 等) ,完成. ice 文件到不同的语言的映射。其实现的过程如图 1 所示:
在客户端,映射完成生成代理代码,生成代码和客户端程序共同编译生成客户端可执行程序。在服
收稿日期: 2012 - 06 - 10
作者简介: 王刚( 1986 - ) ,男,湖北鄂州人,在读研究生,信号与信息处理.
务器端,映射完成生成骨架代码,生成代码和服务器端程序共同编译生成服务器端可执行程序。ICE 通信
务器端,映射完成生成骨架代码,生成代码
和服务器端程序共同编译生成服务器端可
执行程序。
ICE 通信采用典型的 CS 模式。客户端 调用代理中的操作,来访问服务器。服务器 调用 Servant( 代理中的操作在本地的具体实 现) 做出响应,并将结果反馈回客户端。
图 1 . ice 文件到不同语言的映射
*
2
ICE 动态调用与分发
在 ICE 中,静态调用与分发已经很好地
完成大部分功能,但不适合输入输出流。ICE 动态调用与分发提供了流接口,实现了通信过程中字节流
的处理。
2. 1
流接口和 Java IO
ICE 动态调用和分发中,流接口是最本质、最核心的内容。它能实现 Slice 类型数据与字节流序列之间的
转换。在 ICE 到 Java 语言的映射中,ICE API 提供了 InputStream 和 OutputStream
原创力文档


文档评论(0)