国产开源网络编程框架t-io使用必备:极速开发器Tio.java

爱写码
• 阅读 1426

Tio.java简介

  • 为了让用户减少查找API的时间,t-io把常用API以静态方法的形式汇集于一个类,这就是Tio.java

  • Tio.java本身并不实现过复杂的业务,各业务实现仍然分布在其它类中,Tio.java只是把用户关心的API集中起来,便于用IDE查找而已 具体请参考:https://www.tiocloud.com/doc/tio/245

    业务数据绑定

  • 无序列表资源绑定是指把业务相关的数据和Tcp连接(即ChannelContext)关联起来,譬如ChannelContext-A代表了用户张三,张三的userid是333,就用下面的代码进行绑定

    Tio.bindUser(ChannelContext-A, "333")
  • 无序列表t-io目前内置了4种资源绑定,当然用户可以灵活使用这些绑定从而解决业务层所有的资源绑定问题,譬如可以给group加前缀”ios-“,从而标记这个用户使用的是ios,譬如

    Tio.bindGroup(ChannelContext-A, "333");
    Tio.bindGroup(ChannelContext-A, "ios-" + "333");
  • 无序列表内置的4种资源绑定方法中,一个ChannelContext是可以绑定到多个groupid的,其它三个绑定都是一对一或多对一的关系,也就是说一个ChannelContext可以同时属于group-a,group-b… …group-n

  • 无序列表下面贴一下这4个资源绑定的源代码

    /**
     * 绑定业务id
     * @param channelContext
     * @param bsId
     * @author tanyaowu
     */
    public static void bindBsId(ChannelContext channelContext, String bsId) {
        channelContext.tioConfig.bsIds.bind(channelContext, bsId);
    }
    /**
     * 绑定群组
     * @param channelContext
     * @param group
     * @author tanyaowu
     */
    public static void bindGroup(ChannelContext channelContext, String group) {
        channelContext.tioConfig.groups.bind(group, channelContext);
    }
    /**
     * 绑定token
     * @param channelContext
     * @param token
     * @author tanyaowu
     */
    public static void bindToken(ChannelContext channelContext, String token) {
        channelContext.tioConfig.tokens.bind(token, channelContext);
    }
    /**
     * 绑定用户
     * @param channelContext
     * @param userid
     * @author tanyaowu
     */
    public static void bindUser(ChannelContext channelContext, String userid) {
        channelContext.tioConfig.users.bind(userid, channelContext);
    }

    业务数据解绑

  • 无序列表既然有绑定,就肯定会有解绑,这是个和绑定相反的操作,所以话不多说,直接贴出不长的源代码

    /**
     * 解绑业务id
     * @param channelContext
     * @author tanyaowu
     */
    public static void unbindBsId(ChannelContext channelContext) {
        channelContext.tioConfig.bsIds.unbind(channelContext);
    }
    /**
     * 与所有组解除解绑关系
     * @param channelContext
     * @author tanyaowu
     */
    public static void unbindGroup(ChannelContext channelContext) {
        channelContext.tioConfig.groups.unbind(channelContext);
    }
    /**
     * 与指定组解除绑定关系
     * @param group
     * @param channelContext
     * @author tanyaowu
     */
    public static void unbindGroup(String group, ChannelContext channelContext) {
        channelContext.tioConfig.groups.unbind(group, channelContext);
    }
    /**
     * 解除channelContext绑定的token
     * @param channelContext
     * @author tanyaowu
     */
    public static void unbindToken(ChannelContext channelContext) {
        channelContext.tioConfig.tokens.unbind(channelContext);
    }
    //    org.tio.core.TioConfig.ipBlacklist
    /**
     * 解除channelContext绑定的userid
     * @param channelContext
     * @author tanyaowu
     */
    public static void unbindUser(ChannelContext channelContext) {
        channelContext.tioConfig.users.unbind(channelContext);
    }
    /**
     * 解除userid的绑定。一般用于多地登录,踢掉前面登录的场景
     * @param tioConfig
     * @param userid
     * @author: tanyaowu
     */
    public static void unbindUser(TioConfig tioConfig, String userid) {
        tioConfig.users.unbind(tioConfig, userid);
    }

    异步发送

  • 异步发送,指的是业务层把Packet丢给t-io后立即返回,返回时Packet并没有被发送,而只是提交到了待发送队列

  • 异步发送都是以send开头的,这个API有点多,贴代码有点长,用图片展示更舒适些 国产开源网络编程框架t-io使用必备:极速开发器Tio.java

    阻塞发送

  • 阻塞发送:t-io把Packet送给对方后才返回

  • 阻塞发送都是以bSend开头的,这个API有点多,贴代码有点长,用图片展示更舒适些 国产开源网络编程框架t-io使用必备:极速开发器Tio.java

    如何获取ChannelContext

  • 前面的业务数据绑定,一个重要的目的就是要根据那些业务标识来获取ChannelContext,譬如你绑定了一个userid,那么后面就可以通过这个userid来获取ChannelContext

  • 获取ChannelContext的API都是以get开头的,这个API有点多,贴代码有点长,用图片展示更舒适些 国产开源网络编程框架t-io使用必备:极速开发器Tio.java

    断开连接和移除连接

  • 无序列表断开连接都是以close开头的方法,指的是把当前已经连上的TCP连接断开掉 国产开源网络编程框架t-io使用必备:极速开发器Tio.java

  • 无序列表移除连接都是以remove开头的方法,指的是彻底抛弃这个连接 国产开源网络编程框架t-io使用必备:极速开发器Tio.java

  • 注意*

  • 如果是用t-io做TCP服务器端* 上面两个方法是等价的,因为服务器不存在重连一说

  • 如果是用t-io做TCP客户端,并且没有配置重连* 上面两个方法也是等价的,因为不需要重连,tio断开连接后就会释放该连接全部资源

  • 如果是用t-io做TCP客户端,并且配置了重连规则,上面两个方法才是有区别的,区别如下* close(): 不释放相关资源,并且会进行重连 remove():完全释放相关资源,不再进行重连

    集群通知

  • t-io是内置集群功能的,作为与业务不相关的io框架,内置集群功能是件费力却不见得讨好的事(为啥不讨好?譬如会增加代码复杂度、会降低tio-mvc在TFB上的跑分排名),但t-io考虑到广大用户的呼声,还是内置了集群功能

  • 目前t-io提供的消息发送功能,都是支持集群的,这个从Tio.java的源代码中就能看出来

  • 集群通知类API都是以notifyCluster开头的,见图 国产开源网络编程框架t-io使用必备:极速开发器Tio.java

    t-io拉黑IP

  • 无序列表简单到极致,只需要一行代码

    Tio.IpBlacklist.add(tioConfig, channelContext.getClientNode().getIp());
