ICE运行时环境备忘一

原创 2012年03月25日 14:50:32
1、ICE运行环境的唯一句柄Communicator对象,其用来管理ICE运行环境下所有对象资源,包含但不限于:
   A、客户端线程池,主要用来进行AMI方法的回调接口调用,防止环形调用产生的死锁
   B、服务器端的线程池,主要用来接收和处理客户端的接口调用请求
   C、ICE运行环境对应的属性集合
   D、对象工厂,主要用来根据实例化接口对象
   E、日志对象和统计对象,其实现日志接口和统计接口用以实现ICE运行过程中的日志记录和网络传输统计
   F、缺省的路由器和定位器
   G、插件管理对象,用来管理ICE运行环境下的插件对象
   H、对象适配器ObjectAdapter,用以维护对象标示和服务对象之间的映射关系
2、Communicator对象的定义类似如下:
class CommunicatorI : public Communicator
{
public:
virtual void destroy();                   // 销毁通信器以及其所管理的ICE运行资源
virtual void shutdown();                  // 关闭通信器,不再接收客户端请求,但是正在执行的请求会执行完成
virtual void waitForShutdown();           // 等待当前通信器结束,意味着正在执行的所有请求都执行完毕
virtual bool isShutdown() const;          // 判断通信器是否已经关闭


virtual ObjectPrx stringToProxy(const std::string&) const;    // 根据对象标示获取对象的代理
virtual std::string proxyToString(const ObjectPrx&) const;    // 根据对象代理获取对象的标示


virtual ObjectPrx propertyToProxy(const std::string&) const;  // 根据给定的属性名称找到对应值的代理对象
virtual PropertyDict proxyToProperty(const ObjectPrx&, const std::string&) const;  // 返回代理对象的属性集


virtual Identity stringToIdentity(const std::string&) const;  // 将字符串标示转换成唯一ID
virtual std::string identityToString(const Identity&) const;  // 将唯一ID转换成字符串


virtual ObjectAdapterPtr createObjectAdapter(const std::string&);  // 通过名字创建对象适配器,端口在配置文件中配置(name.Endpoints)
virtual ObjectAdapterPtr createObjectAdapterWithEndpoints(const std::string&, const std::string&); //通过名称和端口创建适配器
virtual ObjectAdapterPtr createObjectAdapterWithRouter(const std::string&, const RouterPrx&);  // 通过名字和路由器来创建适配器


virtual PropertiesPtr getProperties() const;    // 获取通信器的属性集合
virtual LoggerPtr getLogger() const;            // 获取日志接口对象
virtual StatsPtr getStats() const;              // 获取统计接口对象
};
3、通信器Communicator的创建和初始化方法:
    Ice::CommunicatorPtr ic = Ice::Initialize(argc, argv, initdata);       // 通过命令行参数创建,会解析命令行中ICE相关属性
Ice::CommunicatorPtr ic = Ice::Initialize(initdata);                   // 通过初始化对象创建

Ice::InitializationData initdata;                                      // 构建初始化对象
initdata.properties = Ice::createProperties(args);                     // 设置初始化对象的属性集合
initdata.logger = new MyLoggerI;                                       // 设置对应的日志接口
initdata.stats = new MyStatsI;                                         // 设置对应的统计接口
4、对象适配器是ICE运行环境用来维护ASM的对象,管理ICE运行环境Activate Servant Map
   每个对象适配器有一个和多个接入端点可以接入
   每个对象适配器默认采用communicator的服务器线程进行消息处理,当然也可以通过指定<adapter-name>.ThreadPool.Size来指定自己的线程池
   可以通过Communicator中如下的方法创建一个ObjectAdapter对象:
   createObjectAdapter、createObjectAdapterWithEndpoints、createObjectAdapterWithRouter   
   Adapter对象提供了getName方法获取对象名称、getCommunicator方法获取其所在的通信器对象
   对象适配器是一个有状态的对象,其包含状态包括:Holding(初始状态,不接收请求)、Active(激活状态,正常处理)、Inactive(去激活状态,对象即将销毁)
   对象适配器提供了一系列的API来管理其状态转换:activate、hold、deactivate、waitForHold、waitForDeactivate、destory   
   对象适配器均有一个地址与其对应,类似如:"tcp -h 10.0.0.1 -p 35840 -t 5000 -z:tcp -h 10.0.0.2 -p 35840 -t 5000 -z" (绑定两个地址,超时5s,支持压缩)
   可以调用objectadapter的getEndpoints返回所绑定的地址信息
