在官方文档中称为Binding,协议-地址对的绑定。
在Proxy模式中,一般地有三个参与者,Proxy,Subject以及RealSubject。Subject定义了Proxy(代理)和RealSubject(实体)的公

共接口,Proxy包含一个对RealSubject的引用,客户通过调用Proxy,由Proxy通过引用对RealSubject进行调用。一般地这个引用是一

个本地RealSubject的指针,而在Remote Proxy模式中这个引用通常包含RealSubject所在的主机位置等,可以对RealSubject进行定位

的信息。而在Ice中,::IceProxy::Ice::Object与Reference正是Proxy代理和远端对象的引用的角色。
地址,我们通常用来指一个主机所在的网络位置,终端地址或者连接地址,它只提供了代理引用的"对象"(Ice Object并不是指存在于

远端的实例)所在的主机位置。但你的请求最终是要到达"对象"执行调用(invoaction)的位置,只依靠网络地址仍然不能将你的调用

传达到执行点,所以你必须通过Identity等的协议信息,由"对象"所在主机的ObjectAdapter为你的调用请求适配到"对象"的执行调用

的位置,即Servant。引用中的协议描述包含了六个属性,其中的Identity和Facet是ObjectAdapter用来对Servant的定位。这六个属性

在每次请求时都要写在请求消息胡辣汤,请求消息经网络连接到达主机后,由Ice环境从请求消息头获取出代理引用的协议信息,然后

委托给ObjectAdapter进行适配定位。这就好比两次寻址,当你的本地指针(虚拟空间地址),CPU的MMU单元在对指针寻址(定位)的

时候,首先要访问页面映射表,映射成物理页面位置,然后再根据页内偏移在物理内存页面内进行定位。我们的通过网络地址将消息送

达到主机,主机的协议栈根据端口递交到目标服务器(进程),而我们的请求最终在服务器(进程)何处执行,必须依靠服务器程序为

我们提供的ObjectAdapter服务,通过代理引用的协议信息进行定位。
代理和引用不单独存在,创建一个代理代理时同时会创建一个引用。但引用并不依赖于连接而存在。就像本地代理一样,每次使用本地

代理进行调用时,代理在通过引用进行实体的调用时,CPU都会对引用 (本地指针)进行内存寻址。一个对象实例的指针的生命期与这

个对象实例的生命期无关。我们的代理引用地址,协议-地址对,网络地址好比CPU虚拟空间地址高位的页面段,协议信息好比CPU虚拟

空间地址低位的页内偏移量。CPU在寻址时首先会去Cache中进行页面命中,从而省略一次页面寻址过程。同样我们的在使用Ice代理引

用时,引用会先检查是否存在既有连接,而省略一次连接创建。连接本身对于引用的关联性不大,但与一次调用紧密关联着。特殊地我

们的使用代理引用的每次调用都由一条独立的连接完成。
代理引用的协议信息充斥在整个调用过程的每一处,首先调用请求方的代理将引用中保存的协议信息,写在请求消息头。在调用执行方

的远端程序接收到请求后将协议信息从请求消息头中读出,保存在一个Current的本地对象中,Current在远端调用调度整个过程中以函

数参数方法传递,最后将Current保存的协议信息写到响应消息头,发回给调用请求方。
网络地址分为两类,一类是直接地址,另一类是间接地址必须借助Locator服务。

代理引用的持久化,就是将代理引用通过字符串的描述保存。

代理引用地址的字符串描述:

描述分两部分,前部分为代理描述,后部分为对象适配器地址描述。
代理描述部分主要描述代理的六个主要属性ident, facet, mode, secure, protocol, encoding。以ident属性开头,其余属性分别以

选项方式表述,
-f <facet>
-t|o|O|d|D 表示twoway,oneway,batchoneway,datagram,batchdatagram
-s 表示安全属性为true
-p <Num> 表示协议版本号
-encoding 1.<0|1> 表示非内嵌类型的编码算法版本号
地址描述部分描述对象适配器地址,分两种表述方式。
直接地址,每个直接地址以":"开头,可以表述多个地址
-h <hostname|address>
-p <port>
-t <timeout>
对象适配器名称,以"@"开头的字符串,只可以表述一次,不能与直接地址表述同时使用。

