Кварцевое задание запущено - Не удалось подключиться к SFTP-серверу - Сброс подключения - PullRequest
0 голосов
/ 04 ноября 2019

Изменено описание. У меня есть кварцевое задание, работающее на этой виртуальной машине, и я получал эту ошибку

org.apache.commons.vfs2.FileSystemException: Could not connect to SFTP server at "sftp://reports.staging.companyname.com/".
        at org.apache.commons.vfs2.provider.sftp.SftpFileProvider.doCreateFileSystem(SftpFileProvider.java:107)
        at org.apache.commons.vfs2.provider.AbstractOriginatingFileProvider.getFileSystem(AbstractOriginatingFileProvider.java:103)
        at org.apache.commons.vfs2.provider.AbstractOriginatingFileProvider.findFile(AbstractOriginatingFileProvider.java:81)
        at org.apache.commons.vfs2.provider.AbstractOriginatingFileProvider.findFile(AbstractOriginatingFileProvider.java:65)
        at org.apache.commons.vfs2.impl.DefaultFileSystemManager.resolveFile(DefaultFileSystemManager.java:693)
        at org.apache.commons.vfs2.impl.DefaultFileSystemManager.resolveFile(DefaultFileSystemManager.java:621)
        at com.companyname.appname.connector.dropbox.sftp.PseSFTPConnection.doConnect(PseSFTPConnection.java:149)
        at com.companyname.appname.connector.dropbox.sftp.PseSFTPConnection.connect(PseSFTPConnection.java:109)
        at com.companyname.appname.connector.dropbox.sftp.DropboxDaoSFTPImpl.isAvailable(DropboxDaoSFTPImpl.java:183)
        at com.companyname.appname.batch.jobs.DataFileProcessorJob.execute(DataFileProcessorJob.java:46)
        at sun.reflect.GeneratedMethodAccessor137.invoke(Unknown Source)
        at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
        at java.lang.reflect.Method.invoke(Method.java:606)
        at org.springframework.util.MethodInvoker.invoke(MethodInvoker.java:273)
        at org.springframework.scheduling.quartz.MethodInvokingJobDetailFactoryBean$MethodInvokingJob.executeInternal(MethodInvokingJobDetailFactoryBean.java:264)
        at org.springframework.scheduling.quartz.QuartzJobBean.execute(QuartzJobBean.java:86)
        at org.quartz.core.JobRunShell.run(JobRunShell.java:216)
        at org.quartz.simpl.SimpleThreadPool$WorkerThread.run(SimpleThreadPool.java:549)
Caused by: org.apache.commons.vfs2.FileSystemException: Could not connect to SFTP server at "reports.staging.companyname.com".
        at org.apache.commons.vfs2.provider.sftp.SftpClientFactory.createConnection(SftpClientFactory.java:230)
        at org.apache.commons.vfs2.provider.sftp.SftpFileProvider.doCreateFileSystem(SftpFileProvider.java:96)
        ... 17 more
Caused by: com.jcraft.jsch.JSchException: Session.connect: java.net.SocketException: Connection reset
        at com.jcraft.jsch.Session.connect(Session.java:565)
        at com.jcraft.jsch.Session.connect(Session.java:183)
        at org.apache.commons.vfs2.provider.sftp.SftpClientFactory.createConnection(SftpClientFactory.java:226)
        ... 18 more
sdfFileProcessing_Worker-9 2019-11-04 05:20:03,915 ERROR: com.companyname.appname.connector.dropbox.sftp.DropboxDaoSFTPImpl - Is available

, когда я использую обычную утилиту командной строки Sftp, также получающую "Сброс соединения по пиру" "ssh_exchange_identification:прочитано: Сброс соединения по одноранговому узлу Не удалось прочитать пакет: "сброс соединения по одноранговому узлу" из java-кода и обычная команда Sftp -> соединение также не удается

root@qa-batch:~# sftp userid_usercontinuation@somedomain.com
ssh_exchange_identification: read: Connection reset by peer
Couldn't read packet: Connection reset by peer
root@qa-batch:~# free -m
             total       used       free     shared    buffers     cached
Mem:          3953       3522        430          0        299       1570
-/+ buffers/cache:       1652       2300
Swap:         2047          6       2041
root@qa-batch:~#

Я продолжаю получать это исключение.

Проблема постоянно повторяется, и в коде, использующем блок finally, правильно отключите соединение. Я проверил на некоторых форумах переполнения стека, но они упомянули, что это может быть проблема кучи. Поэтому я попытался остановить службу Java Quartz, временно я могу подключиться с помощью команды SFTP cli (то есть, через 5 минут). Но мое требование заключается в том, чтобы java-приложение могло подключаться к sftp и читать удаленный файл, а затем обрабатывать и обновлять базу данных.

1 Ответ

0 голосов
/ 04 ноября 2019

Обычно «Сброс соединения по пиру» означает, что существует проблема на другом конце (в данном случае удаленный сервер SFTP), поэтому есть вероятность, что Quartz Job и Java в целом не являются «виновными». Возможно, иногда вы также можете проверить сеть на наличие проблем, но это не Java ...

Итак, с точки зрения разрешения, прежде всего попробуйте подключиться к какому-нибудь «не Java» клиенту и увидите, что иногда вы не будетебыть в состоянии подключиться также.

После этого вы ничего не можете сделать:

  • Повторите попытку, вы можете повторить попытку подключения

  • В качестве альтернативы, если бизнес-логика имеет смысл: выполняйте задание чаще, чтобы, если одно выполнение задания не могло взаимодействовать с удаленным сервером, довольно быстро запустился другой триггер, и, вероятно, в этот раз вам повезет больше.

Я понимаю, что все это довольно плохие обходные пути, но, опять же, без стабильного соединения с удаленной частью вы не можете действительно решить это на Java, извините

...