关于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获取onclick、onchange等事件值的代码
Jul 22 Javascript
JavaScript中的prototype.bind()方法介绍
Apr 04 Javascript
js对象的复制继承实例
Jan 10 Javascript
javascript图片滑动效果实现
Jan 28 Javascript
JS模拟bootstrap下拉菜单效果实例
Jun 17 Javascript
BootStrap中的表单大全
Sep 07 Javascript
JS比较两个数值的大小实例
Nov 25 Javascript
JavaScript制作简易计算器(不用eval)
Feb 05 Javascript
jQuery中hover方法搭配css的hover选择器,实现选中元素突出显示方法
May 08 jQuery
JavaScript实现短信倒计时60s
Oct 09 Javascript
微信小程序 搜索框组件代码实例
Sep 06 Javascript
javascript实现贪吃蛇游戏(娱乐版)
Aug 17 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
php发送get、post请求的6种方法简明总结
2014/07/08 PHP
PHP中使用json数据格式定义字面量对象的方法
2014/08/20 PHP
Yii分页用法实例详解
2014/12/04 PHP
php探针不显示内存解决方法
2019/09/17 PHP
javascript拓展DOM操作 prependChild insertAfert
2010/11/17 Javascript
JavaScript通过正则表达式实现表单验证电话号码
2014/03/07 Javascript
JS实现倒计时和文字滚动的效果实例
2014/10/29 Javascript
jQuery实现的指纹扫描效果实例(附演示与demo源码下载)
2016/01/26 Javascript
javascript原生ajax写法分享
2016/04/10 Javascript
javascript正则表达式之分组概念与用法实例
2016/06/16 Javascript
JS中append字符串包含onclick无效传递参数失败的解决方案
2016/12/26 Javascript
js实现简单的计算器功能
2017/01/16 Javascript
JavaScript日期选择功能示例
2017/01/16 Javascript
vue2.0数据双向绑定与表单bootstrap+vue组件
2017/02/27 Javascript
AngularJS1.X学习笔记2-数据绑定详解
2017/04/01 Javascript
如何实现js拖拽效果及原理解析
2020/05/08 Javascript
如何利用Node.js与JSON搭建简单的动态服务器
2020/06/16 Javascript
Python实现多线程抓取妹子图
2015/08/08 Python
python实现批量注册网站用户的示例
2019/02/22 Python
详解django2中关于时间处理策略
2019/03/06 Python
Python内存管理实例分析
2019/07/10 Python
python爬虫 urllib模块发起post请求过程解析
2019/08/20 Python
如何关掉pycharm中的python console(图解)
2019/10/31 Python
Python中BeautifuSoup库的用法使用详解
2019/11/15 Python
详解pycharm配置python解释器的问题
2020/10/15 Python
Python3 用什么IDE开发工具比较好
2020/11/28 Python
巴西最大的家具及装饰用品店:Mobly
2017/10/11 全球购物
Topshop法国官网:英国快速时尚品牌
2018/04/08 全球购物
ECCO英国官网:丹麦鞋履品牌
2019/09/03 全球购物
Nixon手表英国官网:美国尼克松手表品牌
2020/02/10 全球购物
网上卖盒饭创业计划书范文
2014/02/07 职场文书
省文明单位申报材料
2014/05/08 职场文书
运动会演讲稿200字
2014/08/25 职场文书
科技活动周标语
2014/10/08 职场文书
2014年小学安全工作总结
2014/12/04 职场文书
JavaScript parseInt0.0000005打印5原理解析
2022/07/23 Javascript