关于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 关键字屏蔽实现函数
Aug 02 Javascript
node.js中的fs.appendFile方法使用说明
Dec 17 Javascript
跟我学习javascript的prototype原型和原型链
Nov 18 Javascript
你不需要jQuery(三) 新AJAX方法fetch()
Jun 14 Javascript
JS实现显示带倒影的图片横排居中放大展示特效实例【测试可用】
Aug 23 Javascript
jQuery手指滑动轮播效果
Dec 22 Javascript
基于JS代码实现简单易用的倒计时 x 天 x 时 x 分 x 秒效果
Jul 13 Javascript
React复制到剪贴板的示例代码
Aug 22 Javascript
EasyUI Tree树组件无限循环的解决方法
Sep 27 Javascript
gulp安装以及打包合并的方法教程
Nov 19 Javascript
JS实现的哈夫曼编码示例【原始版与修改版】
Apr 22 Javascript
JavaScript分页组件使用方法详解
Jul 26 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 和 MySQL 基础教程(四)
2006/10/09 PHP
PHP架构及原理知识点详解
2019/12/22 PHP
JQuery 将元素显示在屏幕的中央的代码
2010/02/27 Javascript
document.forms[].submit()使用介绍
2014/02/19 Javascript
jquery中的常用事件bind、hover、toggle等示例介绍
2014/07/21 Javascript
JavaScript如何自定义trim方法
2015/07/28 Javascript
js获取上传文件的绝对路径实现方法
2016/08/02 Javascript
JS如何设置cookie有效期为当天24点并弹出欢迎登陆界面
2016/08/04 Javascript
html、css和jquery相结合实现简单的进度条效果实例代码
2016/10/24 Javascript
不使用 JS 匿名函数理由
2017/11/17 Javascript
ReactNative之FlatList的具体使用方法
2017/11/29 Javascript
Vue项目webpack打包部署到Tomcat刷新报404错误问题的解决方案
2018/05/15 Javascript
js数组去重的N种方法(小结)
2018/06/07 Javascript
微信小程序地图导航功能实现完整源代码附效果图(推荐)
2019/04/28 Javascript
JS字符串与二进制的相互转化实例代码详解
2019/06/28 Javascript
vue@cli3项目模板怎么使用public目录下的静态文件
2020/07/07 Javascript
浅谈JavaScript中的“!!”作用
2020/08/03 Javascript
[46:44]VG vs TNC Supermajor小组赛B组败者组决赛 BO3 第一场 6.2
2018/06/03 DOTA
python使用pil生成缩略图的方法
2015/03/26 Python
django实现分页的方法
2015/05/26 Python
不可错过的十本Python好书
2017/07/06 Python
python爬虫 使用真实浏览器打开网页的两种方法总结
2018/04/21 Python
利用Python如何生成便签图片详解
2018/07/09 Python
django框架自定义用户表操作示例
2018/08/07 Python
浅谈Python 列表字典赋值的陷阱
2019/01/20 Python
解决python 上传图片限制格式问题
2019/10/30 Python
一文了解python 3 字符串格式化 F-string 用法
2020/03/04 Python
部署Django到阿里云服务器教程示例
2020/06/03 Python
从python读取sql的实例方法
2020/07/21 Python
纯css3实现照片墙效果
2014/12/26 HTML / CSS
【HTML5】Canvas绘制简单图片教程
2016/05/13 HTML / CSS
家乐福巴西网上超市:Carrefour巴西
2016/10/31 全球购物
String这个类型的class为何定义成final?
2012/11/13 面试题
大学新闻系应届生求职信
2014/06/02 职场文书
关于艺术节的开幕致辞
2016/03/04 职场文书
python区块链持久化和命令行接口实现简版
2022/05/25 Python