ICE的Glacier2使用
1、使用Glacier2的步骤:
A、编写一个Glacier2的配置文件,参见样例
B、设置Glacier2的访问鉴权(密码或者证书),passwords文件每行样例"test xxMqsnnDcK8tw" 可以通过openssl的passwd命令创建密码
C、定制Glacier2的session管理对象
D、启动Glacier2,glacier2router --Ice.Config=config
E、修改客户端的配置使用router
F、获取Glacier2.router并创建session
G、附加线程保持session的激活状态
2、Glacire2的配置样例:
Glacier2.InstanceName=MyRouter
Glacier2.Client.Endpoints=tcp -h 5.6.7.8 -p 4063
Glacier2.Client.PublishedEndpoints=tcp -h 5.6.7.8 -p 4064
Glacier2.Server.Endpoints=default
Glacier2.SessionManager=MySessionManager:tcp -h 127.0.0.1 -p 10001
Glacier2.PermissionsVerifier=MySessionVerifier:tcp -h 127.0.0.1 -p 10002
Glacier2.SSLPermissionsVerifier=MySSLSessionVerifier:tcp -h 127.0.0.1 -p 10003
Glacier2.SessionTimeout=60
Glacier2.SessionManager.LocatorCacheTimeout=30
Glacier2.SSLSessionManager.LocatorCacheTimeout=30
Glacier2.CryptPasswords=passwords
Glacier2.AddConnectionContext=1
Glacier2.Client.ForwardContext=1
Glacier2.Server.ForwardContext=1
Glacier2.Trace.Session=1
Glacier2.Client.Trace.Request=1
Glacier2.Filter.Address.Accept=10.0.1.[5,6]:[10000-11000]
Glacier2.Filter.Address.Reject=10.0.1.[5,6]:[10500,10501]
Glacier2.Filter.Category.Accept=cat1 cat2
Glacier2.Filter.Identity.Accept=id1 id2
Glacier2.Filter.AdapterId.Accept=Adapter1 Adapter2
Glacier2.RoutingTable.MaxSize=10000
Glacier2.Filter.ProxySizeMax=10000
3、客户端使用Glacier2
A、配置默认router:Ice.Default.Router=MyRouter/router:tcp -h 5.6.7.8 -p 4063
B、关闭ACM,Ice.ACM.Client=0 Ice.RetryIntervals=-1
C、创建Session
Ice::RouterPrx defaultRouter = communicator->getDefaultRouter();
Glacier2::RouterPrx router = Glacier2::RouterPrx::checkedCast(defaultRouter);
Glacier2::SessionPrx session = router->createSession(username, password); //创建基于密码方式的session
Glacier2::SessionPrx sslSession = router->createSessionFromSecureConnection(); // 基于ssl的证书方式创建session
D、创建额外的线程,在线程中隔段时间调用router->refreshSession()来确保session的存活
也可以通过调用session对象的ice_ping()方法来刷新session的过期时间
E、为了能够让服务器端使用回调,客户端试图传递一个回调的代理对象CallBackPrx给服务器端,让服务器端在合适的时机来进行回调
首先需要有一个adapter,其router已经设置,可动态创建createObjectAdapterWithRouter,也可静态配置
CallbackAdapter.Router=Glacier2/router:tcp -h 5.6.7.8 -p 4063
F、在该adapter上增加CallBack对象,返回CallBackPrx对象,可以通过各种方式传递给服务器端
G、如果在客户端会存在一个嵌套的调用,即客户端在处理请求的同时需要处理回调,注意一定要增加客户端的线程数Client.ThreadPool.Size
H、有时客户端为了简化代码逻辑处理,可以使用Glacier2::Application类来编程程序,其自动获取router代理和管理session
class Application : public Ice::Application
{
public:
Application();
Application(Ice::SignalPolicy policy);
virtual int runWithSession(int argc, char* argv[]) = 0; // 成功返回0,非0表示失败
virtual Glacier2::SessionPrx createSession() = 0; // 创建session对象
virtual void sessionDestroyed(); // 释放session
static Glacier2::RouterPrx router(); // 获取router代理
static Glacier2::SessionPrx session(); // 获取创建好的session代理
void restart();
std::string categoryForClient(); // 获取session的分类
Ice::Identity createCallbackIdentity(const std::string& name); // 获取一个回调对象的ID
Ice::ObjectPrx addWithUUID(const Ice::ObjectPtr& servant); // 加入一个回调处理对象,返回回调代理
Ice::ObjectAdapterPtr objectAdapter(); // 获取用于回调的adapter
};
4、服务器端使用Glacier2
A、实现Glacier2的session管理
class MySessionManagerI : public Glacier2::SessionManager
{
public:
virtual ::Glacier2::SessionPrx create(const std::string& User, const ::Glacier2::SessionControlPrx&, const ::Ice::Current& current);
};
class MySSLSessionManagerI : public Glacier2::SSLSessionManager
{
public:
virtual ::Glacier2::SessionPrx create(const ::Glacier2::SSLInfo&, const ::Glacier2::SessionControlPrx&, const ::Ice::Current& current);
};
B、注意在上述session管理对象的create方法中,必须返回一个Session的代理对象,该session的代理对象必须要包含对应的router属性
可以通过current.adapter->addWithUUID(new MySession);获得
C、实现Session对象接口
class MySession : public ::Glacier2::Session
{
public:
virtual void destory();
};
D、实现Glacier2的鉴权接口,当然你也可以使用ssl的鉴权方式
class MySessionVerifier : public Glacier2::PermissionsVerifier
{
public:
bool checkPermissions(string userId, string password, out string reason);
};
class MySSLSessionVerifier : public Glacier2::SSLPermissionsVerifier
{
public:
bool authorize(SSLInfo info, out string reason);
}
E、可以在SessionManager的create方法中通过SessionControlPrx对象动态的设置session的访问过滤
interface SessionControl {
StringSet* categories();
StringSet* adapterIds();
IdentitySet* identities();
void destroy();
ICE的Glacier2使用的更多相关文章
- ZeroC Ice 暂记
摘自: http://weibo.com/p/1001603869896789339575 原文地址: http://www.oschina.net/question/865233_242146 吴治 ...
- Ice简介+Qt代码示例
1.ICE是什么? ICE是ZEROC的开源通信协议产品,它的全称是:The Internet Communications Engine,翻译为中文是互联网通信引擎,是一个面向对象的中间件,它封装并 ...
- ICE的连接机制
1.当使用ICE的proxy进行方法调用时,ICE运行环境会建立一个到服务器的连接.当proxy提供了多个endpoint时 默认的ICE运行环境选择endpoint的行为为random,可以通过 ...
- 高性能分布式应用开发中间件ICE介绍
作为一个技术人员,你是否在为不断增长的数据量和日益复杂的业务逻辑而头疼不已,杂乱堆砌在一起的庞大业务让系统越来越脆弱,于是你想到了网格,想到了利用分布式来重组一个健壮的系统架构. 随后,RMI,EJB ...
- Ice框架介绍
概述 Ice是一个开源的综合性RPC框架,以高性能和原生支持微服务的架构而著称.提供了很多可以直接使用的组件,如注册中心IceGrid,部署工具IcePatch2,防火墙穿透Glacier2,发布订阅 ...
- ZeroC Ice启用SSL通讯的配置
Zeroc ICE ( Internet Communications Engine )中间件号称标准统一,开源,跨平台,跨语言,分布式,安全,服务透明,负载均衡,面向对象,性能优越,防火墙穿透,通讯 ...
- 第3月第2天 find symbolicatecrash 生产者-消费者 ice 引用计数
1.linux find export find /Applications/Xcode.app/ -name symbolicatecrash -type f export DEVELOPER_DI ...
- c#Ice开发之环境配置(一)
第一步,基于Windows下的安装,所以下载windows版的Ice,官网最新版本是Ice3.5.1: http://www.zeroc.com/download/ 安装完成可以在vs-工具的最下面看 ...
- Ice分布式程序设计—IceBox(Hello World Application)
忙了三天,总算浏览完此书.藉此记下 Ice 的 IceBox 服务框架. 在此用 IceBox 框架写 Hello World 程序,即以载体来体现其特性. 第一步:编写 Slice 文件,映射生成 ...
随机推荐
- 面向对象高级编程——使用@property
在绑定属性的时候,如过我们直接把属性暴露出去,虽然写起来简单,但是,没办法检查参数,导致可以把成绩随意改: s = Student() s.score = 9999 #不符合常规依然可以更改 这显然不 ...
- 在运行myeclipse10注册机时,显示找不到com.sun.java.swing.plaf.nimbus.NimbusLookAndFeel这个包
在win7下安装MyEclipse10.安装完成之后运行注册机,总是提示classnotfond显示找不到com.sun.java.swing.plaf.nimbus.NimbusLookAndFee ...
- 每天一个Linux命令(40)vmstat命令
vmstat是Virtual Meomory Statistics(虚拟内存统计)的缩写,可对操作系统的虚拟内存.进程.CPU活动进行监控. 它能够对系统的整体情况进行统计,无法对某个进程 ...
- HTTP学习笔记01-URL
URI URL语法 相对URL和绝对URL 相对URL URL的常用协议 http https mailto ftp rtsprtspu file news telnet 展望美好的未来 1.URI ...
- php数组函数-array_diff()
array_diff()函数返回两个数组的差集数组.该数组包括了所有在被比较数组中,但是不在任何其他参数数组中的键值在返回数组中,键名保持不变. array_diff(array1,array2,ar ...
- PHP常用函数的归纳
//===============================时间日期=============================== //y返回年最后两位,Y年四位数,m月份数字,M月份英文.d月 ...
- 20145240《Java程序设计》课程总结
20145240<Java程序设计>课程总结 每周读书笔记链接汇总 20145240 <Java程序设计>第一周学习总结:http://www.cnblogs.com/2014 ...
- Python面向对象的编程注意细节
和前文一样,这了也是学习过程中,来源于网上各种资料的一个整合记录,希望能够帮到自己和大家: 主要的关注点是在使用class的时候,应该注意的一些细节: 1.在class里面,有了 __init__(s ...
- Windows batch: call more than one command in a FOR loop?
https://stackoverflow.com/questions/2252979/windows-batch-call-more-than-one-command-in-a-for-loop U ...
- java基础(5)-集合类1
集合的由来 数组是很常用的一种数据结构,但假如我们遇到以下这样的的问题: 容器长度不确定 能自动排序 存储以键值对方式的数据 如果遇到这样的情况,数组就比较难满足了,所以也就有了一种与数组类似的数据结 ...