欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页

java.io.IOException: 远程主机强迫关闭了一个现有的连接

程序员文章站 2022-04-24 10:29:18
...

摆脱烦恼最有效的是慢思考,为什么和我想的不一样,出入在哪里,什么导致的?


疑惑

    我使用netty框架接受数据,每隔半个小时存储数据,运行不到三个小时报错

     java.io.IOException: 远程主机强迫关闭了一个现有的连接

  java.io.IOException: 远程主机强迫关闭了一个现有的连接。
    at sun.nio.ch.SocketDispatcher.read0(Native Method)
    at sun.nio.ch.SocketDispatcher.read(Unknown Source)
    at sun.nio.ch.IOUtil.readIntoNativeBuffer(Unknown Source)
    at sun.nio.ch.IOUtil.read(Unknown Source)
    at sun.nio.ch.SocketChannelImpl.read(Unknown Source)


 解惑

主要原因是客户端强制关闭了连接(没有调用SocketChannel的close方法),服务端还在read事件中,此时读取客户端的信息时会报错。

代码不够健壮导致的;

//获取此key对应的套接字通道
		SocketChannel channel = (SocketChannel) key.channel();
		//创建一个大小为1024k的缓存区
		ByteBuffer buffer = ByteBuffer.allocate(1024);
		StringBuffer sb = new StringBuffer();
		//将通道的数据读到缓存区
		int count = 0;
		try{
			count = channel.read(buffer);
		}catch(IOException e){
			key.cancel();
			channel.socket().close();
			channel.close();
			return;
		}

 

上一篇: BIO、NIO

下一篇: BIO与NIO