我正在尝试从S3读取一个csv文本文件,然后将其每一行发送到分布式队列中进行处理。
在尝试读取时,我会在不同的执行点上收到“java.net.SocketException:Socket is closed”异常。这是代码:
在尝试读取时,我会在不同的执行点上收到“java.net.SocketException:Socket is closed”异常。这是代码:
AmazonS3 s3 = new AmazonS3Client(new PropertiesCredentials(MyClass.class.getResourceAsStream("myCredentials.properties")));
String bucketName = "myBucket";
String key = "myFile";
S3Object object = s3.getObject(new GetObjectRequest(bucketName, key));
InputStream in = object.getObjectContent();
BufferedReader readerS3 = new BufferedReader(new InputStreamReader(in, Charset.forName(fileInfo.getEncoding())));
try {
String line = null;
while ((line = readerS3.readLine()) != null) {
// Sending the line to a distributed queue
}
} catch (IOException e) {
e.printStackTrace();
}finally {
try {
in.close();
} catch (IOException e) {
e.printStackTrace();
}
}
有没有想法解决这个问题?
更新:
如果我停止整个程序并再次运行它,那么第二次运行该方法时就会出现此异常,但是如果我再次运行该方法,则第一次运行该方法时它可以正常工作。
S3Client
、S3Object
和AmazonS3Client
。可能存在垃圾回收器无法及时清理对象并关闭连接的问题。 - jn1kkhttp://docs.amazonwebservices.com/AWSJavaSDK/latest/javadoc/com/amazonaws/ClientConfiguration.html#getSocketTimeout()
- jn1kk