1、当使用ICE的proxy进行方法调用时,ICE运行环境会建立一个到服务器的连接。当proxy提供了多个endpoint时
   默认的ICE运行环境选择endpoint的行为为random,可以通过ice_endpointSelection设置选择endpoint的方式为order
   也可以通过设置属性:Ice.Default.EndpointSelection、name.EndpointSelection来改变endpoint的选择策略
2、ICE的连接在失败时会重试,重试的规则取决于属性Ice.RetryIntervals,默认取值为0,即立即重试一次
   可以配置成如下形式:Ice.RetryIntervals=0 10 50 100
   可以配置Ice.Trace.Retry来跟踪连接的重试
3、ICE支持给每个连接一个唯一的ID标示,来让应用控制连接的使用行为,通过调用proxy的ice_connectionId方法
   来给其建立的连接命名。当然使用相同连接ID的代理意味着共享了相同的连接
4、ICE会对proxy上的建立的连接进行cache,以确保下次方法调用时尽可能的使用已经建立的连接,有时如果应用针对
   某个proxy有多个endpoint,并且希望在这些endpoint之间保持负载均衡的方法调用,那么可以通过设置属性
   ice_connectionCached(false)来关闭连接cache,当然这也会为频繁的连接建立带来足够的开销
5、ICE的每个连接都有两个超时时间:ice_timeout、ice_connectiontimeout,分别对应消息的超时时间和连接建立
   的超时时间,可以通过在代理上调用上述方法来设置超时,也可以通过属性Ice.Override.Timeout、Ice.Override.ConnectTimeout
   来强制改变超时时间
6、ICE运行环境针对每个communicator可以设置连接ACM,分别为Ice.ACM.Client和Ice.ACM.Server,默认取值为60s
   意味着如果连接存在60s的idle时间,那么连接将会自动关闭。可以设置取值为0来禁用IDLE检测机制。那么连接建立后
   则不会关闭,直到communicator关闭为止。ICE检测空闲连接的时间间隔为Ice.MonitorConnections,取值在5s到5m之间。
   如果你使用了glacier2来进行防火墙的策略调度,那么你最好关闭ACM,否则可能会导致过早的关闭客户端连接而导致
   回调无法成功
7、程序中获取连接:客户端可以使用proxy->ice_getConnection(),服务器端可以使用current.conn
8、连接对象提供的接口方法如下:
   local interface Connection 
   {
       void close(bool force);                    // 关闭连接,基本上很少显示调用
       Object* createProxy(Identity id);          // 在使用双向的防火墙策略时,常在客户端使用来创建回调对象
       void setAdapter(ObjectAdapter adapter);    // 设置代理的对象适配器,也常用于双向连接
       ObjectAdapter getAdapter();                // 获取adapter对象
       Endpoint getEndpoint();                    // 获取endpoint端点信息
       void flushBatchRequests();                 // 刷新批量请求
       string type();                             // 返回协议类型,类似如:tcp、udp、ssl
       int timeout();                             // 返回超时时间
       string toString();                         // 串化
       ConnectionInfo getInfo();                  // 获取连接的相关连接信息,类似如tcp端口、udp信息等
    };
注意getEndpoint和getInfo返回的是基类信息,需要根据type方法的返回值来进行向下转型获取详情
9、
客户端双向连接的使用:
Ice::ObjectAdapterPtr adapter = communicator->createObjectAdapter("");
 // 创建默认adapter,无名称,无端点
    Ice::Identity ident;
    ident.name = IceUtil::generateUUID();
    ident.category = "";
    CallbackPtr cb = new CallbackI;                                         // 创建回调对象
    adapter->add(cb, ident);                                                // 添加回调对象为servant
    adapter->activate();                                                    // 激活adapter
    proxy->ice_getConnection()->setAdapter(adapter);                        // 设置代理对象的连接adapter为当前adapter
    proxy->addClient(ident);                                                // 传递callback的ID给服务器
10、服务器端双向连接的使用:
    CallbackPrx client = CallbackPrx::uncheckedCast(curr.con->createProxy(ident)); // 在连接上使用callback的id来创建代理
    client->notify();                                                              // 回调代理
注意,该处创建的callbackprx代理不能修改其相关属性:类似timeout、twoway、datagram等,同时需要关闭ACM机制来防止
不合事宜的连接关闭
11、客户端的双向调用接收callback的回调是在客户端线程池中,但是此时可能客户端线程池正在阻塞在客户端请求上,那么
    你最好配置客户端线程池的线程个数大于1,否则这样的嵌套调用会导致线程的死锁等待

