关于B/S判断浏览器断开的问题讨论


Posted in Javascript onOctober 29, 2008

客户端通过脚本和服务器保持请求,每次请求刷新一个时间,服务器检查这个时间,如果发现时间超过预定,则可以判断该客户端浏览器已关闭。然后对进行相应得操作。如果你想知道是那个客户端浏览器关闭,可以把会话绑定到轮询对象中。长连接不是所有服务器都支持得,这种方式,比你的现实多了。
我的个人看法。
我首先同意这几种做法
,它们也能实现这个需求,他们都通过客户端的轮询,更新服务器的最后访问时间,让服务器检测超时。我来谈谈我对这2种做法的理解

1 服务器端如何进行超时判断,启动一个后台线程进行定时轮询?循环检查每个session是否超过了间隔?
2 如果用线程,那么服务器端判断的间隔或者周期是多少,1秒,10秒,20秒..
3 如果大家都用10秒间隔,客户也能承受这个间隔,我们来看结果
  1) 我还不知道哪个服务器不支持长连接,如果你下载100G的文件,难道不行吗?中间非得断开n次?
  2) 你的每个客户端需要在10秒之内,发出新的请求,让服务器进行响应,我的则不需要
  3) 轮询操作要注意并发问题,也就是同步访问问题,你的数据得保存在application或者其它自定义全局数据结构里面,而多线程不存在这个问题
  4) 轮询属于单线程,统一处理,而长连接为多线程
  5) 客户端每次请求刷新后断开连接,可以减少占用服务器的连接数,提高并发数,但相对增加了每次请求的负担。
4 关键区别:如果要求在0.1秒内必须做出精确反应,发现连接断开要马上进行处理,我想我的多线程方案会更有效,因为浏览器很难在那么短的时间内发出10次请求的。而长连接则只需要减少发送数据的间隔就可以。

 

总结:
需求决定应用。
系统要求的判断超时的时间越短,长连接的方案优势越大,时间越长,轮询的可用性越强。具体需要根据应用做抉择。
对于一般的B/S判断,大部分聊天室和在线人数统计都是临行轮询操作的。一个人离开聊天室,不会立即更新在线列表,但IM程序(QQ/MSN)等则会相对非常精确的更新。

如果需要精确判断,我想长连接是我能想到的解决方案之一;另一个就是客户端插件,比如applet,Flash,ActiveX等使用socket进行了,不过机制和长连接没有区别。
两点小建议

1。 做到0.1反应可以,但做到0.1秒“精确”反应不行。TCP协议虽然是长连接,但没规定CS中一端掉线时,另一端迅速可知(否则也不会有后来TCP不太标准的“心跳”协议),这关乎中间网络硬件的支持。现实中也是如此。 当然,我不知道版主这篇文章的可能还有上文,所以不知这系统准备运行在什么网上。

2。 文章既然提到“前面页面”。看来这个系统就不应该是QQ或游戏服务器了,后台很可能就是运行一个普通的WEB服务器,IIS或APACHE。。它们的设计目标明确,所以都会有最大连接数限制。表面上,数千人同时在线,没关系,由于采用短连接,同一时间的并发数通常够用。但如果就算客户不活动,连接也要保持,那这个数目就很快有个死限了。
就算游戏或IM工具,典型如QQ,也不敢用TCP来长连接服务器。

所以我的总结是,如果准备做一个最多就1,2百人左右同时上线(而不是同时活动),那可以采用楼主的方法。如果人数一涨,则包括flash, activeX, socket ...统统不可能用长连接,宁可用UDP去碰。

Javascript 相关文章推荐
轻轻松松学习JavaScript
Feb 25 Javascript
JavaScript 判断日期格式是否正确的实现代码
Jul 04 Javascript
js中如何把字符串转化为对象、数组示例代码
Jul 17 Javascript
jquery表单对象属性过滤选择器实例分析
May 18 Javascript
js定时器实例分享
Dec 20 Javascript
浅谈Express异步进化史
Sep 09 Javascript
移动端网页开发调试神器Eruda的介绍与使用技巧
Oct 30 Javascript
Node.js中sequelize时区的配置方法
Dec 10 Javascript
Angular实现的自定义模糊查询、排序及三角箭头标注功能示例
Dec 28 Javascript
Vue 实现手动刷新组件的方法
Feb 19 Javascript
如何实现双向绑定mvvm的原理实现
May 28 Javascript
微信小程序实现树莓派(raspberry pi)小车控制
Feb 12 Javascript
JS写的数字拼图小游戏代码[学习参考]
Oct 29 #Javascript
JavaScript函数、方法、对象代码
Oct 29 #Javascript
js身份证验证超强脚本
Oct 26 #Javascript
javascript引导程序
Oct 26 #Javascript
javascript笔试题目附答案@20081025_jb51.net
Oct 26 #Javascript
Div自动滚动到末尾的代码
Oct 26 #Javascript
Firefox getBoxObjectFor getBoundingClientRect联系
Oct 26 #Javascript
You might like
萌王史莱姆”萌王性别尴尬!那“萌战”归女组还是男?
2018/12/17 日漫
Zend 输出产生XML解析错误
2009/03/03 PHP
『PHP』PHP截断函数mb_substr()使用介绍
2013/04/22 PHP
php采集文章中的图片获取替换到本地(实现代码)
2013/07/08 PHP
php上传功能集后缀名判断和随机命名(强力推荐)
2015/09/10 PHP
详解WordPress中过滤链接与过滤SQL语句的方法
2015/12/18 PHP
jquery图片不完全按比例自动缩小的简单代码
2013/07/29 Javascript
详细分析JavaScript变量类型
2015/07/08 Javascript
JS+CSS实现仿支付宝菜单选中效果代码
2015/09/25 Javascript
JS代码实现根据时间变换页面背景效果
2016/06/16 Javascript
nodejs基础应用
2017/02/03 NodeJs
JavaScript实现的鼠标响应颜色渐变效果完整实例
2017/02/18 Javascript
javascript checkbox/radio onchange不能兼容ie8处理办法
2017/06/13 Javascript
JS+canvas动态绘制饼图的方法示例
2017/09/12 Javascript
Angular实现下拉框模糊查询功能示例
2018/01/03 Javascript
js变量值传到php过程详解 将php解析成数据
2019/06/26 Javascript
js canvas实现5张图片合成一张图片
2019/07/15 Javascript
Vue-cli3项目引入Typescript的实现方法
2019/10/18 Javascript
在vue中实现清除echarts上次保留的数据(亲测有效)
2020/09/09 Javascript
vant 中van-list的用法说明
2020/11/11 Javascript
Js利用正则表达式去除字符串的中括号
2020/11/23 Javascript
python简单读取大文件的方法
2016/07/01 Python
python安装Scrapy图文教程
2017/08/14 Python
Python 多线程的实例详解
2017/09/07 Python
基于Python中单例模式的几种实现方式及优化详解
2018/01/09 Python
keras的backend 设置 tensorflow,theano操作
2020/06/30 Python
优衣库英国官网:UNIQLO英国
2016/12/25 全球购物
南京某公司笔试题
2013/01/27 面试题
机电工程专业应届生求职信
2013/10/03 职场文书
魅力教师事迹材料
2014/01/10 职场文书
大学生水果店创业计划书
2014/01/28 职场文书
个人批评与自我批评总结
2014/10/17 职场文书
2014年度个人工作总结范文
2015/03/09 职场文书
2015个人简历自我评价语
2015/03/11 职场文书
婚宴主持词
2015/06/30 职场文书
javascript数组includes、reduce的基本使用
2021/07/02 Javascript