我有一个可以运行的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数据库的最简单方法。什么是实现这一目标的最佳方式?
答案 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
});