关于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 相关文章推荐
最新优化收藏到网摘代码(digg,diigo)
Feb 07 Javascript
setTimeout与setInterval在不同浏览器下的差异
Jan 24 Javascript
HTML页面滚动时获取离页面顶部的距离2种实现方法
Sep 05 Javascript
回车直接实现点击某按钮的效果即触发单击事件
Feb 27 Javascript
JS判断客服QQ号在线还是离线状态的方法
Jan 13 Javascript
jquery衣服颜色选取插件效果代码分享
Aug 28 Javascript
设置点击文本框或图片弹出日历控件的实现代码
May 12 Javascript
完美实现js焦点轮播效果(二)(图片可滚动)
Mar 07 Javascript
完美实现js选项卡切换效果(一)
Mar 08 Javascript
老生常谈js-react组件生命周期
May 02 Javascript
vue 实现类似淘宝星级评分的示例
Mar 01 Javascript
Vuex的热更替如何实现
Jun 05 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定时更新程序设计思路分享
2014/06/10 PHP
php处理抢购类功能的高并发请求
2018/02/08 PHP
给Javascript数组插入一条记录的代码
2007/08/30 Javascript
JS 类型转换常见方法小结
2010/05/31 Javascript
js getBoundingClientRect() 来获取页面元素的位置
2010/11/25 Javascript
jquery学习笔记 用jquery实现无刷新登录
2011/08/08 Javascript
javaScript使用EL表达式的几种方式
2014/05/27 Javascript
php利用curl获取远程图片实现方法
2015/10/26 Javascript
基于jquery实现智能表单验证操作
2016/05/09 Javascript
ES6通过babel转码使用webpack使用import关键字
2016/12/13 Javascript
vue bootstrap小例子一枚
2017/06/09 Javascript
vue事件修饰符和按键修饰符用法总结
2017/07/25 Javascript
Vue.js仿微信聊天窗口展示组件功能
2017/08/11 Javascript
jQuery事件对象的属性和方法详解
2017/09/09 jQuery
Node.js 多进程处理CPU密集任务的实现
2019/05/26 Javascript
JavaScript定时器使用方法详解
2020/03/26 Javascript
Angular8 简单表单验证的实现示例
2020/06/03 Javascript
在vue中给后台接口传的值为数组的格式代码
2020/11/12 Javascript
python抓取百度首页的方法
2015/05/19 Python
Python利用ElementTree模块处理XML的方法详解
2017/08/31 Python
基于python中的TCP及UDP(详解)
2017/11/06 Python
python去重,一个由dict组成的list的去重示例
2019/01/21 Python
python求最大值最小值方法总结
2019/06/25 Python
基于Python绘制美观动态圆环图、饼图
2020/06/03 Python
opencv 形态学变换(开运算,闭运算,梯度运算)
2020/07/07 Python
Python3爬虫中关于中文分词的详解
2020/07/29 Python
使用CSS3的ruby-position固定注音位置的用法示例
2016/07/05 HTML / CSS
利用HTML5绘制点线面组成的3D图形的示例
2015/05/12 HTML / CSS
L’AGENCE官网:加州女装品牌
2018/06/03 全球购物
娱乐地球:Entertainment Earth
2020/01/08 全球购物
Set里的元素是不能重复的,那么用什么方法来区分重复与否呢? 是用==还是equals()? 它们有何区别?用contains来区分是否有重复的对象。还是都不用
2013/07/30 面试题
一个C/C++编程面试题
2013/11/10 面试题
应届生的求职推荐信范文
2013/11/30 职场文书
七年级历史教学反思
2014/02/05 职场文书
Redis的字符串是如何实现的
2021/10/24 Redis
javascript条件式访问属性和箭头函数介绍
2021/11/17 Javascript