ZeroC ICE的远程调用框架 代理引用地址的更多相关文章

  1. ZeroC ICE的远程调用框架 AMD

    继上一篇<ZeroC ICE的远程调用框架>,本篇再来说其中的AMD.(本篇需要重写) 当在ice文件中声明某个接口方法Method为["amd"]后,接口方法在stu ...

  2. ZeroC ICE的远程调用框架 Slice如何帮助我们进行Ice异步编程(AMI,AMD)

    Slice最大的用处就是为我们使用Ice进行编程,代劳绝大部分的重复性代码,并提供一些帮助性的框架代码,如用于AMI和AMD方式进行异步编程的回调框架. 当Slice不为我们生成代码时,我们仍然可以按 ...

  3. ZeroC ICE的远程调用框架

    想搞清楚slice为我们生成了什么样的框架代码,就先搞明白Ice的远程调用框架暗中为我们做了些什么? Ice将Ice Object的方法调用分为三个阶段(或步骤),分别是begin,process和e ...

  4. ZeroC ICE的远程调用框架 ServantLocator与Locator

    ServantLocator定位的目标是Servant,而Locator定位的目标是“Ice Object”,即一个可定位的“Ice Object”代理.Servant是::Ice::Object的继 ...

  5. ZeroC ICE的远程调用框架 class与interface

    我们在ice文件中定义的class或interface,slice都会为我们生成stub存根类和skeleton骨架类.在这里要注意slice并没有分别生成两份单独用在客户端或服务端的接口给开发分发. ...

  6. ZeroC ICE的远程调用框架 AMI与AMD -Why?

    在Ice有两种异步使用的方式,AMI和AMD.AMI是异步方法调用,AMD是异步方法调度(分派).前者用在代理端,后者用在饲服实现端. AMI其实就是在代理端,使用Future机制进行异步调用,而不阻 ...

  7. ZeroC ICE的远程调用框架 Callback(一)-AMI异步方法调用框架

    Ice框架提供了不少回调设施,其中一些是使用Ice远程调用进行ami模式或amd模式的支撑.本篇来看一下用于代理端的回调设施. Ice代码中有好几个Callback相关命名的基类,并且slice还会为 ...

  8. ZeroC ICE的远程调用框架 ThreadPool

    ThreadPool提供Reactor/Proactor服务,并且强偶合了Reactor(反应器)/Proactor(前摄器).不同于Reactor/Proactor使用线程池 进行事件处理的设计.如 ...

  9. ZeroC ICE的远程调用框架 ASM与defaultServant,ServantLocator

    ASM与defaultServant,ServantLocator都是与调用调度(Dispatch)相关的. ASM是ServantManager中的一张二维表_servantMapMap,默认Ser ...

随机推荐

  1. python学习-模块与包(九)

    9.4查看模块内容 dir(): 返回模块或类所包含的全部程序单元(包括变量.函数.类和方法等) __all__:模块本身提供的变量,不会展示以下划线开头的程序单元.另使用from xx import ...

  2. vue element NavMenu 莫名出现蓝色边框

    最近在开发一款官网,使用的是element,在头菜单NavMenu,的时候没有设置任何的边框属性,结果出现了如下图所示的边框线. 点击有二级菜单时出现 找了好多方法发现是有一个属性影响到了,:focu ...

  3. MyBatis 示例-类型处理器

    MyBatis 提供了很多默认类型处理器,参考官网地址:链接,除了官网提供的类型处理器,我们也可以自定义类型处理器. 具体做法为:实现 org.apache.ibatis.type.TypeHandl ...

  4. GridSplitter

    <Grid> <Grid.ColumnDefinitions> <ColumnDefinition Width="*" /> <Colum ...

  5. Enum枚举学习- java5之前和之后的写法

    enum枚举 JDK1.5以前枚举的写法 /** * java5.0以前,定义枚举类.类中的对象是有限的 * @author amber * */ public class Season { priv ...

  6. 分享一次大厂的技术面试通过,却因学历被拒发 offer 的悲惨经历

    概述 今天心情很down,快周末了,说点不开心的事情给大家开心一下,上周面试心仪已久的大厂,技术面很顺利的通过一面/二面/三面,最后到HR面也很顺利,然后被问到学历(自考本科)后,HR 语气发生一些转 ...

  7. 设计模式(十六)Mediator模式

    在实际的工作小组的交流过程是,组员向仲裁者报告,仲裁者向组员下达指示,组员之间不再互相询问和指示.Mediator模式是指,当发生麻烦事情的时候,通知仲裁者:当发生涉及全体组员的事情时,也通知仲裁者. ...

  8. Java自动化测试框架-06 - 来给你的测试报告化个妆整个形 - (下)(详细教程)

    简介 经过上一次的化妆和整形,有客户提出需求能不能将那个普通会员的套餐再升级一下,再漂亮一点.所以这次咱们就来看看从哪里下刀可以使它变得再漂亮一点点. 上一篇文章修改了一些基本的ReportNG信息, ...

  9. Maven optional关键字透彻图解

    写在前面 本来想写一篇「如何自定义Spring Boot Starter」,但是为了更好理解 Starter 的一些设计理念和其中的关键点,所以提前将一些细节内容单独提取出来讲解说明 在 Maven ...

  10. Docker在Linux上 基本使用

    简介 Docker 是一个开源的应用容器引擎,让开发者可以打包他们的应用以及依赖包到一个可移植的容器中,然后发布到任何流行的Linux机器上,也可以实现虚拟化,容器是完全使用沙箱机制,相互之间不会有任 ...