背景
内部重构的一个项目中,同事通过apache的GenericObjectPool
构建一个小型的线程池维护FTP服务器的连接,但是在实际使用中偶尔会出去报错,错误为:connection reset by peer, socket write error
分析
很明显,这是一个socket连接重置的问题。在服务器和客户端交互的模型中,两方都维护着发送端和接收端,主动发送(output)与被动接收(input),当服务器接收端已经关闭后,而客户端却还在发送数据的时候,服务器就会向客户端发送(连接已经重置,socket错误)的消息。ftp导致报错的主要原因是连接超时。
解决方法
在连接池的的borrowObject()
方法中,默认不会校验去除的对象,但是可以设置取出的对象是否校验通过,通过setTestOnBorrow(true)
设置获取对象时进行校验,具体代码在borrowObject(long borrowMaxWaitMillis)
中
这样保证每次从线程池中获取的对象都可用。