大道至简--GoEasy推送

获取变推送,被动变主动

以往一提到需要数据实时显示,大家首先想到的就是利用轮询方式定时向后台去查看有没有信息,有的话,web页面将向下拉取这些数据。慢慢地大家意识到这种方式十分消耗客户端和服务端的资源,那么怎么做是最优方式呢? 将被动变主动!就如同对讲机一样,当对方有话要讲时直接讲你就可以听到了,而不是你不停问对方有话讲没。由此而衍生出的技术有websocket, socket.io。它们的共同特点都是在客户端和服务器端建立一个管道,通过这个管道服务器端可以直接将实时信息主动推送给客户端。

直击痛点

恐怕问题又来了,如何正确有效的将websocket, socket.io应用到你的系统中呢?于是乎你开始找谷哥,找度娘,发现大家的实现实例都是长篇大论,代码都是几百行。头痛吗?如果这时有人已经集成了这些技术,但是代码复杂度降低了几十个点,你是不是心动了呢?

技术选择

到目前为止能够提供推送服务的技术不在少数,什么PubNub,极光,云推,友盟,GoEasy等。如何选择?我选择的原则是代码是否简单,代码是否易懂,服务是否稳定。经过对比,PubNub和GoEasy在代码的简洁易懂方面是达到了我的要求的,代码实现思路跟用对讲机通信一样简单明了。但是由于PubNub是国外的产品,有时候访问官网需要连接VPN,考虑到系统用户都在国内及服务的稳定性,最后GoEasy拔得头筹。

Web实时消息后台服务器推送技术

大道至简

既然选择了GoEasy, 不在此介绍一下它的代码,谁知道我是不是口说无凭?下面我用对讲机来比喻GoEasy实现推送消息的过程。
假如你是你是服务器端,你的女朋友是客户端:
1.  既然要通信,至少你和女朋友每人要有一台对讲机吧。
      服务器端:引入GoEasy到项目中           

<repository>
  <id>goeasy</id>
  <name>goeasy</name>
  <url>http://maven.goeasy.io/content/repositories/releases/</url>
</repository>
...
<dependency>
  <groupId>io.goeasy</groupId>
  <artifactId>goeasy-sdk</artifactId>
  <version>0.3.3</version>
</dependency>

     客户端:引入GoEasy.js

<script type="text/javascript" src="http(s)://cdn.goeasy.io/goeasy.js"></script>

2. 打开对讲机的电源,确保你们在可通讯范围内。
   服务器端:创建一个GoEasy对象,appkey连接到GoEasy的凭证

GoEasy goEasy = new GoEasy("appkey" );

   客户端:创建一个GoEasy对象,appkey连接到GoEasy的凭证

<script type="text/javascript">var goEasy = new GoEasy({
               appkey: 'Your app key here'
               });
</script>

3.  将你们的对讲机调到同一频道,你开始讲话,女朋友准备收听
      客户端:订阅频道1

goEasy.subscribe({
                 channel: 'channel1',
                 onMessage: function(message){
                              alert('Meessage received:'+message.content);//女朋友听到的内容
                           }
                    });

     服务器端:往频道1推消息

 goEasy.publish('channel1', '妹妹,我宣你!');

这里服务器端使用的是GoEasy的Java SDK, 如果你使用的是其他语言,则可以通过restful API来推送消息,一个url, POST 请求,三个参数,就可以轻松搞定!

如果大家有其他更好的选择,欢迎留言讨论!


 

猜你喜欢

转载自sanrenxing-1.iteye.com/blog/2335729