我需要通过SSH隧道连接到MongoDB,并且JSch端口转发抛出错误:
本地端口127.0.0.1:27017无法绑定
我必须通过SSH隧道连接到MongoDB。我在stackoverflow上找到了代码,它解决了我的问题。但是几周后,相同的代码停止工作。我无法确定原因。另外,使用与Java代码中相同的凭据,我也尝试使用SSH -L
命令通过CMD连接到相同的凭据,并且它可以正常工作。我还可以使用NoSQLBrowser中的相同凭据连接到MongoDB。我已经尝试并搜索了Google上的所有内容,但问题仍然没有解决。下面是它的代码-
java.util.Properties config = new java.util.Properties();
config.put("StrictHostKeyChecking", "no");
JSch jsch = new JSch();
SSH_SESSION = null;
SSH_SESSION = jsch.getSession(SSH_USER, SSH_HOST, SSH_PORT);
SSH_SESSION.setPassword(SSH_PASSWORD);
SSH_SESSION.setConfig(config);
SSH_SESSION.connect();
SSH_SESSION.setPortForwardingL(27017, "localhost", 22);
MongoClient mongoClient = new MongoClient(LOCAL_HOST, LOCAL_PORT);
mongoClient.setReadPreference(ReadPreference.nearest());
MongoCursor<String> dbNames = mongoClient.listDatabaseNames().iterator();
while (dbNames.hasNext()) {
System.out.println(dbNames.next());```
我在端口转发线路上收到以下错误:-
com.jcraft.jsch.JSchException: PortForwardingL: local port 127.0.0.1:27017 cannot be bound.
at com.jcraft.jsch.PortWatcher.<init>(PortWatcher.java:158)
at com.jcraft.jsch.PortWatcher.addPort(PortWatcher.java:110)
at com.jcraft.jsch.Session.setPortForwardingL(Session.java:1847)
at com.jcraft.jsch.Session.setPortForwardingL(Session.java:1828)
at com.jcraft.jsch.Session.setPortForwardingL(Session.java:1809)
at com.jcraft.jsch.Session.setPortForwardingL(Session.java:1792)
at com.schenker.boot.bootdemo.controller.TestMongoAgain.main(TestMongoAgain.java:35)
Caused by: java.net.BindException: Address already in use: JVM_Bind
at java.net.DualStackPlainSocketImpl.bind0(Native Method)
at java.net.DualStackPlainSocketImpl.socketBind(Unknown Source)
at java.net.AbstractPlainSocketImpl.bind(Unknown Source)
at java.net.PlainSocketImpl.bind(Unknown Source)
at java.net.ServerSocket.bind(Unknown Source)
at java.net.ServerSocket.<init>(Unknown Source)
at com.jcraft.jsch.PortWatcher.<init>(PortWatcher.java:150)
... 6 more
com.jcraft.jsch.JSchException: PortForwardingL: local port 127.0.0.1:27017 is not registered.
at com.jcraft.jsch.PortWatcher.delPort(PortWatcher.java:118)
at com.jcraft.jsch.Session.delPortForwardingL(Session.java:1876)
at com.jcraft.jsch.Session.delPortForwardingL(Session.java:1865)
另外,很奇怪的是,如果我使用PortForwardingL
而不是PortForwardingR
,它不会引发任何错误,但是在下一行中它将连接到我的本地MongoDB。有人可以帮我吗?
答案 0 :(得分:0)
端口27017可能由本地计算机上运行的某些应用程序/服务使用-可能是本地Mongo数据库。
无论如何,只要选择其他任何端口号即可。可以是任何东西。
尽管如果仅在不使用应用程序的情况下将端口用于内部使用,则不应依赖固定的端口号。您永远不会知道其他一些应用程序何时阻止该端口。让JSch自动选择一个空闲端口:
int forwardedPort = SSH_SESSION.setPortForwardingL(0, "localhost", 22);
MongoClient mongoClient = new MongoClient(LOCAL_HOST, forwardedPort);
尽管通常来说,您的代码似乎是错误的。您将端口转发到22,而您可能应该将其转发到远程Mongo DB端口。
查看完整的工作示例(对于MySQL,对于MongoDB,它是相同的,只是端口不同):
Connect to remote MySQL database through SSH using Java
强制性警告:请勿使用StrictHostKeyChecking=no
盲目接受所有主机密钥。那是一个安全漏洞。您失去了针对MITM attacks的保护。
有关正确(且安全)的方法,请参见:
How to resolve Java UnknownHostKey, while using JSch SFTP library?