t-io企业集群版的msg服务器tio-msg-demo,你肯定感兴趣

294 阅读2分钟

概念

什么是RPC(Remote Procedure Call)远程过程调用,是一种通过网络从远程计算机程序上请求服务,实现某个业务,但是不需要具体了解底层网络技术的协议。t-io把程序中对外实现通信的各个协议模块进行了打包处理成一个盒子,上层应用对外通信就只要对接盒子的接口,而不必关心盒子里面的内容,RPC服务要对外实现远程调用,首先要跟t-io通信,再到远方的服务。 具体请参考

引述

企业集群版的t-io,已经实现了msg服务器。自从有了集群服务器后,做rpc, 做msg都是很容易的事了!对于有RPC业务需求的老铁又是一大福音。我自己开发的IM聊天工具谭聊中已经验证的非常完美了。 废话不多说,请看具体实现代码。

示范代码

DemoMessage.

package org.tio.msg.demo; import org.tio.msg.common.bs.msg.Message; public class DemoMessage extends Message { private static final long serialVersionUID = -985195945448439158L; private String name = "hello tio message"; public String getName() { return name; } public void setName(String name) { this.name = name; } }

启动类TioMsgDemoStarter.java

`package org.tio.msg.demo;

import java.sql.SQLException;

import org.slf4j.Logger; import org.slf4j.LoggerFactory; import org.tio.core.Node; import org.tio.msg.client.MsgClientStarter; import org.tio.msg.client.MsgApi; import org.tio.msg.common.utils.JsonInit; import org.tio.msg.common.utils.PropInit; import org.tio.utils.jfinal.P;

/**  * @author tanyaowu  / public class TioMsgDemoStarter { private static Logger log = LoggerFactory.getLogger(TioMsgDemoStarter.class); public static MsgClientStarter cluClientStarter = null; /* * 基本的初始化,一般用于单元小测试 * @throws SQLException  / public static void initBase() throws SQLException { PropInit.init(new String[] { "app.properties" }); JsonInit.init(); } /* * @param args * @author tanyaowu */ public static void main(String[] args) { try { initBase(); //启动tio cluster client Node cluServerNode = new Node(P.get("tio.clu.server.ip"), P.getInt("tio.clu.server.port")); cluClientStarter = new MsgClientStarter(false, null, cluServerNode, null); cluClientStarter.start(); Thread.sleep(100L);//sleep一下,让各连接的握手完成,实际项目中,一般不需要这样 //添加listener MsgApi.addListener(cluClientStarter.getClientTioConfig(), DemoMessage.class, DemoMessageListener.me); for (int i =0; i < 1000; i++) { //发布一个demo 消息 DemoMessage demoMessage = new DemoMessage(); demoMessage.setName("hello tio message " + i); MsgApi.publish(cluClientStarter.getClientTioConfig(), demoMessage, true); } } catch (Throwable e) { log.error("", e); System.exit(1); } } }`

运行

`04-24 22:27:01 INFO  o.t.c.client.PacketDispatcher[102] server:127.0.0.1:1982, client:0:0:0:0:0:0:0:0:13378 收到消息:MessageNtf

04-24 22:27:01 WARN  o.t.m.demo.DemoMessageListener[20] 收到Tio Message, fromCid[1385963494888697856], Message: { "name":"hello tio message" }`