netty-socketio是一个开源的Socket.io服务器端的一个java的实现, 它基于Netty框架。可应用于服务端主动推送消息到客户端等场景,比如说股票价格变化、k线图的走势,和websocket是一个作用,只不过socketio可支持所有的浏览器。 项目地址为: https://github.com/mrniko/netty-socketio

Socket.IO除了支持WebSocket通讯协议外,还支持许多种轮询(Polling)机制以及其它实时通信方式,并封装成了通用的接口,并且在服务端实现了这些实时机制的相应代码。Socket.IO实现的Polling通信机制包括Adobe Flash Socket、AJAX长轮询、AJAX multipart streaming、持久Iframe、JSONP轮询等。Socket.IO能够根据浏览器对通讯机制的支持情况自动地选择最佳的方式来实现网络实时应用。

一、下载Netty-SocketIO

  1. socket.io-client-master
  2. netty-socketio-master
  3. netty-socketio-demo-master

从netty-socketio的git上可下载到以上三个压缩包,分别对应的是web 客户端的所需文件、netty socketio的java服务端实现、以及对应的可以应用web推送的demo。

二、部署server的资源项目

从git上下载的socketio server压缩包中没有项目所需的jar包,我是自己新建了一个项目,本来上传到了CSDN的代码库里了,但写博客的时候怎么也打不开了,那么只能提供对应项目导航图,同时提供jar包的下载地址,需要的可动手去获得。

http://mvnrepository.com/网站上课下载到需要的所有jar包。

然后将jar包添加到项目中。

切记jdk的版本一定要在1.7以上,我在本地环境中用的1.7,但是服务器上一直用的是1.6,部署项目的时候没有注意,导致服务端可以接收到客户端的socketio 的connect,但是客户端的response相应中却连接不通,开始的时候以为是跨域问题导致的,搜了好多帖子,但问题根本就是不是跨域引起的,jdk的版本换成1.7就ok了,因为netty的nio是基于java的1.7的。

三、应用server

在需要应用socketio的项目上右键,为项目添加socketio项目支持(注意红色标出的)。

新建main类。

  1. public static void main(String[] args) throws InterruptedException {
  2. Configuration config = new Configuration();
  3. config.setHostname("localhost");
  4. config.setPort(10015);
  5. SocketIOServer server = new SocketIOServer(config);
  6. server.addConnectListener(new ConnectListener() {// 添加客户端连接监听器
  7. @Override
  8. public void onConnect(SocketIOClient client) {
  9. logger.info(client.getRemoteAddress() + " web客户端接入");
  10. client.sendEvent("helloPush", "hello");
  11. }
  12. });
  13. // 握手请求
  14. server.addEventListener("helloevent", HelloUid.class, new DataListener<HelloUid>() {
  15. @Override
  16. public void onData(final SocketIOClient client, HelloUid data, AckRequest ackRequest) {
  17. // 握手
  18. if (data.getMessage().equals("hello")) {
  19. int userid = data.getUid();
  20. logger.info(Thread.currentThread().getName() + "web读取到的userid:" + userid);
  21. // send message back to client with ack callback
  22. // WITH data
  23. client.sendEvent("hellopush", new AckCallback<String>(String.class) {
  24. @Override
  25. public void onSuccess(String result) {
  26. logger.info("ack from client: " + client.getSessionId() + " data: " + result);
  27. }
  28. }, sessionTime);
  29. } else {
  30. logger.info("行情接收到了不应该有的web客户端请求1111...");
  31. }
  32. }
  33. });
  34. server.start();
  35. Thread.sleep(Integer.MAX_VALUE);
  36. server.stop();
  37. }

当client通过ip和端口连接到server后,会构造一个SocketIOClient client的对象,在实际的应用中,可以将该client保存起来,通过client.sendEvent("helloPush", "hello");就可以向client端发送相应的数据了。

四、应用client

①、引入socket.io.js

  1. <script type="text/javascript" src="${ctx}/components/socketio/socket.io.js"></script>

