Tio.java简介

  • 为了让用户减少查找API的时间,t-io把常用API以静态方法的形式汇集于一个类,这就是Tio.java
  • Tio.java本身并不实现过复杂的业务,各业务实现仍然分布在其它类中,Tio.java只是把用户关心的API集中起来,便于用IDE查找而已

业务数据绑定

  • 资源绑定是指把业务相关的数据和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把Packet送给对方后才返回

  • 阻塞发送都是以bSend开头的,这个API有点多,贴代码有点长,用图片展示更舒适些

如何获取ChannelContext

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

  • 获取ChannelContext的API都是以get开头的,这个API有点多,贴代码有点长,用图片展示更舒适些

断开连接和移除连接

  • 断开连接都是以close开头的方法,指的是把当前已经连上的TCP连接断开掉

移除连接都是以remove开头的方法,指的是彻底抛弃这个连接

注意

  • 如果是用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拉黑IP

简单到极致,只需要一行代码

Tio.IpBlacklist.add(tioConfig, channelContext.getClientNode().getIp());

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

  1. 国产开源网络编程框架tio的得意之作—谭聊介绍

    想各位对即时通讯源码有追求人,必然有所了解谭聊,谭聊是完全基于开源网络编程框架t-io开发的一款即时通讯软件,也是t-io作者亲自操刀,性能上的强大能力完全继承了t-io的特性,即单机版可以达到近百万 ...

  2. t-io 3.7.5 发布,口碑炸裂的国产网络编程框架

    标题说明 看到"口碑炸裂"四字,应该又有不少"闻风而至"的同学要来"口吐芬芳",所以先上3张"炸裂封条" 如果3张&qu ...

  3. 学习C++项目——一个基于C++11简单易用的轻量级网络编程框架 1

    一个基于C++11简单易用的轻量级网络编程框架 一.项目下载.导入.编译和运行   现在准备深入学习 C++ ,先肝一个项目,这个项目是<一个基于C++11简单易用的轻量级网络编程框架>, ...

  4. 基于c++和asio的网络编程框架asio2教程基础篇:1、基本概念和使用说明

    基于c++和asio的网络编程框架asio2教程基础篇:1.基本概念和使用说明 由于asio2没有写技术文档,因此打算写几篇文章介绍一下如何使用它,主要是针对新手. 1.asio2如何使用? asio ...

  5. Python四大主流网络编程框架

    目前Python的网络编程框架已经多达几十个,逐个学习它们显然不现实.但这些框架在系统架构和运行环境中有很多共通之处,本文带领读者学习基于Python网络框架开发的常用知识,及目前的4种主流Pytho ...

  6. python网络编程攻略-Python四大主流网络编程框架

    目前Python的网络编程框架已经多达几十个,逐个学习它们显然不现实.但这些框架在系统架构和运行环境中有很多共通之处,本文带领读者学习基于Python网络框架开发的常用知识,及目前的4种主流Pytho ...

  7. 您所应了解的Python四大主流网络编程框架

    本文内容摘录自<Python高效开发实战--Django.Tornado.Flask.Twisted>一书.该书分为三部分:第1部分是基础篇,带领初学者实践Python开发环境和掌握基本语 ...

  8. 有限状态机的C++实现(2)-bayonet开源网络服务器框架

    有限状态机的C++实现(2)-bayonet开源网络服务器框架 | Vimer的程序世界 有限状态机的C++实现(2)-bayonet开源网络服务器框架 Published on 二月 18, 201 ...

  9. 基于c++和asio的网络编程框架asio2教程基础篇:2、各个回调函数的触发顺序和执行流程

    基于c++和asio的网络编程框架asio2教程基础篇:2.各个回调函数的触发顺序和执行流程 以tcp举例: tcp服务端流程: #include <asio2/asio2.hpp>int ...

最新文章

  1. jittor和pytorch生成网络对比之dragan
  2. svn 1.8.11 命令行提交新添加文件错误
  3. Python操作excel文件根据某一字段将相同的类拆分
  4. 安卓怎么显示res文件夹中的html_使用Android WebView加载现有的.html文件
  5. hdu 2833(Floyd + dp)
  6. php-fpm 无法运行cli,linux-怎样让php在cli与fpm环境下运行时加载不同的扩展?
  7. resnet50结构_无需额外数据、Tricks、架构调整,CMU开源首个将ResNet50精度提升至80%+新方法
  8. 【日常】Mac安装Homebrew
  9. Google 应用与游戏出海 7 月刊: 创意工具,让应用大放异彩
  10. 熬夜整理了一万多字的line-height总结,你还看不懂那我真的要跪了!
  11. 苏宁!你还挺得过去吗?(苏宁大幅裁员)
  12. windows 命令行操作
  13. 星界边境服务器Linux,星界边境starbound如何联机?服务器建立指南
  14. 12306暴SQL注入漏洞?!这下乐大发了
  15. linux mint ubuntu 16.06,Ubuntu和Linux Mint:安装Pinta 1.6工具
  16. Andriod微信小程序自动化测试
  17. 国产系统下的DES,SM4工具,银河麒麟V10桌面系统,飞腾芯片
  18. 移动云品牌焕新,全新LOGO全新启航!
  19. 《O N E 影视厅》管理系统——WAMP架构win10+apache+mysql+php
  20. SpringBoot实现登录注册

热门文章

  1. 良心安利通用模板素材网站
  2. 1条毛巾用27年:100个商界大佬的抠门绝活
  3. 产品经理经典面试题整理:问题拆解与回答思路
  4. [转]国内地图服务可用性比较
  5. 顺丰慢吗,了解这些问题你就能得到答案
  6. 合泰杯比赛总结(一)
  7. 简单使用tabby? (前端)
  8. 深入分析:Onliner SpamBot7.11亿电邮账号泄露事件
  9. php emoji 保存 显示不出来,PHP导出带有emoji表情的文本到excel文件出问题了
  10. 用c语言写复化梯形积分公式,第六章 函数和宏定义实验(2)