无法使用 ssh 客户端连接到 mysql 数据库
本文关键字:连接 mysql 数据库 客户端 ssh | 更新日期: 2023-09-27 18:35:42
我想通过SSH通道连接到服务器上的mysql数据库。
我已经下载了这个 SSH.Net 库。
这是我尝试过的,我认为在我的安全连接建立后它会起作用。
我的 SSH 连接已建立,但未执行与数据库的正常连接。
所以请检查我的代码:
using (var client = new SshClient("cpanel****", "******", "******"))
{
client.Connect();
con = new MySqlConnection(GetConnectionString());
con.Open();
cmd = new MySqlCommand(String.Format("insert into {0} values (null, ?Parname , ?Parname2, ?Parname3, ?Parname4, ?Parname5, ?Parname6, ?Parname7);", ConfigSettings.ReadSetting("main")), con);
cmd.Parameters.Add("?Parname", MySqlDbType.Double).Value = Math.Round(deciLat, 5);
// ... more parameters
cmd.ExecuteNonQuery();
client.Disconnect();
}
这是一个听起来合理的教程 http://georgelantz.com/2007/09/10/access-mysql-through-ssh-tunnel-in-a-windows-net-application/。
基本思想是与隧道(也称为端口转发)建立SSH连接,然后将MySQL连接指向本地主机。
SSH 隧道将连接到本地主机:XX 重定向到 ssh 服务器端口:YY。 因此,您的端口 YY 将是 mysql 连接端口,在您的连接字符串中,您将使用 localhost:XX。
您使用的SSH库似乎也支持端口转发,因此您也可以使其正常工作。