ICE动态调用与分发机制的研究与实现.docVIP

ICE动态调用与分发机制的研究与实现.doc

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 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)

zhuliyan1314 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档