构建Web后端使用Redis进行轮询(web轮训redis)

  随着面向web的网页的普及,如今的web开发者拥有越来越多的轮询技术可供选择。而随着Redis的技术不断发展,在维护web服务的轮询时,使用Redis来完成轮询也越来越多见。

  轮询是一种常用的后端设计技术,是客户端和服务器之间进行数据交换的最简单方式。它可以实现客户端套接字,从服务器中定期获取更新,以查看后台是否有任何新变化,用于实时发布。

  Redis可以用作轮询服务的后端,既可以完成服务端轮询任务,也可以实现客户端轮询任务,从而提供服务端推送或实时状态更新的完美支持。

  在web环境中,使用Redis的轮询技术,主要基于订阅发布(pub/sub)机制, developer 可以部署基于订阅发布的通信服务来完成轮询任务。下面我们从服务端了解如何实现基于Redis的轮询。

//服务端
//首先将订阅建立起来
sub = Redis.subscribe('new_event')
sub.subscribe do|on|
# 此处定义订阅收到的消息时的响应动作
on.message do |chan, msg|
#将某个事件的消息发送给客户端
send_message to :client_subscriber, msg
end
end

  服务端采用Redis的sub监听器,将订阅的信息发送到用户端,这样,用户端就能当需要的时候接受到消息,而不是定期发请求拉取消息。

//客户端
# 连接订阅服务器
sub = Redis.subscribe('new_event')
# 增加一个句柄进行处理服务器返回的消息
sub.subscribe do |on|
# 接受到消息时进行处理
on.message do |chan, msg|
#处理消息
end
end

# 等待服务器推送的消息
sub.poll

  客户端只需要把sub这个订阅发布建立起来,再循环调用sub.poll方法来获取实时的消息,就可以实现客户端通过Redis做轮询任务了。

  基于pub/sub机制,使用Redis来完成轮询任务具有很高的可靠性,并且可以大大提高web程序的性能,完善请求轮次、处理效率和后端高可用控制。


数据运维技术 » 构建Web后端使用Redis进行轮询(web轮训redis)