点赞
收藏
评论区
推荐文章
爱写码 爱写码
2年前
网络编程框架t-io的编程基本知识介绍
tio作为目前国内最流行的开源网络编程框架软件,以简单易懂,上手容易而著称,相同的功能比起netty实现起来,要简单的多,代码量也大大减少,如果要使用好tio,还是要先学习tio的一些基本知识,这篇文章主要从8个方面介绍了tio的基础知识。具体请参考:tio收发消息过程tio收发消息及处理过程,可以用一张图清晰地表达出来应用层包:PacketPacke
待兔 待兔
3个月前
手写Java HashMap源码
HashMap的使用教程HashMap的使用教程HashMap的使用教程HashMap的使用教程HashMap的使用教程22
Easter79 Easter79
3年前
Vue 入门
Vue.js是构建用户界面的MVVM框架 ,只关注视图层Vue将DOM和数据绑定起来,一旦创建了绑定,DOM将和数据保持同步,每当变更了数据,DOM也会相应地更新。这样就减少了不必要的DOM操作提高渲染效率,让前端程序员只需要关心业务逻辑不再关心DOM是如何渲染的MVC和MVVM的区别:MVC是后端分层开发概念,MVVM是前端视图层
爱写码 爱写码
3年前
聊聊t-io和netty的差异
引言tio和netty的差异,这是个被大量问及的问题,在此,作为tio作者,列一些差异化的东西tio的最大优势API设计易懂,尽量避免引入自创概念——最大限度降低学习成本接管了大量业务资源的绑定与自动解绑,开发人员只需要无脑地调用API即可完成绑定与解绑功能,这个处理如果丢给业务开发人员是极其复杂易错的:多线程环境下的集合管理都是要同步安全的,同步的设计既
爱写码 爱写码
3年前
t-io应用场景和能力
tio历史、应用场景(图示——简)tio应用场景(文字描述——详)tio是基于JVM的网络编程框架,和netty属同类,所以netty能做的tio都能做,考虑到tio是从项目抽象出来的框架,所以tio提供了更多的和业务相关的API,大体上tio具有如下特点和能力:内置完备的监控和流控能力内置半包粘包处理一骑绝尘的资源管理能力内置心跳检查和心跳发送能力
Stella981 Stella981
3年前
Scut开源游戏服务器引擎
Scut开源游戏服务器引擎简介Scut游戏服务器引擎使用C语言开发,特别适用于手机网络游戏,支持使用Python脚本进行游戏开发;支持MSSQL/Mysql数据库;支持HTTP/Socket协议同时接入;采用实体类对象建模,自动构造数据库表结构生成和修改语句;业务逻辑层使用C/Python脚本开发,提供了丰富的类库和API接口,极大降低了开
Wesley13 Wesley13
3年前
C++实现简单的RPC框架
简介    RPC是远程过程调用(RemoteProcedureCall)的缩写形式 ,RPC的目的是为了简化网络通信,让用户可以专注于业务处理,不用关心网络层的处理,真正实现在客户端A中调用函数F就可以调用服务端B中的函数F的目的。    RPC模型引入存根进程(stub)的概念, 对于服务端的服务类A,在客户端通过A::s
Stella981 Stella981
3年前
IOS数据存储之NSUserDefaults
概述数据存储是开发中必不可少的一个功能,我们可以通过Sqlite数据库手动创建数据库,定义数据表;可以使用IOS的数据框架CoreData,更方便的操作数据库;也可以直接读写文件系统;这里将介绍另外一种常用的方法:使用NSUserDefaults类,以字典形式保存数据,IOS会自动把字典中的键值对转换成对应的XML文件(也就是plist文件),这
Stella981 Stella981
3年前
Devops与敏捷二者能否结合?
当前软件行业的趋势倾向于使应用程序开发和部署成为业务运营的重要组成部分。这些公司开始专注于实现像DevOps解决方案这样的方法,这有助于缩短产品开发时间。使用DevOps进行开发减少了交付软件所需的阶段。软件交付时间短允许用户尽早部署软件,并通过更多的反馈为业务增加价值。DevOps与敏捷的结合DevOps的实施主要集中在软
Wesley13 Wesley13
3年前
5000多张数据表,如何用SQL迁移到数据仓库?
点击关注上方“SQL数据库开发”,设为“置顶或星标”,第一时间送达干货需求背景最近公司打算集中梳理几大业务系统的数据,希望将各个业务系统中的数据集中到数据仓库中。总共有5000多张数据表,但是好在业务数据量没有像电商那么庞大,也就几十个G。需求分析其实这个需求很简单,就是把这50