基于zeroice的多进程插件化

进程拆分
通用插件定义

一个进程内部插件:
PrintPlugin:控制台打印+文件存储(不是每一个进程都需要)
ModelMgrPlugin:自定义属性可实现该功能
ServiceProxyPlugin:服务代理Plugin
ServicePlugin:被调用接口集合plugin:生产内部任务
TaskMgrPlugin:任务队列管理:任务缓存,任务消费,任务解析,任务执行
TaskCosumerPlugin:

-----自定义属性:业务配置属性化
加载多个配置文件
--Ice.Config=config.server,config.model
可以将业务自定义模型文件加入进来,通过属性获取配置文件的值

----外部接口调用
ServiceProxyPlugin

一个service暴露多个servant 
解决问题:服务端多个接口放在一个实例 破坏了单一设计职责

一个接口类只干一种事儿
class Test001I : public Printer
class Test002I : public Logger

服务端:

auto servant = make_shared<PrinterI>();
        adapter->add(servant, Ice::stringToIdentity("SimplePrinter"));

        auto MyServant = make_shared<MyPrinterI>();
        adapter->add(MyServant, Ice::stringToIdentity("SimplePrinterTest"));

客户端:
        auto base = ich->stringToProxy("SimplePrinter:default -p 10000");
        auto printer = Ice::checkedCast<PrinterPrx>(base);
        if(!printer)
        {
            throw std::runtime_error("Invalid proxy");
        }
       

 printer->printString("Hello World!");

        auto MyBase = ich->stringToProxy("SimplePrinterTest:default -p 10000");
        auto printerT = Ice::checkedCast<PrinterPrx>(base);        

----内部插件接口调用
X插件内部调用了本进程内部的HelloPlugin插件,调用了一个pluginTestApi方法。
        auto  helloPlugin = std::dynamic_pointer_cast<::HelloPluginI>(current.adapter->getCommunicator()->getPluginManager()->getPlugin(“HelloPlugin”));
        helloPlugin->pluginTestApi();


zeroc所有属性查看
PropertyNames.cpp

属性介绍
https://docs.huihoo.com/ice/2.0.0/manual/index.html

----线程池配置
给客户端跨进程调用接口分配线程
Ice.ThreadPool.Client.Size=5
给服务端接口或者发送接口分配线程
Ice.ThreadPool.Server.Size=5
双向模式不管是接收还是发送都会分配线程
 

  • 3
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
zero ICE快速入门文档, ice是最优秀的rpc框架。 4、开发服务端代码如下 步骤一:编写Servant类即带有Disp的存根文件也就是说继承_HelloWorldDisp 这个类,这个类是个抽象类定义如下: public abstract class _HelloWorldDisp extends Ice.ObjectImpl implements HelloWorld{} servant类是ice所定义的接口,在服务器端的实现类。我们在该类中可以编写服务器端对请求的具体处理。 代码如下: package myHelloWorld.server; import Ice.Current; import myHelloWorld._HelloWorldDisp; public class HelloWorld_gaojs extends _HelloWorldDisp{ private static final long serialVersionUID = 1L; public void say(String s, Current __current) { System.out.println("Hello World!"+" the string s is " + s); } } 步骤二:创建远程的服务器类 package myHelloWorld.server; public class ServerStart { /** * @param args */ public static void main(String[] args) { int status = 0; // Communicator实例,是ice run time的主句柄 Ice.Communicator ic = null; try { // 调用Ice.Util.Initialize()初始Ice run time System.out.println("初始ice run time..."); ic = Ice.Util.initialize(args); // args参数可传可不传 // 创建一个对象适配器,传入适配器名字和在10000端口处接收来的请求 System.out.println("创建对象适配器,监听端口10000..."); Ice.ObjectAdapter adapter = ic.createObjectAdapterWithEndpoints( "SimplePrinterAdapter", "default -p 10000"); // 实例一个PrinterI对象,为Printer接口创建一个servant System.out.println("为接口创建servant..."); Ice.Object object = new HelloWorld_gaojs(); // 调用适配器的add,告诉它有一个新的servant,传递的参数是刚才的servant,这里的“gaojs”是Servant的名字 System.out.println("对象适配器加入servant..."); adapter.add(object, Ice.Util.stringToIdentity("gaojs")); // 调用适配器的activate()方法,激活适配器。被激活后,服务器开始处理来自客户的请求。 System.out.println("激活适配器,服务器等待处理请求..."); adapter.activate(); // 这个方法挂起发出调用的线程,直到服务器实现终止为止。或我们自己发出一个调用关闭。 ic.waitForShutdown(); } catch (Ice.LocalException e) { e.printStackTrace(); status = 1; } catch (Exception e) { e.printStackTrace(); status = 1; } finally { if (ic != null) { ic.destroy(); } } System.exit(status); } }
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值