Node.js通过ssh连接

时间:2014-07-10 23:28:53

标签: mysql node.js ssh

我有一个可以运行的node.js服务器,但需要为ssh连接设置:

var mysql = require('mysql')
var io = require('socket.io').listen(3000)
var db = mysql.createConnection({

    host: 'hostname',
    user: 'username',
    password: '12345',
    database: '12345',
    port: 3306,
    socket: '/var/run/mysqld/mysqld.sock' 
})

db.connect(function(err){
    if (err) console.log(err)
})

我知道有用于此目的的ssh npm库,但是可用的选项(ssh2,node-sshclient等)似乎处理可能使事情过于复杂的相当复杂的功能。我正在寻找通过ssh连接到我的mysql数据库的最简单方法。什么是实现这一目标的最佳方式?

1 个答案:

答案 0 :(得分:21)

如果您正在运行linux / unix系统,请执行以下操作:

通过ssh连接到您的mysql服务器,并通过此ssh隧道代理mysql端口(默认为3306)。

其工作原理如下:

1 输入screen(即使shell关闭,也要启动永久性的屏幕会话)。

2 输入屏幕外壳:

ssh -L 3306:127.0.0.1:3306 your_servers_domain_or_ip -lyour_login_name

3 输入您的ssh密码/或使用PKI身份验证以避免手动步骤

4 完成...现在可以像在应用程序安装在同一台机器上时那样连接MySQL。

从node.js连接到MySQL,如下所示:

var db = mysql.createConnection({
    host: '127.0.0.1', // Important to connect to localhost after connecting via ssh in screen
    user: 'username',
    password: '12345',
    database: '12345',
    port: 3306
});