Netty-SocketIO:最好用的Java版即时消息推送(2)

简介: Netty-SocketIO:最好用的Java版即时消息推送

###五、注意事项


关于socketio的ssl应用,一直没有弄出来,主要是java的toolkey生成的jks总是不被浏览器识别,socketio提供的例子也不能运行,在各大网站上暂时没有解决问题。可通过浏览器添加https的例外做法来规避错误,但不可取,后面还需要研究。

socketio在浏览器刷新后,旧的连接断开,需要重新建立连接,这个请注意。

客户端session超时后,切记关闭socket,我是通过10分钟一次的扫描进行的session超时验证,该方法不够理想。

server端,在实际应用中,需要将客户端断开的socket进行垃圾清理,注意判断方法如下:

NamespaceClient client = (NamespaceClient) socket;
if (client.getBaseClient().isConnected()) {
  SessionManager.getSession(getSession().getSessionId());
} else {
  logger.warn("web发送心跳包失败,客户端连接线程[" + this.getName() + "]已断开");
  running = false;
  break;
}


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


2017年12月26日补充:


项目迁移到了另外一台阿里云服务器,于是Netty-SocketIO的server在启动的时候出现了以下错误:


java.net.BindException: Cannot assign requested address: bind
  at sun.nio.ch.Net.bind0(Native Method)
  at sun.nio.ch.Net.bind(Unknown Source)
  at sun.nio.ch.Net.bind(Unknown Source)
  at sun.nio.ch.ServerSocketChannelImpl.bind(Unknown Source)
  at io.netty.channel.socket.nio.NioServerSocketChannel.doBind(NioServerSocketChannel.java:127)


问题发生在server.start()处,进行javaChannel().bind(localAddress, config.getBacklog());域名和端口绑定时出现了错误:


private SocketIOServer server = null;

server = new SocketIOServer(NetConfigManager.getWebQuotationConfig());// 此处的Configuration对象的Hostname设置的是域名,Port设置为10015


server.start();


最开始从日志里面找出了这样一条消息:


socketio.SocketIOServer$1: SocketIO server start failed at port: 10015!

直觉告诉我,阿里云的安全组在作怪,把10015端口禁掉了。于是我就去改安全组,把10015的入方向和出方向都放开了,但问题依然没有解决。


接下来,我只能丈二和尚摸不着头脑的去百度,他娘的结果没什么可靠的信息,都是一些乱七八糟的东西——什么端口被占用,使用netstat -ano查询端口,还有什么hosts文件要修改,等等,一系列坑爹又不负责任的答案。


折腾了接近四个半小时的时间,我™几乎要疯了,脑子一股热血升腾,恨不得把鼠标给砸了。


在气晕的状态下,我努力的控制着自己,问:“明明上一台阿里服务器的时候,这样配置,socketio就是正常的,现在怎么™就error了?”


试着让自己恢复冷静,就能想到办法。“不是端口的问题,那肯定是域名的问题!”


我试了试“localhost”,发现SocketIOServer竟然start成功了!????这说明什么问题,说明域名没有localhost的权限!但改成localhost有毛用,客户端不可能访问到服务器的localhost啊?


接着,我想到了IP地址!!!!!把域名换成公网的IP地址,竟然™的SocketIOServer start成功了!!!!


此时有两种解决方案,一是使用IP来替代域名,另外一个就是继续找域名的解决方案——一个不懂网络的程序员注定在网络安全方面吃点亏!,我™就是受害者之一。


好了,问题记录就先到这里——解决问题的最好办法就是让自己冷静下来!!!!


2018年9月11日补充:


由于项目在tomcat服务器的访问前缀由原来的http改为https,导致客户端的socketio无法正常访问到Netty-SocketIO服务器端。从昨天到今天,整整两天,一直在寻找解决方案,现在事情终于有所转机,为了更多小伙伴的需要,就把问题整理备案。


由于https下不允许使用http访问,所以Netty-SocketIO服务器端需要从http升级到https,具体的实例该怎么做呢?

demo可参照https://github.com/mrniko/netty-socketio-demo/blob/master/server/src/main/java/com/corundumstudio/socketio/demo/SslChatLauncher.java,但据我的实战情况来看,该官方实例无法在本地正常运行,也就是说,官方提供的https解决方案在本地是行不通的,但官方实例提供了一个keystore.jks,如果小伙伴们对keystore.jks不熟悉的话,可以先借用该jks。


有了jks,我们可以先将Server端升级到https,也就是ssl(非常抱歉,对https和ssl我还不是很清楚,但并不妨碍我将实例运行起来)。


Configuration config = new Configuration();
config.setPort(10015);
// 注意不要指定config.setHostname
// 具体原因不清楚,不得不再说一声抱歉,我在网络方面就是一个白痴,比如说我不懂hosts文件是干嘛的,也不懂内网和外网之间的区别,总之这一块使我非常焦虑,只好一步步组合方案进行试验,换句话说理论知识不够,只能靠不断试错来总结经验
// keystore.jks的密钥
config.setKeyStorePassword("test1234");
InputStream stream = new FileInputStream(new File("/home/soft/keystore.jks"));
config.setKeyStore(stream);
// 升级为https
server = new SocketIOServer(config);


然后我们来看客户端


var socket =  io.connect('https://147.101.128.223:10015');

// 使用https而不再是http,然后紧接着是服务器的外网地址,不知道为什么,然后是对应的端口


现在,已经可以通过https来访问到socketio的服务器端了。




但遗憾的是:地址栏中的https竟然变成了不安全的状态!!!!!


2018年9月14日补充:


之前的补充当中说https的地址栏变成了不安全的状态,其实是jdk的域名不匹配,如果jks把项目实际的域名匹配上的话,就不再提示不安全了!

