关于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 相关文章推荐
用js+xml自动生成表格的东西
Dec 21 Javascript
jquery 模板的应用示例
Nov 12 Javascript
用jquery模仿的a的title属性的例子
Oct 22 Javascript
高性能JavaScript模板引擎实现原理详解
Feb 05 Javascript
js实现时间轴自动排列效果
Mar 09 Javascript
JavaScript实现短信倒计时60s
Oct 09 Javascript
详解webpack require.ensure与require AMD的区别
Dec 13 Javascript
在 Vue.js中优雅地使用全局事件的方法
Feb 01 Javascript
快速了解Node中的Stream流是什么
Feb 13 Javascript
layui 上传文件_批量导入数据UI的方法
Sep 23 Javascript
JS回调函数深入理解
Oct 16 Javascript
vue3.0 项目搭建和使用流程
Mar 04 Vue.js
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
用PHP ob_start()控制浏览器cache、生成html实现代码
2010/02/16 PHP
PHP读取ACCESS数据到MYSQL的代码
2011/05/11 PHP
ThinkPHP连接Oracle数据库
2016/04/22 PHP
浅谈mysql_query()函数的返回值问题
2016/09/05 PHP
php中10个不同等级压缩优化图片操作示例
2016/11/14 PHP
php面向对象程序设计中self与static的区别分析
2019/05/21 PHP
Prototype中dom对象方法汇总
2008/09/17 Javascript
ASP.NET jQuery 实例8 (动态添加内容到DropDownList)
2012/02/03 Javascript
IE、FF、Chrome浏览器中的JS差异介绍
2013/08/13 Javascript
Javascript编程中几种继承方式比较分析
2015/11/28 Javascript
JavaScript Date对象详解
2016/03/01 Javascript
如何检测JavaScript的各种类型
2016/07/30 Javascript
解决layui数据表格Date日期格式的回显Object的问题
2019/09/19 Javascript
微信小程序实现上传多张图片、删除图片
2020/07/29 Javascript
[15:20]DOTA2亚洲邀请赛总决赛开幕式表演:羽泉献唱
2017/04/05 DOTA
使用python调用zxing库生成二维码图片详解
2017/01/10 Python
利用Python进行数据可视化常见的9种方法!超实用!
2018/07/11 Python
python使用webdriver爬取微信公众号
2018/08/31 Python
Ubuntu18.04中Python2.7与Python3.6环境切换
2019/06/14 Python
在Python 的线程中运行协程的方法
2020/02/24 Python
Django单元测试中Fixtures的使用方法
2020/02/26 Python
python的json包位置及用法总结
2020/06/21 Python
给Django Admin添加验证码和多次登录尝试限制的实现
2020/07/26 Python
Python 爬取淘宝商品信息栏目的实现
2021/02/06 Python
html5使用canvas画一条线
2014/12/15 HTML / CSS
一封普通求职者的求职信
2013/11/20 职场文书
大学四年个人的自我评价
2014/02/26 职场文书
建筑安全员岗位职责
2014/03/13 职场文书
2014世界杯球队球队口号
2014/06/05 职场文书
2014年学生资助工作总结
2014/12/18 职场文书
银行优秀员工推荐信
2015/03/24 职场文书
2015年发展党员工作总结报告
2015/03/31 职场文书
2015大学生暑期实习报告
2015/07/13 职场文书
HTML页面滚动时部分内容位置固定不滚动的实现
2021/04/14 HTML / CSS
python基础之类方法和静态方法
2021/10/24 Python
Python FuzzyWuzzy实现模糊匹配
2022/04/28 Python