用JAVA和Websocket实现实时通信
说到websocket你们必定不会陌生,WebSocket是HTML5一种新的协议。它实现了浏览器与服务器全双工通讯(full-duplex)。一开始的握手须要借助HTTP请求完成,当浏览器和服务器握手成功后,浏览器和服务器之间就造成了一条快速通道。二者之间就直接能够数据互相传送。有了websocket, 你们就能够摒弃以往用轮询来实现实时通信的方式了。 有了websocket后,应运而生的相关产品也不在少数,选择也成了最大的问题,在这里你可能会说“干吗用别人的,我能够本身用原始的开发一个啊” 对此我只想说你真NB,我也很想知道你是如何解决如下问题的:javascript
- 你是打算花1个月,2个月仍是1年还实现一个websocket通讯的?若是你说你打算花一个月,那说明两点,你的技术要上天了(这么刁的东西你能够那么快弄出来还不存在性能问题,除了我现有的膝盖,请把我下辈子的膝盖也拿走),贵公司土豪(贵公司对技术的炙热追求已经达到了行业的巅峰了,看来大家的项目不是很紧嘛,预算挺多嘛,告诉我贵公司的名字我也来钻研技术,哈哈哈)
- Websocket只支持ie10+, chrome, firefox, safari, opera. 不说多了,当前IE9及低版本的用户群体还有不少,你是怎么以为这些低版本浏览器的实时通信的? 上面两个问题无非就是涉及到两方面问题:开发成本和浏览器兼容性问题。站在管理者角度来看,都但愿尽量多的压缩开发成本,全部选择第三方推送服务是众多企业的一个理性选择。 选择产品时须要注意如下几点:
- 代码结构是否清晰易懂
- 消息到达率怎么样,数据到达状况是否可视
- 浏览器兼容性如何
- 产品的稳定性和安全性 好,重点来了,我不去评判其余产品的优缺点,只给出我对我最终选择的产品-GoEasy推送做一个单方面的评价。GoEasy推送知足我上面列的全部指标。
- 代码结构是否清晰易懂 GoEasy的代码分为订阅和推送两部分: 订阅时,只须要三句代码: a. 引入goeasy.js (文件很是小)
<script type="text/javascript" src="http://cdn.goeasy.io/goeasy.js"></script>java
b. 建立goeasy实例 var goEasy = new GoEasy({appkey: 'appkey'}); c. 订阅channel. goEasy. subscribe({ channel: 'channel1', onMessage: function(message){ alert('Meessage received:'+message.content);//接收到推送的消息 } }); 推送时,用goeasy提供的restful api来实现,api只须要三个参数便可: URL: http://goeasy.io/goeasy/publish Method: Post Parameters: appkey, channel, content 2. 消息到达率怎么样,数据到达状况是否可视 咱们项目的用户并发量目前最高在300人的样子,天天会推送30条消息的样子,每条消息的到达状况均可以在goeasy后台页面进行查看。至于到达率,咱们项目的对到达率的要求是98%, 就目前来看GoEasy应该是100%的到达率。 3. 浏览器兼容性如何 除了经常使用的浏览器chrome, firefox, safari, opera外还支持IE 6到IE11的版本,低版本IE浏览器GoEasy采用的是polling的方式。GoEasy在兼容性这方面作的很不错。 4. 产品的稳定性和安全性 稳定性的断定:项目已经持续运行了4个月了,没有出现过消息推不出或接收不到的状况。 安全性的断定:GoEasy在安全控制方面主要是经过appkey来控制,建立好app后系统会生成两个key,一个既能够用来接收又能够用来推送,另外一个只能够用来接收。因此用户能够选择性的暴露你的key. 这样轻松用JAVA实现客户端与服务器端的实时通讯了