ICE的连接机制的更多相关文章

  1. ZeroC Ice启用SSL通讯的配置

    Zeroc ICE ( Internet Communications Engine )中间件号称标准统一,开源,跨平台,跨语言,分布式,安全,服务透明,负载均衡,面向对象,性能优越,防火墙穿透,通讯 ...

  2. 第3月第2天 find symbolicatecrash 生产者-消费者 ice 引用计数

    1.linux find export find /Applications/Xcode.app/ -name symbolicatecrash -type f export DEVELOPER_DI ...

  3. c#Ice开发之环境配置(一)

    第一步,基于Windows下的安装,所以下载windows版的Ice,官网最新版本是Ice3.5.1: http://www.zeroc.com/download/ 安装完成可以在vs-工具的最下面看 ...

  4. Ice分布式程序设计—IceBox(Hello World Application)

    忙了三天,总算浏览完此书.藉此记下 Ice 的 IceBox 服务框架. 在此用 IceBox 框架写 Hello World 程序,即以载体来体现其特性. 第一步:编写 Slice 文件,映射生成 ...

  5. ZeroC Ice 暂记

    摘自: http://weibo.com/p/1001603869896789339575 原文地址: http://www.oschina.net/question/865233_242146 吴治 ...

  6. webrtc进阶-信令篇-之三:信令、stun、turn、ice

    webRTC支持点对点通讯,但是webRTC仍然需要服务端:  . 协调通讯过程中客户端之间需要交换元数据,    如一个客户端找到另一个客户端以及通知另一个客户端开始通讯.  . 需要处理NAT(网 ...

  7. VS2012配置使用ICE通信接口

    1.下载安装Ice-3.5.1.msi http://www.zeroc.com/download.html 2.添加安装路径到环境变量path,D:\Program Files (x86)\Zero ...

  8. clang 搭建和编译boost 和zero ICE库 (Ubuntu10 64)

    相关介绍资料如下: Boost编译http://sourceforge.net/projects/boost/files/boost/1.55.0/boost_1_55_0.tar.gz/downlo ...

  9. Ice的HelloWorld(Java)

    Ice是一种面向对象的中间间平台,入门ice,简单的HelloWorld是必不可少的. 转载请注明http://www.cnblogs.com/zrtqsk/p/3745286.html,谢谢. 一. ...

随机推荐

  1. 字符编码 and 字节和字符串转换(待补充)

    ascii用一个字节(8位二进制)代表一个字符 Unicode常用2个字节(16位二进制)代表一个字符,生僻字需要用四个字节 汉字中已经超出了ASCII编码的范围,用Unicode, Unicode兼 ...

  2. HTML中表格的使用

    表格: <table></table>表格 width:宽度.可以用像素或百分比表示. 常用960像素. border:边框,常用值为0. cellpadding:内容跟边框的 ...

  3. Django 之models进阶操作

    到目前为止,当我们的程序涉及到数据库相关操作时,我们一般都会这么搞: 创建数据库,设计表结构和字段 使用 MySQLdb 来连接数据库,并编写数据访问层代码 业务逻辑层去调用数据访问层执行数据库操作 ...

  4. 算法寒假实习面试经过之 十一贝(offer) 联想研究院(电话一面 被拒)

    联想研究院 1面 自我介绍 聊比赛,讲了讲jdd的. 感觉都快要背过了... 之前重复的问题就不说了,说一下印象比较深的 adaboost 与gbdt的区别 随机森林,如果有t个特征,n个树,每个树深 ...

  5. iOS 52个技巧学习心得笔记 第二章 对象 , 消息, 运行期

    1. 属性 在开发过程中经常要用到定义属性,@property和@synthesize是经常用到的属性, property在.h文件中作声明,@synthesize在.m文件中用于实现 // Stud ...

  6. SOA宣言和微服务特点

    如果从概念层来看,我更喜欢把SOA归为企业架构的范畴,从企业架构出发把业务分解为不同业务域的服务,关注系统间的服务互联互通的规范,并不关心如何实现.也就是说在企业架构上使用SOA支撑业务,而在方案架构 ...

  7. mysql 触发器 存储过程 java调用

    触发器和存储过程是为了提高SQL的运行效率. SQL语句先编译.后执行,而触发器与存储过程都会提前预编译完成,且只编译一次,供反复调用. 随着时代的进步,硬件与带宽的提升,触发器和存储过程提升效率并不 ...

  8. Linux Shell基础 Shell的输入重定向和输出重定向

    概述 在 Linux 中输入设备指的是键盘,输出设备指的是显示器.在 Linux 中,所有的内容都是文件,计算机硬件也是文件,标准输入设备(键盘)和标准输出设备(显示器)也是文件.这些设备的设备文件名 ...

  9. U-Boot中支持USB

    转载: http://blog.csdn.net/qiurihuanghua/article/details/6234832 今天查看了一下在P4080DS板子的U-Boot中支持USB,主要是加入U ...

  10. 【c++习题】【17/5/22】重载数组下标操作符

    一.写出程序运行结果 1#include <iostream > using namespace std; int a[10]={1,2, 3, 4, 5, 6, 7, 8, 9, 10} ...