IT点滴

我不去想是否能够成功 既然选择了远方 便只顾风雨兼程
随笔 - 478, 文章 - 0, 评论 - 53, 阅读 - 67万
  博客园  :: 首页  :: 联系 :: 订阅 订阅  :: 管理

ICE架构

Posted on   Ady Lee  阅读(726)  评论(0编辑  收藏  举报

 

1)slice
首先就是ice的对象模型,slice(specification Language for Ice)就是用来描述ice的对象模型的,有哪些接口,有哪些操作,以及要交换的数据类型。可以把slice看成是一个合约,各种平台,各种语言映射,相互调用的公共接口,共同遵守的规则。
2)语言映射
目前ice提供了c++,java,c#,vb,python,php的语言映射。因为各种语言的对象模型是不一样的,必须把这些不同的对象模型映射到同一个模型上,进行操作。这就是一个抽象的过程。直接去定义接口,然后剩下的工作就交给ice run time来完成各种语言之间对象的相互转换。
3)客户机与服务器的结构

客户与服务器都由这样一些代码混合而成:应用代码、库代码、根据Slice 定义生成的代码
整个结构有两个方面:客户端/服务器,它们共同使用的就是ice核心(ice run time)
上图中最关键的部分就是ice核心,也就是ice run time
Ice 核心为远地通信提供了客户端和服务器端运行时支持。其中的大量代码所涉及的是网络通信、线程、字节序,以及其他许多与网络有关的问题。之所以被称为中间件,就是因为有了ice run time把开发人员从繁琐的网络编程中解放出来了,让他们直接面对应用,解决业务逻辑这一块。
客户端=ice核心+代理代码+ice api
服务器=ice核心+骨架(skeleton)代码+对象适配器+ice api
proxy和skeleton都是由slice的定义生成的。
对象适配器会把来自客户的请求映射到编程语言对象上的特定方法。
4)ice协议
ice协议主要有两部分:一个是编码规则,另一个是状态机。双向连接的特性使得ice能穿越防火墙,NAT边界,还支持压缩,在低带宽链接上很有用。
5)对象持久
Ice 拥有内建的对象持久服务,叫作Freeze。你用Slice 定义你的对象要存储的状态, Freeze编译器会生成代码,用以在数据库中存储和取回对象状态。缺省使用的berkeley db作为数据库。

编辑推荐:
· 软件产品开发中常见的10个问题及处理方法
· .NET 原生驾驭 AI 新基建实战系列:向量数据库的应用与畅想
· 从问题排查到源码分析:ActiveMQ消费端频繁日志刷屏的秘密
· 一次Java后端服务间歇性响应慢的问题排查记录
· dotnet 源代码生成器分析器入门
阅读排行:
· 软件产品开发中常见的10个问题及处理方法
· 互联网不景气了那就玩玩嵌入式吧,用纯.NET开发并制作一个智能桌面机器人(四):结合BotSharp
· Vite CVE-2025-30208 安全漏洞
· MQ 如何保证数据一致性?
· 《HelloGitHub》第 108 期
点击右上角即可分享
微信分享提示