NGiNX_HTTP_Push_Module 是一个 Nginx 的扩展模块,它实现了 HTTP Push 和Comet server的功能。HTTP Push 被经常用在网页上主动推的技术,例如一些聊天室啊,更新信息非常频繁的应用场合。

Http Server Push是一种推送技术,服务器主动向浏览器发送数据。

可以参考:http://wiki.nginx.org/HttpPushStreamModule

1. 下载安装

1) 下载源代码包
Nginx:http://nginx.org/
Nginx Http Push Module:http://pushmodule.slact.net/(网站打不开)csdn上有一份http://download.csdn.net/download/javadxz/10046650

2) 解压缩
tar zxvf nginx-1.12.2.tar.gz
tar zxvf nginx_http_push_module-0.692.tar.gz

3) 编译安装

进入nginx根目录

编译Nginx,configure指定待添加模块的路径

./configure --add-module=/home/nginx/nginx_http_push_module-0.692
 make && make install

错误提示:
./configure: error: the HTTP rewrite module requires the PCRE library. 安装pcre-devel与openssl-devel解决问题
yum install gcc gcc-c++ openssl_devel -y
yum -y install pcre-devel openssl openssl-devel
./configure --prefix=/usr/local/nginx

2. 配置

关于推送配置说明,可参考推送模块源码包内的README,

推送协议可参考protocol.txt,或访问http://pushmodule.slact.net/protocol.html

在Nginx配置文件中添加一个基本的推送配置,

可参考自带的用于测试的配置文件nginx_http_push_module-0.692/tests/nginx.conf,将其中配置部分附加到Nginx配置文件的http结构中(安装后nginx启动默认读取的文件是/usr/local/nginx/conf/nginx.conf)

        location /chat {
push_channel_group pushmodule_chat;
location /chat/pub {
set $push_channel_id $arg_id; #多个聊天室就相当于 ?id=markdream
push_publisher;
push_message_timeout 5m;
push_message_buffer_length 10;
}
location /chat/sub {
set $push_channel_id $arg_id; #多个聊天室就相当于 ?id=markdream
push_subscriber;
send_timeout 3600;
}
}

3. 调试

启动

./nginx

./nginx -s reload

./nginx -s stop

启动Nginx,使用curl进行推送测试

1) subscriber请求数据:
curl -X GET localhost:8082/chat/sub?id=1
向channel1请求数据,当前channel无数据,等待数据生成

2) publisher推送数据:
curl -X POST -d "china 2017-10-31" http://localhost:8082/chat/pub?id=1
向channel1推送数据,subscriber收到数据并返回

4. 总结

Http服务器需要使用一个或一组url指定发布服务和订阅服务(publisher and subscriber locations,我翻译的不太合理)。

所有发送到发布服务的请求被视为发布请求,所有发送到订阅服务的请求被视为订阅请求。

通道(channel)需要使用唯一id进行标识,推荐使用url指定具体通道,如 localhost:8082/sub?id=1。

发布请求(publisher request)通过POST向服务器传输数据,并通知其向某些通道某些用户发送数据,

订阅请求(subscriber request)通过GET向服务器请求数据,通知其该用户想要接收数据。

配置信息详解

变量:

$push_channel_id

作为唯一标识,区别通信通道,要通信的pub和sub这个值必须相同。

例如:

set $push_channel_id $arg_id; 
#channel id 就是当前url上的字符串变量"id"
#(/foo/bar?id=channel_id_string)

指令:

Publisher/Subscriber

push_subscriber[ long-poll | interval-poll ]

默认值:long-poll

位置:server,location

定义一个server或者location作为subscriber,这个代表一个sub与信息管道进行通信,通过entity-caching请求头(If-Modified-Since and If-None-Match)自动遍历列表,处理队列中保留时间最长的信息。

当有sub请求数据并且数据未到达时,sub端长轮训请求。如果是interval-poll方式,则会返回304码,返回最近接受的数据。

push_subscriber_concurrency[ last | first | broadcast ]

默认值:broadcast

使用环境:http,server,location

多用户请求时的控制处理,工作方式:

broadcast:广播形式接受,所有当前连接的用户请求被保存;

