使用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正是依靠这种“等待,断开,继续等待”,实现的长连接