②、创建connection的公共方法

  1. function connectQuotation(uid, callback) {
  2. // 链接行情server
  3. socket = io.connect('http://localhost:10015');
  4. // 如果用户在web端登陆,那么发送握手请求
  5. if (uid) {
  6. // 连接上server后
  7. socket.on('connect', function() {
  8. // 发送握手请求
  9. var jsonObject = {
  10. uid : parseInt(uid),
  11. message : "hello"
  12. };
  13. this.emit('helloevent', jsonObject);
  14. this.on('hellopush', function(data, ackServerCallback, arg1) {
  15. // base64转码的数据,可忽视
  16. YUNM.session = {
  17. sessionId : $.base64.atob(data.sessionId),
  18. time : $.base64.atob(data.time)
  19. };
  20. if (ackServerCallback) {
  21. ackServerCallback('server message was delivered to client!');
  22. }
  23. });
  24. });
  25. }
  26. // 如果web端session超时,socket断开,10分钟扫描一次
  27. int = window.setInterval(function() {
  28. // 我是通过ajax判断session超时的,你也可以通过其他方式
  29. $.ajax({
  30. type : 'POST',
  31. url : common.ctx + "/getSessionTimeout",
  32. dataType : "json",
  33. cache : false,
  34. success : function(json) {
  35. var timeout = parseInt(json.message);
  36. // session超时后,socket断开,服务端就可以监听到释放资源
  37. if (timeout == 0) {
  38. socket.disconnect();
  39. }
  40. },
  41. error : function() {
  42. socket.disconnect();
  43. // 清除
  44. window.clearInterval(int);
  45. }
  46. });
  47. }, YUNM._set.interval);
  48. callback();
  49. }

③、需要web推送的页面进行socketio的连接

  1. $(function() {
  2. connectQuotation($("#global_uid").val(), function() {
  3. socket.on("pushQuotation", function(message) {
  4. if (message.type == "dealOrder") {
  5. var msg = message.response.result;
  6. // 输出服务端消息
  7. YUNM.debug(msg);
  8. }
  9. });
  10. });
  11. });

五、注意事项

  1. 关于socketio的ssl应用,一直没有弄出来,主要是java的toolkey生成的jks总是不被浏览器识别,socketio提供的例子也不能运行,在各大网站上暂时没有解决问题。可通过浏览器添加https的例外做法来规避错误,但不可取,后面还需要研究。
  2. socketio在浏览器刷新后,旧的连接断开,需要重新建立连接,这个请注意。
  3. 客户端session超时后,切记关闭socket,我是通过10分钟一次的扫描进行的session超时验证,该方法不够理想。
  4. server端,在实际应用中,需要将客户端断开的socket进行垃圾清理,注意判断方法如下:
  1. NamespaceClient client = (NamespaceClient) socket;
  2. if (client.getBaseClient().isConnected()) {
  3. SessionManager.getSession(getSession().getSessionId());
  4. } else {
  5. logger.warn("web发送心跳包失败,客户端连接线程[" + this.getName() + "]已断开");
  6. running = false;
  7. break;
  8. }

整体Netty-SocketIO的Web推送还是非常易于掌握的,但是缺少api,做起来需要不停实践,另外解决问题的方法不多,希望本篇可以给你提供些许帮助。