last:最近的用户请求被保存,其他用户全部409冲突;

first:最开始的用户请求被保存,其他全部409冲突;

push_publisher

默认值:none

使用环境:server,location

定义一个server或者location作为publisher,发给publisher的http请求被视为发送给subscribers的数据。

信息存储:

push_store_messages[ on | off ]

默认值:on

使用环境:http,server,location

当使用off时,仅表示push_message_buffer_length 0;

push_max_reserved_memory[ size ]

默认值:16M

使用环境:http

这个模块的内存块大小将会用于信息队列和信息缓存。

push_min_message_buffer_length[number ]

默认值:1

使用环境:http,server,location

每个channel的最小信息存储。

push_max_message_buffer_length[number ]

默认值:10

使用环境:http,server,location

每个channel的最大信息存储数。

push_message_buffer_length[ on |off ]

默认值:off

使用环境:http,server,location

每个channel存储的确切信息数

push_delete_oldest_received_message[off ]

默认值:0

使用环境:http,server,location

当启动时,一旦channel中最老的数据被用户接受后,它将被删除。所有超过push_max_message_buffer_length的信息将会在channel的信息缓存中。原作者建议避免使用改指令,因为它违背了用户get请求的幂等原则。

push_message_timeout[ time ]

默认值:1h

使用环境:http,server,location

作为消息在对立当中的过期时间,如果你不希望消息有过期时间,可以设置为0.

安全

push_authorized_channels_only[ on| off ]

默认值:off

使用环境:http,server,location

subscriber是否可以通过请求来创建一个channel。如果设置on,publisher必须在subscriber请求数据前,发送一个post或者put请求。否则所有的subscriber请求不存在的channels时,将会得到403码。

push_channel_group[ string ]

默认值:none

使用环境:server,location

作为一种约束,适用于发给指定channel,而其他channel将永远不会收到。就好像是channel id的前缀字符串。

push_max_channel_id_length[ number]

默认值:512

使用环境:main,server,location

设置最大的channel id长度,长的部分将会被截断,例如:

1.设置conf:

push_max_channel_id_length5;

2.输入连接:

http://192.168.0.237:2033/activity?id=lengzijian

3.更改perl脚本

4.查看页面

push_max_channel_subscribers[number ]

默认值:0(unlimited)

使用环境:main,server,location

最大并发subscriber数,你懂得!!!!

总结

最后附上用nginx_http_push_module实现的官方的聊天室:

聊天室下载地址:http://www.2zct.com/nginx/chat.zip

nginx配置信息下载地址:http://www.2zct.com/nginx/nginx_conf.zip

稍微做了改动,js+nginx实现,如果有任何问题,可以留言解答。

利用nginx_push_stream_module实现服务器消息推送的更多相关文章

  1. HTML5服务器消息推送(java版)

    前端代码(html5.html): <html> <meta http-equiv="Content-Type" content="text/html; ...

  2. SignalR SelfHost实时消息,集成到web中,实现服务器消息推送

    先前用过两次SignalR,但是中途有段时间没弄了,今天重新弄,发现已经忘得差不多了,做个笔记! 首先创建一个控制台项目Nuget添加引用联机搜索:Microsoft.AspNet.SignalR.S ...

  3. springboot实现服务器端消息推送(websocket + sockjs + stomp)

    服务器端推送技术在web开发中比较常用,可能早期很多人的解决方案是采用ajax向服务器轮询消息,这种方式的轮询频率不好控制,所以大大增加了服务器的压力,后来有了下面的方案:当客户端向服务器发送请求时, ...

  4. web消息推送的各种解决办法

    摘要 在各种BS架构的应用程序中,往往都希望服务端能够主动地向客户端推送各种消息,以达到类似于邮件.消息.待办事项等通知. 往BS架构本身存在的问题就是,服务器一直采用的是一问一答的机制.这就意味着如 ...

  5. Java Socket聊天室编程(一)之利用socket实现聊天之消息推送

    这篇文章主要介绍了Java Socket聊天室编程(一)之利用socket实现聊天之消息推送的相关资料,非常不错,具有参考借鉴价值,需要的朋友可以参考下 网上已经有很多利用socket实现聊天的例子了 ...

  6. javascript跨域传递消息 / 服务器实时推送总结

    参考文档,下面有转载[非常好的两篇文章]: http://www.cnblogs.com/loveis715/p/4592246.html [跨源的各种方法总结] http://kb.cnblogs. ...

  7. 利用Kafka的Assign模式实现超大群组(10万+)消息推送

    引言 IM即时通信场景下,最重要的一个能力就是推送:在线的直接通过长连接网关服务转发,离线的通过APNS或者极光等系统进行推送.   本文主要是针对在线用户推送场景来进行总结和探讨:如何利用Kafka ...

  8. 基于XMPP协议(openfire服务器)的消息推送实现

    转自:http://blog.csdn.net/nomousewch/article/details/8088277 最近好像有不少朋友关注Android客户端消息推送的实现,我在之前的项目中用到过J ...

  9. 用 centrifugo 搭建 消息推送服务器 docker + rancher 搭建

    关于消息推送服务器 目前有很多第三方的开放成熟的推送服务.鉴于项目需要 我们项目需要自己搭建 自己的推送服务. 我们的推送应用场景 聊天消息 项目内部消息提醒 移动设备接受消息 应用到的相关软件工具知 ...

