我正在使用 JSch 通过 SFTP 上传文件。在其当前状态下,每个线程在需要时打开和关闭连接。
JSch是否可以使用连接池来避免大量连接打开和关闭带来的开销?
这是一个从线程内部调用函数的例子
public static void file_upload(String filename) throws IOException {
JSch jsch = new JSch();
Session session = null;
try {
session = jsch.getSession("user", "server_name", 22);
session.setConfig("StrictHostKeyChecking", "no");
session.setPassword("super_secre_password");
session.connect();
Channel channel = session.openChannel("sftp");
channel.connect();
ChannelSftp sftpChannel = (ChannelSftp) channel;
FileInputStream inputSrr = new FileInputStream(filename);
try {
sftpChannel.put(inputSrr, "/var/temp/"+filename);
} catch (SftpException e) {
e.printStackTrace();
} finally {
if (inputSrr != null) {
inputSrr.close();
}
}
sftpChannel.exit();
session.disconnect();
} catch (JSchException e) {
e.printStackTrace();
} catch (SftpException e) {
e.printStackTrace();
}
}
最佳答案
为此我更喜欢 commons-pool . ;)
关于java - 在 JSch 中使用连接池,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12780036/