当前位置:首页 > H5 > 正文内容

高效服务器发送事件,服务器发送事件,服务器发送事件和长轮询的区别

高老师7年前 (2018-05-27)H52246

HTML5 服务器发送事件(server-sent event)允许网页获得来自服务器的更新。通过官网的介绍可以看出是接收服务器发送数据,千万不能和ajax混淆,网上大片博文的介绍对其解读是错误的,导致让我差点觉得这个事件很鸡肋。

先看通用案例:

html5:

<script type="text/javascript">
if(typeof(EventSource)!=="undefined") 
{ 
	//浏览器支持
	var api = 'server.php';
	var source=new EventSource(api);
	source.onmessage=function(event)
	{
	    console.log(event.data)
	};
} 
else 
{ 
	//浏览器不支持 
}			
</script>

php:

<?php
header('Content-Type: text/event-stream'); 
header('Cache-Control: no-cache'); 

$time = date('Y-m-d H:i'); 
echo "data: The server time is: {$time}\n\n"; 
flush();

上面是根据w3c的代码修改的,通过谷歌调试发现每隔3秒还是会请求1次,天呐,w3c官网是不是搞错了.如果是这样的话我还不如选择ajax,写起来不是更爽?于是继续找,发现网上一堆重复的请求博文很头疼,最后终于在mozilla发现原来可以阻塞,于是有了下面的高效案例。

再看高效案例:

php:

<?php
header('Content-Type: text/event-stream');
header('Cache-Control: no-cache');
while (1) 
{
 $time = date('Y-m-d H:i:s');
 echo "data: The server time is: {$time}\n\n";
 ob_flush();
 flush();
 sleep(1);
}

以上代码通过阻塞可以达到约30s请求一次,数据是每隔1秒发送1次,但是考虑一般用户在页面停留时长肯定能达到30s的,于是有了下面的代码

php:

<?php
ini_set('max_execution_time', '0');
header('Content-Type: text/event-stream');
header('Cache-Control: no-cache');
while (1) 
{
 $time = date('Y-m-d H:i:s');
 echo "data: The server time is: {$time}\n\n";
 ob_flush();
 flush();
 sleep(1);
}

以上代码通过限制脚本执行时间,可以达到7分钟请求脚本1次,7分钟自动请求1次,并且这7分钟都是每秒推送,已经非常高效

超时问题延伸:

通常情况下,php设置不超时,但是web服务器本身是不可能等待php那么久的,会直接抛出超时,但是实际上php脚本还是在默默无闻的跑着。

但是为什么上面的脚本不会直接抛出超时,个人猜测或许是apache和nginx对于Content-Type: text/event-stream类型的都不会直接超时。另外再想想文件流的传输过程貌似web服务器也不会说传输中断的问题。

扫描二维码推送至手机访问。

版权声明:本文由高久峰个人博客发布,如需转载请注明出处。

本文链接:https://blog.20230611.cn/post/266.html

分享给朋友:

“高效服务器发送事件,服务器发送事件,服务器发送事件和长轮询的区别” 的相关文章

 js图片旋转插件jqueryrotate

js图片旋转插件jqueryrotate

jQuery 插件——jqueryrotate,它可以实现旋转效果。jqueryrotate 支持所有主流浏览器,包括 IE6。如果提示方法不存在,可能是你的Jquery版本过低或者过高。基本语法:$('#img').rotate(90);//旋转90度其他的参数:参数类型说明默认值...

 js构造函数

js构造函数

工厂模式虽然解决了创建多个对象的问题,但是并没有解决识别对象从属的问题.因为都属于object.因此出现了构造函数//构造函数名称首字母大写是规范 function Box(name,age){ this.name=name; this.age=age; this.run=funct...

javascript使用原型为内置对象增加方法

javascript使用原型为内置对象增加方法

//字面量的形式创建原型对象 /* function Box(){} Box.prototype={ 'name':'gao', age:23, fun:function(){ return this.name+'--'+...

js原型对象的缺点,js原型链及其优缺点

js原型对象的缺点,js原型链及其优缺点

//原型的缺点 function Box(){} Box.prototype={ 'name':'gao',  age:23,  family:['哥哥','姐姐','妹妹'], &...

setTimeout在循环执行顺序的思考

setTimeout在循环执行顺序的思考

朋友面试时候遇到的问题,我天真的认为会输出0,1,2,但是实际一直只输出2,2,2。通过了解才执行Js自身是单线程的环境,for循环本身是同步代码,setTimeout是异步代码。单线程的语言不能同时做2件事情,必须做出选择。于是Js引擎决定了当我执行完成同步的代码,再去执行异步的代码。当执行异步的...