随机推荐

  1. 团队项目:"Jarvis For Chat"

    "Jarvis For Chat"项目简介 项目详情信息已经在上一篇博客中详细给出,详请查看博客 团队成员 姓名 学号 张扬(队长) 031602345 苏韫月 031602631 ...

  2. 在IE中MVC控制器中返回JSON格式的数据时提示下载

    最近做项目时,视图中用jquery.form.js异步提交表单时,接收的是JSON格式的数据,但是奇怪的是在IE中提示下载文件,其他浏览器中一切正常,下载后,里面的内容就是在控制器中返回的数据.代码如 ...

  3. Vim技能修炼教程(6) - 行编辑器

    在很久很久以前,计算机的运算能力还很弱,终端与主机的通信也不好.在没有显示器的时代,只能通过电传打字机跟主机通信.那时候只有行编辑器,编辑的时候只能在一行中进行.需要显示哪一行,就把哪一行或者哪几行打 ...

  4. Vim技能修炼教程(2) - 语法高亮速成

    语法高亮速成 我们继续在人间修行Vim技能之旅.上一次我们学习了如何通过vundle安装插件,这次我们迅速向写插件的方向挺进. 我们先学习一个最简单的语法高亮插件的写法. 语法高亮基本上是由三部分组成 ...

  5. Python的安装与设置

    1.Python的下载与安装最新的python 版本下载可以去python的网站进行下载 . 考虑系统兼任这里下载32位的Python 双击下载的exe文件进行安装 单击Next 完成Python 安 ...

  6. 看完前任三,想起我的前任java女程序员,她曾教会我……

    前任三最近非常火了,票房蹭蹭往上升,昨天也去电影院看了,想起了我的前任,她是一名女程序员,为了让我学好java,她曾经亲自教我Java的算法,学算法是件非常重要的事,在这忍住回忆的悲伤,分享给你们. ...

  7. 【剑指offer12】矩阵中的路径(回朔法),C++实现

    1.题目 请设计一个函数,用来判断在一个矩阵中是否存在一条包含某字符串所有字符的路径.路径可以从矩阵中的任意一个格子开始,每一步可以在矩阵中向左,向右,向上,向下移动一个格子.如果一条路径经过了矩阵中 ...

  8. ubuntu下codeblock美化

    1.备份配置文件:default.conf. 2.将default.conf中的内容替换为最下面代码,并保存. 3.打开codeblock,Setting-Editor-Syntax,然后选择Colo ...

  9. Ubuntu Kylin14.04下PHP环境的搭建(LAMP)

    1.首先打开命令行,切换到root身份,获得最新的软件包 su root sudo apt-get install update 2.安装MySQL数据库 sudo apt-get install m ...

  10. Django项目部署(阿里云)(2)--扩展

    新博客地址:http://muker.net/django-server-two.html 前面的只是最简单的部署,真实情况总是更复杂一点实际流程大概是这么操作的(我这种菜鸟的想法):本地写代码-&g ...