无法使用 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();
           }

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

这是一个听起来合理的教程 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库似乎也支持端口转发,因此您也可以使其正常工作。