无法使用ssh客户端连接到mysql数据库

时间:2012-05-30 16:33:25

标签: c# mysql database connection-string

我想通过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();
           }

1 个答案:

答案 0 :(得分:1)

这是一个合理的教程http://georgelantz.com/2007/09/10/access-mysql-through-ssh-tunnel-in-a-windows-net-application/

基本思想是建立与隧道的SSH连接(也称为端口转发),然后将MySQL连接指向localhost。

SSH隧道将连接重定向到localhost:XX到ssh服务器端口:YY。所以你的端口YY将是mysql连接端口,在你的连接字符串中你将使用localhost:XX。

您正在使用的SSH库似乎也支持端口转发,因此您也可以将其工作。