`
奔跑的羚羊
  • 浏览: 576230 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

答复: [译]Nginx & Comet:低延迟信息推送

阅读更多

使用curl快速测试

 

新建一个订阅者

打开一个终端访问subscribe

curl -X GET http://localhost:8082/activity?id=0 

可以看到HTTP请求被阻塞

 

发布消息
打开另一个终端访问publish

curl -X POST http://localhost:8082/publish?id=0 -d "hello world"

 


订阅者收到消息
此时subscriber就可以收到字符串“Hello World”,完成HTTP请求。

curl -X GET http://localhost:8082/activity?id=0 

 

 

一个简单测试就完成了。

通过这个例子,我们可以看出,如果订阅者没有收到消息,会被阻塞,直到发布者发布消息。当订阅者收到消息后,会立即断开。

 

 

再一起来看一下http header中信息

curl -X GET http://localhost:8082/activity?id=0 -verbose 

 这是终端会显示:

 

# curl -X GET http://localhost:8082/activity?id=0 -verbose
* About to connect() to localhost port 8082
*   Trying 127.0.0.1... * connected
* Connected to localhost (127.0.0.1) port 8082
> GET /activity?id=0 HTTP/1.1
User-Agent: curl/7.12.1 (i386-redhat-linux-gnu) libcurl/7.12.1 OpenSSL/0.9.7a zlib/1.2.2 libidn/0.5.6
Host: localhost:8082
Pragma: no-cache
Accept: */*
Referer: rbose

< HTTP/1.1 200 OK
< Server: nginx/0.8.31
< Date: Thu, 07 Jan 2010 08:37:12 GMT
< Content-Length: 33
< Last-Modified: Thu, 07 Jan 2010 08:37:10 GMT
< Connection: keep-alive
< Etag: 0
< Vary: If-None-Match, If-Modified-Since
* Connection #0 to host localhost left intact
* Closing connection #0
Hello world

 

从响应的头部可以看到Last-Modified: Thu, 07 Jan 2010 08:37:10 GMT

这个就是发布者(publisher)上一次发布(publish)的时间
可以通过发送If-Modified-Since来获取指定时间之后的数据 

curl -X GET -H "If-Modified-Since:Thu, 07 Jan 2010 08:37:10 GMT" http://localhost:8082/activity?id=0 –verbose

这时subscribe会重新被阻塞而不是接收下次publish的数据

 

 

到此,可以清晰的看出,nginx的push正是依靠这种“等待,断开,继续等待”,实现的长连接

分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics