1. 程式人生 > >C# 連線mysql,即使關閉連線,Mysql狀態依然是sleep

C# 連線mysql,即使關閉連線,Mysql狀態依然是sleep

Aborted connection 245 to db: '資料庫' user: '使用者' host: '--IP地址--' (Got timeout reading communication packets)For more information, see Help and Support Center

參考https://stackoverflow.com/questions/5567097/using-mysqlconnection-in-c-sharp-does-not-close-properly

關閉方法

if (this._Connection != null)
        {
            this._Connection.Close();
        }
        this._Connection.Dispose();
        if (this._Transaction != null)
        {
            this._Transaction.Dispose();
        }

採用-- 顯示連線數--檢視 狀態依然存在 為sleep,執行緒池並沒有真正關閉
SHOW PROCESSLIST

而是等待wait_timeout時間限制時,會自動關閉,然後有系統日誌記錄

 

解決方案,但是有點耗時

 conn._Connection.ClearPoolAsync(conn._Connection);//使用完後,關閉連線池 這樣關閉後,不會出現系統日誌

這樣會關閉所有的閒置連線池

MySqlConnection.ClearPool(MySqlConnection connection)清空關聯的連線池
MySqlConnection.ClearAllPools()清空所有連線池
如果連線正在使用,連線池會做相應標記,等連線關閉時自動燒燬。 

參考https://www.cnblogs.com/supersnowyao/p/8652722.html