为RPC而生的t-io企业集群版的msg服务器tio-msg-demo,你应该感兴趣
概念解释
什么是RPC(Remote Procedure Call)远程过程调用,是一种通过网络从远程计算机程序上请求服务,实现某个业务,但是不需要具体了解底层网络技术的协议。t-io把程序中对外实现通信的各个协议模块进行了打包处理成一个盒子,上层应用对外通信就只要对接盒子的接口,而不必关心盒子里面的内容,RPC服务要对外实现远程调用,首先要跟t-io通信,再到远方的服务。
为什么要使用RPC呢?如果一个系统(例如,网站、大型应用等)中内部子系统较多、接口也非常多的情况下,采用RPC的好处就很明显了,RPC中采用的长链接,不必每次通信都要像有些协议一样每次都要进行3次握手来建立连接,例如,HTTP协议,这样就能减少了网络开销;其次,就是RPC中一般都有注册中心,而且有丰富的监控管理模块;应用方要进行发布、捆绑下线接口、动态扩展等,对调用方来说可以是无感知、归一化的操作。而且RPC的安全性也很好。
可见RPC下面如果有一个非常高效的网络编程框架配合,使用起来会很方便,由于t-io中内置了socket、NIO功能,所以跟RPC对接具有天然的优势,当然也可以使用netty,但是netty的使用起来比t-io会复杂很多。
基于t-io开发的最成功即时通讯软件谭聊,已经完好的实现RPC的功能,具体请参考:tio-msg-demo
msg服务器介绍
企业集群版的t-io,已经实现了msg服务器。自从有了集群服务器后,做rpc, 做msg都是很容易的事了!对于有RPC业务需求的老铁又是一大福音。我自己开发的IM聊天工具谭聊中已经验证的非常完美了。 废话不多说,请看具体实现代码。
示范代码
DemoMessage.java
1 package org.tio.msg.demo; 2 import org.tio.msg.common.bs.msg.Message; 3 public class DemoMessage extends Message { 4 private static final long serialVersionUID = -985195945448439158L; 5 private String name = "hello tio message"; 6 public String getName() { 7 return name; 8 } 9 public void setName(String name) { 10 this.name = name; 11 } 12 }
DemoMessageListener.java
1 package org.tio.msg.demo; 2 3 import org.slf4j.Logger; 4 import org.slf4j.LoggerFactory; 5 import org.tio.msg.common.bs.msg.MessageListener; 6 import org.tio.utils.json.Json; 7 8 public class DemoMessageListener implements MessageListener<DemoMessage> { 9 private static Logger log = LoggerFactory.getLogger(DemoMessageListener.class); 10 public static final DemoMessageListener me = new DemoMessageListener(); 11 12 @Override 13 public void onMessage(String fromCid, DemoMessage message) { 14 log.warn("收到Tio Message, fromCid[{}], Message:\r\n{}", fromCid, Json.toFormatedJson(message)); 15 } 16 }
启动类TioMsgDemoStarter.java
1 package org.tio.msg.demo; 2 3 import java.sql.SQLException; 4 5 import org.slf4j.Logger; 6 import org.slf4j.LoggerFactory; 7 import org.tio.core.Node; 8 import org.tio.msg.client.MsgClientStarter; 9 import org.tio.msg.client.MsgApi; 10 import org.tio.msg.common.utils.JsonInit; 11 import org.tio.msg.common.utils.PropInit; 12 import org.tio.utils.jfinal.P; 13 14 /** 15 * @author tanyaowu 16 */ 17 public class TioMsgDemoStarter { 18 private static Logger log = LoggerFactory.getLogger(TioMsgDemoStarter.class); 19 public static MsgClientStarter cluClientStarter = null; 20 /** 21 * 基本的初始化,一般用于单元小测试 22 * @throws SQLException 23 */ 24 public static void initBase() throws SQLException { 25 PropInit.init(new String[] { "app.properties" }); 26 JsonInit.init(); 27 } 28 /** 29 * @param args 30 * @author tanyaowu 31 */ 32 public static void main(String[] args) { 33 try { 34 initBase(); 35 //启动tio cluster client 36 Node cluServerNode = new Node(P.get("tio.clu.server.ip"), P.getInt("tio.clu.server.port")); 37 cluClientStarter = new MsgClientStarter(false, null, cluServerNode, null); 38 cluClientStarter.start(); 39 Thread.sleep(100L);//sleep一下,让各连接的握手完成,实际项目中,一般不需要这样 40 //添加listener 41 MsgApi.addListener(cluClientStarter.getClientTioConfig(), DemoMessage.class, DemoMessageListener.me); 42 for (int i =0; i < 1000; i++) { 43 //发布一个demo 消息 44 DemoMessage demoMessage = new DemoMessage(); 45 demoMessage.setName("hello tio message " + i); 46 MsgApi.publish(cluClientStarter.getClientTioConfig(), demoMessage, true); 47 } 48 } catch (Throwable e) { 49 log.error("", e); 50 System.exit(1); 51 } 52 } 53 }
运行
1 04-24 22:27:01 INFO o.t.c.client.PacketDispatcher[102] 2 server:127.0.0.1:1982, client:0:0:0:0:0:0:0:0:13378 收到消息:MessageNtf 3 4 04-24 22:27:01 WARN o.t.m.demo.DemoMessageListener[20] 5 收到Tio Message, fromCid[1385963494888697856], Message: 6 { 7 "name":"hello tio message" 8 }
浙公网安备 33010602011771号