17

我需要访问我实验室远程服务器上的 MySQL 数据库。该服务器只有在我登录到远程网络上的网关服务器后才能访问:

local server => gateway server => MySQL server.

我可以使用端口 24222 SSH 到网关。

我正在使用 PERL DBI模块。这是我在实验室时用来连接的:

my $host="1.2.3.4";
my $database="dbname";
my $user="user";
my $pw="pass";
my $table="table";    

我想我必须建立一条通过网关服务器到数据库服务器的隧道。我该怎么做呢?如果 MySQL 数据库在网关上,我可以像这样打开一个隧道:

$ ssh -f user@gateway -L 3307:127.0.0.1:3306 -N 

如何修改它以通过网关上的开放端口 24222 通过隧道连接到 1.2.3.4 上的 MySQL 服务器?


更新:

使用@anttir 的回答我得到了它的工作如下。

  1. 设置隧道:

    $ ssh -fN -p 24222 user1@11.12.13.14 -L 3307:1.2.3.4:3306
    
  2. 设置脚本变量:

    my $host="127.0.0.1";
    my $port = 3307;
    
4

3 回答 3

21

使用命令:

$ ssh -f user@gateway -L 3307:1.2.3.4:3306 -N 

这表明到客户端 localhost 3307 的所有连接都将通过 SSH 隧道转发到网关,然后连接到主机 1.2.3.4 到端口 3306。

编辑:如果 SSH 在端口 24222 上,那么

$ ssh -f user@gateway -p 24222 -L 3307:1.2.3.4:3306 -N 
于 2012-09-19T12:37:37.093 回答
5

如果您需要使用多个跃点来访问 MySQL 服务器,我首先建议创建 .ssh/config 文件并像这样使用 ProxyCommand:

  Host gateway
     HostName example.com
     User foo
     Port 22
     IdentityFile ~/.ssh/id_rsa.pub

  Host mysql_access_server
      HostName example-web.com
      Port 22
      User foo
      ProxyCommand ssh -A gateway nc %h %p

然后像这样转发端口:

ssh -f mysql_access_server -L 3309:sqlmaster.example.com:3306 -N

然后你可以像这样访问 MySQL 服务器:

mysql --user=root --host=127.0.0.1 --password=root --port=3309 some_db_name
于 2013-09-26T07:42:42.483 回答
2

使用隧道:

ssh -f user@gateway -L 3307:1.2.3.4:3306 -N 

您将能够连接到本地主机端口 3307 上的数据库

于 2012-09-19T12:45:09.320 回答