欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

C#使用Socket快速判斷數(shù)據(jù)庫(kù)連接是否正常的方法

 更新時(shí)間:2015年04月27日 14:52:51   作者:依山帶水  
這篇文章主要介紹了C#使用Socket快速判斷數(shù)據(jù)庫(kù)連接是否正常的方法,涉及C#中socket操作的相關(guān)技巧,非常具有實(shí)用價(jià)值,需要的朋友可以參考下

本文實(shí)例講述了C#使用Socket快速判斷數(shù)據(jù)庫(kù)連接是否正常的方法。分享給大家供大家參考。具體分析如下:

大家在做項(xiàng)目的時(shí)候,一般都是和數(shù)據(jù)庫(kù)有關(guān)的。而相信許多人在用代碼打開(kāi)數(shù)據(jù)庫(kù)的時(shí)候,沒(méi)有判斷數(shù)據(jù)庫(kù)連接是否成功。如果寫(xiě)對(duì)了還好,但是出錯(cuò)了,會(huì)等老長(zhǎng)時(shí)間(默認(rèn)15s,不過(guò) 實(shí)際響應(yīng) 可能會(huì)更長(zhǎng))。而且還會(huì)出現(xiàn)卡死的情況,給用戶(hù)的感覺(jué)就會(huì)變得非常差勁。所以快速判斷數(shù)據(jù)庫(kù)連接是否成功,就顯得尤為重要了。
 
一般情況下,如果連接字符串正確,那么連接到數(shù)據(jù)庫(kù)用的時(shí)間一般在5s以?xún)?nèi)。所以我們可以在連接字符串的最后添加一個(gè)等待時(shí)間:timeout。如:

復(fù)制代碼 代碼如下:
string strCon = "Data Source=192.168.24.66;Initial Catalog=master;User ID=sa;password=123456;Connection Timeout=5";

如果連接不成功,應(yīng)該在5-8s內(nèi)做出回應(yīng)。但是并不能確定一定是連接字符串出錯(cuò)。如果大量人訪問(wèn)的話,很可能會(huì)出現(xiàn)等待時(shí)間超過(guò)5s的情況。而且,如果連接不成功,我們依舊最起碼得等待5秒。等待的滋味是不好受的,用戶(hù)一定會(huì)給你一個(gè)叉叉,所以我們還需要用其他辦法來(lái)快速判斷。

這里我們用Socket來(lái)實(shí)現(xiàn)這一功能。(至于Socket是什么,有興趣的朋友可以自己查查資料)

先用Socket來(lái)判斷與服務(wù)器是否連接成功,然后在進(jìn)行數(shù)據(jù)庫(kù)操作。

#region 采用Socket方式,測(cè)試服務(wù)器連接 
/// <summary> 
/// 采用Socket方式,測(cè)試服務(wù)器連接 
/// </summary> 
/// <param name="host">服務(wù)器主機(jī)名或IP</param> 
/// <param name="port">端口號(hào)</param> 
/// <param name="millisecondsTimeout">等待時(shí)間:毫秒</param> 
/// <returns></returns> 
public static bool TestConnection(string host, int port, int millisecondsTimeout) 
{ 
  TcpClient client = new TcpClient(); 
  try 
  { 
   var ar = client.BeginConnect(host, port, null, null); 
   ar.AsyncWaitHandle.WaitOne(millisecondsTimeout); 
   return client.Connected; 
  } 
  catch (Exception e) 
  { 
   throw e; 
  } 
  finally 
  { 
   client.Close(); 
  } 
} 
#endregion

下面是數(shù)據(jù)庫(kù)的操作,可以根據(jù)自己的情況修改。

/// <summary> 
/// 數(shù)據(jù)庫(kù)連接操作,可替換為你自己的程序 
/// </summary> 
/// <param name="ConnectionString">連接字符串</param> 
/// <returns></returns> 
private static bool TestConnection(string ConnectionString) 
{ 
  bool result = true; 
  try 
  { 
   SqlConnection m_myConnection = new SqlConnection(ConnectionString); 
   m_myConnection.Open(); 
   //數(shù)據(jù)庫(kù)操作...... 
   m_myConnection.Close(); 
  } 
  catch (Exception ex) 
  { 
   System.Diagnostics.Debug.WriteLine(ex.ToString()); 
   result = false; 
  } 
  return result; 
}

我這里用winForm來(lái)測(cè)試的。

private void btnSocket_Click(object sender, EventArgs e) 
{ 
  string strCon = "Data Source=192.168.24.566;Initial Catalog=qmaster;User ID=sa;password=123456"; 
  string[] s=strCon.Split(';'); 
  s = s[0].Split('='); 
  //獲取IP 
  string strIP =s[1]; 
  //發(fā)送數(shù)據(jù),判斷是否連接到指定ip 
  if (TestConnection(strIP , 1433, 500)) 
  { 
   //連接成功 
   MessageBox.Show("Socket Link Succeed","連接服務(wù)器"); 
   // 數(shù)據(jù)庫(kù)操作,我這里用了連接測(cè)試??筛鶕?jù)你的系統(tǒng)自行修改 
   if (TestConnection(strCon)) 
    MessageBox.Show("Sql Link Succeed","連接數(shù)據(jù)庫(kù)"); 
   else 
    MessageBox.Show("Sql Link Failed", "連接數(shù)據(jù)庫(kù)"); 
  } 
  else 
   MessageBox.Show("Socket Link Failed","連接服務(wù)器"); 
}

用Socket來(lái)測(cè)試是否連接到服務(wù)器非常方便,也非??旖?,不用讓用戶(hù)等待那么長(zhǎng)時(shí)間,而且這樣做還可以知道是服務(wù)器地址出錯(cuò),還是數(shù)據(jù)庫(kù)出錯(cuò)。經(jīng)測(cè)試,如果數(shù)據(jù)庫(kù)地址出錯(cuò),在1-3s內(nèi)即可反饋出結(jié)果。提示用戶(hù)“Socket Link Failed”。而數(shù)據(jù)庫(kù)名錯(cuò)誤,則只提示“Sql Link Failed”。

這么方便、快捷、高效、易排錯(cuò)的方法,你會(huì)不會(huì)錯(cuò)過(guò),我不知道,反正我是不會(huì)錯(cuò)過(guò)了!

希望本文所述對(duì)大家的C#程序設(shè)計(jì)有所幫助。

相關(guān)文章

最新評(píng)論