5、Servant对象时真正的接口服务对象,要想提供服务,需要将Servant对象加入到某一个objectAdapter中,并指定一个对象标示
    virtual ObjectPrx add(const ObjectPtr&, const Identity&);      // 指定ID添加对象,一般调用该方法
    virtual ObjectPrx addWithUUID(const ObjectPtr&);               // 自动生成对象标示来添加对象,仅仅临时的服务对象调用该方法添加
virtual ObjectPtr remove(const Identity&);                     // 从objectadapter的ASM中移除一个服务对象

    virtual ObjectPrx createProxy(const Identity&) const;          // 创建servant对应的代理对象
    virtual ObjectPrx createDirectProxy(const Identity&) const;    // 创建servant的直接代理对象
    virtual ObjectPrx createIndirectProxy(const Identity&) const;  // 创建servant的间接代理对象
6、在生成的ICE接口方法代码中,每个映射方法的后面都携带了一个current参数,Current的定义如下:
   module Ice 
   {
        local dictionary<string, string> Context;
        enum OperationMode { Normal, \Idempotent };
        local struct Current 
   {
            ObjectAdapter adapter;    // 服务器的对象适配器,可以通过它再调用getCommunicator得到通信器
Connection con;           // 连接对象
            Identity id;              // 服务对象标示
            string facet;             // 
            string operation;         // 操作的名称
            OperationMode mode;       // 操作模式
            Context ctx;              // 操作上下文属性
int requestId;            // 请求ID
        };
    };

Windows下安装Ice和设置Ice的环境变量

第一步,基于Windows下的安装,所以下载windows版的Ice,官网最新版本是Ice3.5.1-6 https://download.zeroc.com/Ice/3.5/Ice-3.5.1-6...

ICE的属性设置

1、ICE的属性即"name=value"值,具体的name范畴可以见后续描述。可以在程序中设置属性值到ICE的运行环境中    但一定要注意在Communicator::Initialize方法调...

ICE运行环境备忘二

1、需要理解ICE运行环境对客户端请求的调用分派语义,即当一个请求到来时,如何查找到对应到servant服务对象进行消息处理    A、在ASM 中查找该标识。如果ASM 有这样一个条目,就把请求分...

eclipse和NetBeans环境下运行JNA操作备忘

1,eclipse下操作 转自 点击打开链接 1. 下载jna.jar 到JNA官网下载最新版本的“jna.jar”,当前的最新版是4.1.0(to 2015.08)。链接如下: http...

VS2008运行时环境

  • 2017年02月15日 14:01
  • 533KB
  • 下载

Java 运行时环境版本

  • 2008年09月25日 15:07
  • 2KB
  • 下载

Dalvik和ART运行时环境的区别

Dalvik和ART运行时环境的区别在此,我并没有打算深入的学习Dalvik和ART两种方式的实现原理,只是想知道他俩的区别。之前,也是零零散散的看过,并没有总结成文字。在此,总结下。Dalvik以下...

浏览器启动java程序的运行时环境设置

浏览器启动java程序时,会按照安装jdk时的默认参数启动,可能会遇到内存不够无法启动程序的情况,此时可通过设置java默认运行时环境参数解决: 进入控制面板—程序: 进入“java”: 进入...
  • hanxyf
  • hanxyf
  • 2017年06月19日 10:15
  • 88
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:ICE运行时环境备忘一
举报原因:
原因补充:

(最多只允许输入30个字)