xsocket:空闲超时问题。
XSocket是什么? java的nio的封装。
详情:
1. http://xsocket.sourceforge.net/core/apidocs/2_1/index.html
2. http://xsocket.org
开发中要解决的实际问题:如果客户端一定时间内没有操作,则踢客户端下线。
- /**
- * @author 9082046**@qq.com
- *
- */
- 方案一、
- 在启动时设置:
- IServer srv = new Server(Port, IHandler);
- srv.setConnectionTimeoutMillis(Time_1_ms);// 设置最大连接时间。
- srv.setIdleTimeoutMillis(Time_2_ms);// 设置最大空闲时间。
- 方案二、
- 在接受到连接时 和 在接受到数据时设置:
- public class XSocketHandler implements IDataHandler ,IConnectHandler ,IIdleTimeoutHandler ,IConnectionTimeoutHandler,IDisconnectHandler
- {
- public boolean onConnect(INonBlockingConnection nbc) throws IOException,
- BufferUnderflowException, MaxReadSizeExceededException
- {
- nbc.setConnectionTimeoutMillis(Time_1_ms);// 为什么写两次、写两种函数? 目的: 1、举例函数的用法。 2、配合onData() 一定程度上阻止恶意客户端,如果在一定时间内通不过登录验证则会被超时处理。
- nbc.setIdleTimeoutMillis(Time_2_ms);
- return true;
- }
- public boolean onDisconnect(INonBlockingConnection nbc) throws IOException
- {
- return false;
- }
- public boolean onData(INonBlockingConnection nbc) throws IOException,
- BufferUnderflowException, ClosedChannelException,
- MaxReadSizeExceededException
- {
nbc.setConnectionTimeoutMillis(Time_1_ms);
nbc.setIdleTimeoutMillis(Time_2_ms);- return true;
- }
- public boolean onIdleTimeout(INonBlockingConnection nbc) throws IOException
- {
- return true;
- }
- public boolean onConnectionTimeout(INonBlockingConnection nbc) throws IOException
- {
- return true;
- }
- }
个人注:xsocket的最大空闲时间 和 个人原始理解存在差异,个人原始理解:从最后一次接收到client的数据开始计时, 实际XSocket的定义:从最后一次被使用开始计时,无论是接收到数据 或者 被用来发送数据。
如果实际需求中是要求:从客户端最后一次发送数据开始计时,则推荐 在XSocketHandler类中的 IHandler的实现化中使用 setConnectionTimeoutMillis() 方法。
反面举例:世界聊天会使用socket发送数据影响 setIdleTimeoutMillis() 。
如有考虑不周,请指正,请轻喷。欢迎大家留言。
xsocket:空闲超时问题。的更多相关文章
- 新功能:Azure 负载平衡器的空闲超时现可配置了
Yves Pitsch Azure 网络首席项目经理 我们很高兴地宣布,Azure负载平衡器现在可以为云服务和虚拟机提供可配置的 TCP空闲超时支持.要配置此功能,可以使用服务管理 API.Power ...
- MySQL:参数wait_timeout和interactive_timeout以及空闲超时的实现【转】
一.参数意思 这里简单解释一下两个参数,含义如下: interactive_timeout:The number of seconds the server waits for activity on ...
- windows 空闲超时 非管理员如何破解
windows 空闲超时 非管理员如何破解
- 解决IIS应用程序池DefaultAppPool关闭超时错误
错误系统日志: 为应用程序池“DefaultAppPool”提供服务的进程关闭时间超过了限制.进程 ID 是“3060”. 有关更多信息,请参阅在http://go.microsoft.com/fwl ...
- MySQL超时配置
connect_timeout:连接响应超时时间.服务器端在这个时间内如未连接成功,则会返回连接失败. wait_timeout:连接空闲超时时间.与服务器端无交互状态的连接,直到被服务器端强制关闭而 ...
- mysql里几个超时配置参数wait_timeout,net_read_timeout等
以下这些配置项单位都是秒,在mysql命令行中可以使用show global variables like '变量名';可查询配置值. connect_timeout:连接响应超时时间.服务器端在这个 ...
- LVS持久化与超时时间问题分析
前言 在上一篇文章<搭建DNS+LVS(keepAlived)+OpenResty服务器(Docker环境)>中,我搭建了dns+lvs+openresty+web集群:先来回顾一下架构图 ...
- mysql 连接超时的问题
项目中用mycat做的分表分库,异步通知系统会连接mycat去查数据库数据,有时会抛异常提示mysql server has gone away.最初以为是mycat的问题,在修改了mycat的配置, ...
- IIS进程回收 空闲时Net线程未运行
最近手上的项目,用的是asp.net mvc,后台有个线程在循环接收socket数据,本身在系统运行的时候访问页面没问题,但是发现没访问时,后台没有接收数据,后来知道了是IIS把线程回收了.解决方法如 ...
随机推荐
- 对象 get和set方法
1.用途 用户定义的对象定义 getter 和 setter 以支持新增的属性. 示例:obj创建一个伪属性latest,它会返回log数组的最后一个元素. var obj = { log: ['ex ...
- Hibernate持久化对象的状态
1. 站在持久化的角度 , Hibernate 把对象分为 4 种状态 : 持久化状态, 暂时状态, 游离状态(脱管状态) , 删除状态.Session 的特定方法能使对象从一个状态转换到还有一个状态 ...
- 【划分树+二分】HDU 4417 Super Mario
第一次 耍划分树.. . 模板是找第k小的 #include <stdio.h> #include <string.h> #include <stdlib.h> # ...
- 便捷的 chrome/Firefox扩展
chrome: 1.Postman-REST Client 模拟发送post/get请求测试接口很好用 2.Edit This Cookie 管理cookie 3.json-handle / jso ...
- spring boot 在什么时候启动的tomcat
我一直很好奇 spring boot 以哪种方式 启动的 tomcat 今天 特地跟踪了一下 大家都知道 spring 容器很核心的 方式 是org.springframework.context. ...
- firefox浏览器批处理插件imacros
http://www.360doc.com/content/14/1012/19/4360822_416372016.shtml javascript部分 var code = "CODE: ...
- LIntcode---将二叉搜索树转成较大的树
Given a Binary Search Tree (BST), convert it to a Greater Tree such that every key of the original B ...
- django 官方文档下载
今天发现自己的django文档有点过时了,于是想去下载一份新,找了老半天才找到pdf的下载地址:于是把它记录下来,希望以后可以直接用. 一.进行django官方网站: 二.文档的pdf文件就在docu ...
- 编译安装PHP7并安装Redis扩展Swoole扩展(未实验)
用PECL自动安装Redis扩展.Swoole扩展 pecl install redis pecl install swool 编译安装PHP7并安装Redis扩展Swoole扩展 在编译php7的机 ...
- Oracle 10g 数据库的备份和还原
一.备份数据库 1.在图形工具中,如sqldeveloper,pl/sqldeveloper用以下这句查找空表 select 'alter table '||table_name||' allocat ...