另外,socketio的client在链接的时候可以使用域名链接,而不只是ip地址,如下:


var socket = io.connect("cmower.com");

1

需要特别注意的是,Netty-SocketIO的服务器端在配置config的时候,不要指定hostname,切记!!!!


如果在启动Server的时候发现:


java.net.BindException: Address already in use

at sun.nio.ch.Net.bind0(Native Method)

at sun.nio.ch.Net.bind(Net.java:433)

at sun.nio.ch.Net.bind(Net.java:425)

at sun.nio.ch.ServerSocketChannelImpl.bind(ServerSocketChannelImpl.java:223)

at io.netty.channel.socket.nio.NioServerSocketChannel.doBind(NioServerSocketChannel.java:127)

at io.netty.channel.AbstractChannel A b s t r a c t U n s a f e . b i n d ( A b s t r a c t C h a n n e l . j a v a : 554 ) a t i o . n e t t y . c h a n n e l . D e f a u l t C h a n n e l P i p e l i n e AbstractUnsafe.bind(AbstractChannel.java:554) at io.netty.channel.DefaultChannelPipeline AbstractUnsafe.bind(AbstractChannel.java:554)atio.netty.channel.DefaultChannelPipelineHeadContext.bind(DefaultChannelPipeline.java:1258)

at io.netty.channel.AbstractChannelHandlerContext.invokeBind(AbstractChannelHandlerContext.java:511)

at io.netty.channel.AbstractChannelHandlerContext.bind(AbstractChannelHandlerContext.java:496)

at io.netty.channel.DefaultChannelPipeline.bind(DefaultChannelPipeline.java:980)

at io.netty.channel.AbstractChannel.bind(AbstractChannel.java:250)

可以查看是否有其他的进程占用了地址?


举个例子,在我的项目当中,如果我先启动了Tomcat,那么Netty-SocketIO的Server就会提示以上错误;假如我先启动Netty-SocketIO的Server,再启动Tomcat,两者就都正常!


所以,以上建议,请特别注意!!!!


相关文章
|
Java
全网首发:OPPO推送:服务器端的参考代码,JAVA版
全网首发:OPPO推送:服务器端的参考代码,JAVA版
284 0
|
Java 微服务
Java报告推送失败补偿机制;钉钉群通知消息核心代码
Java报告推送失败补偿机制,超过次数后使用钉钉通知开发 自动补偿实现: 要求方法调用的过程中,失败的时候,系统有办法进行自动重试,重试达到一定次数后,钉钉通知开发。 实现设计:注解,反射,定时任务
250 0
Java报告推送失败补偿机制;钉钉群通知消息核心代码
|
Java Docker 容器
《阿里特邀专家徐雷Java Spring Boot开发实战系列课程(第18讲):制作Java Docker镜像与推送到DockerHub和阿里云Docker仓库》电子版地址
阿里特邀专家徐雷Java Spring Boot开发实战系列课程(第18讲):制作Java Docker镜像与推送到DockerHub和阿里云Docker仓库
214 0
《阿里特邀专家徐雷Java Spring Boot开发实战系列课程(第18讲):制作Java Docker镜像与推送到DockerHub和阿里云Docker仓库》电子版地址
|
Web App开发 前端开发 Java
Netty-SocketIO:最好用的Java版即时消息推送
版权声明:欢迎转载,请注明沉默王二原创。 https://blog.csdn.net/qing_gee/article/details/52525677 Netty-SocketIO是一个开源的、基于Netty的、Java版的即时消息推送项目。
6652 1
|
机器人 Java
Java后台推送告警信息到钉钉
Java后台推送告警信息到钉钉的实现
620 0
Java后台推送告警信息到钉钉
|
前端开发 JavaScript Java
Netty-SocketIO:最好用的Java版即时消息推送(1)
Netty-SocketIO:最好用的Java版即时消息推送
784 0
Netty-SocketIO:最好用的Java版即时消息推送(1)
|
Java
全网首发:OPPO推送:服务器端的参考代码,JAVA版
近来调试OPPO推送,服务器没有参考代码,简直让人崩溃。于是反复测试,排列组合,找到了正确的办法。也许有朋友也会遇到类似问题,所以在这里把代码共享出来。节省时间不说,最主要心情好一些。
269 0
|
Java Maven Docker
Java Spring Boot 2.0 实战之制作Docker镜像并推送到Docker Hub和阿里云仓库
大规模集群快速部署Java应用,需要制作Docker镜像,本次课程详细介绍如何制作Java程序的Docker镜像文件,深入解析DockerFile核心参数,以及实践演练把我们制作的Docker镜像推送到DockerHub仓库,国内可以使用阿里云Docker仓库加速,以及安全保护机制。
8856 0
|
NoSQL Java Docker
【直播回顾】阿里特邀专家徐雷Java Spring Boot开发实战系列课程(第18讲):制作Java Docker镜像与推送到DockerHub和阿里云Docker仓库
Docker大规模集群快速部署Java应用,需要构建Docker镜像。 本次课程详细介绍如何制作Java Docker镜像,解析DockerFile核心参数,把Docker镜像推送到DockerHub和阿里云Docker仓库,以及安全保护机制。
7157 0
|
网络协议 Java API
Java新人必学课程,Java进阶学习全路线(内涵Java超级干货推送及专家社群福利)
自从拉了java社群之后,发现经常有一些新手java开发在吐槽,吐槽java不知道从何学起,感觉路很迷惘。其实小编想说,沉下心,你会发现要走的路并不是很难。为了帮助新人更好的成长,小编特意邀请了最课程的陆敏技老师来给大家进行java基础课程直播分享。
19023 0