出於安全考慮,有的時候數據庫服務器只能通過SSH訪問,比如MySql服務裝在了服務器A上,並且A機器只允許B機器才能訪問,而部署環境可能在C機器上,這時候就要C服務器通過B服務器連接A服務器,這時候就需要用到SSH方式連接,需要SSH.NET類庫:
下載地址:https://github.com/sshnet/SSH.NET
代碼如下:
using MySql.Data.MySqlClient; using Renci.SshNet; using System; using System.Collections.Generic; using System.ComponentModel; using System.Data; using System.Drawing; using System.Linq; using System.Text; using System.Threading.Tasks; using System.Windows.Forms; namespace SSHMySql { public partial class Form1 : Form { public Form1() { InitializeComponent(); SSHConnectMySql(); } public void SSHConnectMySql() { string SSHHost = "*.*.*.*"; // SSH地址 int SSHPort = 22; // SSH端口 string SSHUser = "user"; // SSH用戶名 string SSHPassword = "pwd"; // SSH密碼 string sqlIPA = "127.0.0.1";// 映射地址 實際上也可以寫其它的 Linux上的MySql的my.cnf bind-address 可以設成0.0.0.0 或者不設置 string sqlHost = "192.168.1.20"; // mysql安裝的機器IP 也可以是內網IP 比如:192.168.1.20 uint sqlport = 3306; // 數據庫端口及映射端口 string sqlConn = "Database=mysql;Data Source=" + sqlIPA + ";Port=" + sqlport + ";User Id=user;Password=pwd;CharSet=utf8"; string sqlSELECT = "select * from user"; PasswordConnectionInfo connectionInfo = new PasswordConnectionInfo(SSHHost, SSHPort, SSHUser, SSHPassword); connectionInfo.Timeout = TimeSpan.FromSeconds(30); using (var client = new SshClient(connectionInfo)) { try { client.Connect(); if (!client.IsConnected) { MessageBox.Show("SSH connect failed"); } var portFwdL = new ForwardedPortLocal(sqlIPA, sqlport, sqlHost, sqlport); //映射到本地端口 client.AddForwardedPort(portFwdL); portFwdL.Start(); if (!client.IsConnected) { MessageBox.Show("port forwarding failed"); } MySqlConnection conn = new MySqlConnection(sqlConn); MySqlDataAdapter myDataAdapter = new MySqlDataAdapter(); myDataAdapter.SelectCommand = new MySqlCommand(sqlSELECT, conn); try { conn.Open(); DataSet ds = new DataSet(); myDataAdapter.Fill(ds); dataGridView1.DataSource = ds.Tables[0]; } catch (Exception ee) { MessageBox.Show(ee.Message); } finally { conn.Close(); } client.Disconnect(); } catch (Exception ex) { MessageBox.Show(ex.Message); } } } } }
注:如果出現錯誤可以把本地(開發機器)上的MySql服務停止掉。
需要的dll:SSHDLL.rar