Netty-SocketIO的Web推送实战应用的更多相关文章

  1. atitit.web 推送实现方案集合(2)---百度云,jpush 极光推送 ,个推的选型比较.o99

    atitit.web 推送实现方案集合(2)---百度云,jpush 极光推送 ,个推的选型比较.o99 1.1. 云推送有推送次数或频率的限制吗? 1 1.2. 推送的消息长度 1 1.3. 离线消 ...

  2. atitit.web 推送实现方案集合

    atitit.web 推送实现方案集合 1. 俩中模式 Push/Pull 1 2. 需要实现的特性 2 2.1. 推送消息广播. 2 2.2. 推送定向消息. 2 2.3. 提供连接上线前.上线.下 ...

  3. .atitit.web 推送实现解决方式集合(3)----dwr3 Reverse Ajax

    .atitit.web 推送实现解决方式集合(3)----dwr3 Reverse Ajax 1. 原理实现 1 2. Page  添加配置.添加回调函数dwr.engine.setActiveRev ...

  4. Android 基于Netty接收和发送推送解决方案的消息字符串(三)

    在上一篇文章中<Android 基于Netty的消息推送方案之概念和工作原理(二)> .我们介绍过一些关于Netty的概念和工作原理的内容,今天我们先来介绍一个叫做ChannelBuffe ...

  5. JavaScript是如何工作的: Web推送通知的机制

    摘要: 如何在Web端推送消息? 这是专门探索 JavaScript 及其所构建的组件的系列文章的第9篇. 如果你错过了前面的章节,可以在这里找到它们: JavaScript是如何工作的:引擎,运行时 ...

  6. .atitit.web 推送实现解决方案集合(3)----dwr3 Reverse Ajax

    .atitit.web 推送实现解决方案集合(3)----dwr3 Reverse Ajax 1. 原理实现 1 2. Page  增加配置,增加回调函数dwr.engine.setActiveRev ...

  7. 基于netty-socketio的web推送服务

    实时消息的推送,PC端的推送技术可以使用socket建立一个长连接来实现.传统的web服务都是客户端发出请求,服务端给出响应.但是现在直观的要求是允许特定时间内在没有客户端发起请求的情况下服务端主动推 ...

  8. SpringBoot项目集成socketIo实现实时推送

    netty-socketio maven依赖 <dependency> <groupId>com.corundumstudio.socketio</groupId> ...

  9. web推送

    WEB消息推送框架 web-msg-sender是一款web长连接推送框架,采用PHPSocket.IO开发,基于WebSocket长连接通讯,如果浏览器不支持WebSocket则自动转用comet推 ...

随机推荐

  1. 【LeetCode】Copy List with Random Pointer

    A linked list is given such that each node contains an additional random pointer which could point t ...

  2. 并发编程8 线程的创建&验证线程之间数据共享&守护线程&线程进程效率对比&锁(死锁/递归锁)

    1.线程理论以及线程的两种创建方法 2.线程之间是数据共享的与join方法 3.多线程和多进程的效率对比 4.数据共享的补充线程开启太快 5.线程锁 互斥锁 同步锁 6.死锁现象和递归锁 7.守护线程 ...

  3. php 正则表达式四,例子

    PHP常用正则表达式汇总:http://bbs.php100.com/read-htm-tid-83266.html 1.非空匹配: .+ 2.浮点数匹配: ^\d+.\d{2}$ 3.手机号匹配: ...

  4. PHP数组遍历详解

    一.PHP数组简介 1.PHP数组的分类 按照下标的不同分为关联数组和索引数组①索引数组:下标从0开始依次增长②关联数组:下标为字符串格式,每个下标字符串与数组的值一一对应,(有点像对象的键值对) 下 ...

  5. detectron安装+caffe2安装

    detectron安装+caffe2安装 因为想跑一下facebook最近开源的detectron物体检测平台,所以安装caffe2+detectron 总结: 一定要好好看官方安装教程:https: ...

  6. MySQL给字段唯一索引的三种方法

    建表时添加 DROP TABLE IF EXISTS `student`; CREATE TABLE `student` ( `stu_id` ) NOT NULL AUTO_INCREMENT, ` ...

  7. mysql 建立表之间关系 一对一 练习1

    创建db5数据库 create database db5 charset=utf8; use db5; 例一:一个用户只有一个博客 用户表: id name 1 mike 2 alex 3 jack ...

  8. [译转]深入理解LayoutInflater.inflate()

    原文链接:https://www.bignerdranch.com/blog/understanding-androids-layoutinflater-inflate/ 译文连接:http://bl ...

  9. [DevOps] 认识一下

    大家都在说DevOps(Develop Operation),大概知道就是开发和运维沟通交流,一条线,然后使产品能够顺利的.短时间内上线.维稳什么的. 今天特意看了下 DockOne里面的一篇文章,再 ...

  10. 移动app自动化测试

    原文出处https://www.toutiao.com/i6473606106970063374/ 原文作者是今日头条的:一个字头的诞生 在此感谢原文作者的无私分享! 移动App自动化测试(一) 目前 ...