【问题标题】:"local port ... cannot be bound" when forwarding port using JSch in Java在Java中使用JSch转发端口时“本地端口......无法绑定”
【发布时间】:2019-10-25 13:41:25
【问题描述】:

我需要通过 SSH 隧道连接到 MongoDB,JSch 端口转发报错:

本地端口127.0.0.1:27017无法绑定

我必须通过 SSH 隧道连接到 MongoDB。我在stackoverflow上找到了代码,它解决了我的问题。但几周后,相同的代码停止工作。我无法确定它的原因。此外,使用我在 Java 代码中使用的相同凭据,我还尝试使用 SSH -L 命令通过 CMD 连接到相同的凭据,并且它工作正常。我还可以使用来自 NoSQLBrowser 的相同凭据连接到 MongoDB。我已经尝试并搜索了谷歌上的所有内容,但问题仍未解决。下面是它的代码 -

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)

另外,很奇怪的是,如果我使用PortForwardingR 而不是PortForwardingL,它不会抛出任何错误,但在下一行它会连接到我的本地MongoDB。谁能帮我解决这个问题?

【问题讨论】:

    标签: java mongodb ssh jsch portforwarding


    【解决方案1】:

    端口 27017 可能被本地计算机上运行的某些应用程序/服务使用 - 可能是您的 本地 Mongo DB

    无论如何,只需选择任何其他端口号。它可以是任何东西。

    尽管如果您仅将端口用于内部使用而没有应用程序,则不应依赖固定的端口号。您永远不知道其他应用程序何时会阻止该端口。让 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?

    【讨论】:

    • 嗨,马丁,非常感谢。有效。我在你分享的链接上检查了你的答案,我明白你的意思。谢谢你。我想现在我更好地理解了这个 SSH 是如何工作的。
    猜你喜欢
    • 1970-01-01
    • 2013-01-19
    • 2019-08-21
    • 2014-08-30
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2019-02-02
    • 2015-11-19
    相关资源
    最近更新 更多