2024-09-20 18:27:13 +08:00
|
|
|
|
using MySql.Data.MySqlClient;
|
|
|
|
|
|
|
|
|
|
namespace AxibugEmuOnline.Server.Common
|
|
|
|
|
{
|
2025-01-08 13:30:58 +08:00
|
|
|
|
public static class SQLPool
|
2024-09-20 18:27:13 +08:00
|
|
|
|
{
|
2025-01-08 13:30:58 +08:00
|
|
|
|
static Queue<MySqlConnection> _ConQueue = new Queue<MySqlConnection>();
|
|
|
|
|
static Dictionary<MySqlConnection, Haoyue_PoolTime> _OutOfSQLPool = new Dictionary<MySqlConnection, Haoyue_PoolTime>();
|
|
|
|
|
static Dictionary<string, long> _DicSqlRunFunNum = new Dictionary<string, long>();
|
|
|
|
|
static Dictionary<string, long> _DicTimeOutSqlRunFunNum = new Dictionary<string, long>();
|
|
|
|
|
const int DefaultCount = 1;
|
|
|
|
|
const int MaxLimit = 5;
|
|
|
|
|
static readonly object _sync = new object();
|
|
|
|
|
static MySqlConnectionStringBuilder connBuilder;
|
2024-09-20 18:27:13 +08:00
|
|
|
|
|
|
|
|
|
public static void InitConnMgr()
|
|
|
|
|
{
|
|
|
|
|
connBuilder = new MySqlConnectionStringBuilder();
|
|
|
|
|
connBuilder.Database = Config.cfg.DBName;
|
|
|
|
|
connBuilder.Server = Config.cfg.DBIp;
|
|
|
|
|
connBuilder.UserID = Config.cfg.DBUname;
|
|
|
|
|
connBuilder.Password = Config.cfg.DBPwd;
|
|
|
|
|
connBuilder.Port = Config.cfg.DBPort;
|
|
|
|
|
//connBuilder.MinimumPoolSize = 40u;
|
|
|
|
|
//connBuilder.MaximumPoolSize = 100u;
|
|
|
|
|
connBuilder.Pooling = true;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
Console.WriteLine("SQLPool连接初始化....");
|
|
|
|
|
for (int i = 0; i < DefaultCount; i++)
|
|
|
|
|
{
|
|
|
|
|
MySqlConnection _conn = conn();
|
|
|
|
|
_conn.Open();
|
2025-01-08 13:30:58 +08:00
|
|
|
|
_ConQueue.Enqueue(_conn);
|
2024-09-20 18:27:13 +08:00
|
|
|
|
}
|
2025-01-08 13:30:58 +08:00
|
|
|
|
Console.WriteLine("SQLPool初始化完毕,连接数" + _ConQueue.Count);
|
2024-09-20 18:27:13 +08:00
|
|
|
|
}
|
|
|
|
|
public static MySqlConnection conn()
|
|
|
|
|
{
|
|
|
|
|
return new MySqlConnection(connBuilder.ConnectionString);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public static MySqlConnection DequeueSQLConn(string FuncStr)
|
|
|
|
|
{
|
2025-01-13 14:57:02 +08:00
|
|
|
|
Console.WriteLine($"[DequeueSQLConn]{FuncStr}");
|
2024-09-20 18:27:13 +08:00
|
|
|
|
lock (_sync)
|
|
|
|
|
{
|
|
|
|
|
if (_DicSqlRunFunNum.ContainsKey(FuncStr))
|
|
|
|
|
{
|
|
|
|
|
_DicSqlRunFunNum[FuncStr]++;
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
_DicSqlRunFunNum[FuncStr] = 1L;
|
|
|
|
|
}
|
2025-01-07 00:27:15 +08:00
|
|
|
|
MySqlConnection _conn = null;
|
2025-01-08 13:30:58 +08:00
|
|
|
|
if (_ConQueue.Count < 1)
|
2024-09-20 18:27:13 +08:00
|
|
|
|
{
|
2025-01-08 13:30:58 +08:00
|
|
|
|
Console.WriteLine("[DequeueSQLConn]创建新的SQLPool.Count>" + _ConQueue.Count);
|
2024-09-20 18:27:13 +08:00
|
|
|
|
_conn = conn();
|
|
|
|
|
_conn.Open();
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
2025-01-07 00:27:15 +08:00
|
|
|
|
MySqlConnection temp = null;
|
2025-01-08 13:30:58 +08:00
|
|
|
|
while (_ConQueue.Count > 0)
|
2025-01-07 00:27:15 +08:00
|
|
|
|
{
|
2025-01-08 13:30:58 +08:00
|
|
|
|
Console.WriteLine("[DequeueSQLConn]取出一个SQLCount.Count>" + _ConQueue.Count);
|
|
|
|
|
temp = _ConQueue.Dequeue();
|
2025-01-07 00:27:15 +08:00
|
|
|
|
if (temp.State == System.Data.ConnectionState.Closed)
|
|
|
|
|
{
|
2025-01-08 13:30:58 +08:00
|
|
|
|
Console.WriteLine("[DequeueSQLConn]已经断开SQLCount.Count>" + _ConQueue.Count);
|
2025-01-07 00:27:15 +08:00
|
|
|
|
temp.Dispose();
|
|
|
|
|
temp = null;
|
|
|
|
|
continue;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if (temp != null)
|
|
|
|
|
{
|
|
|
|
|
_conn = temp;
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
Console.WriteLine("[DequeueSQLConn]连接池全部已断开,重新创建连接");
|
|
|
|
|
_conn = conn();
|
|
|
|
|
_conn.Open();
|
|
|
|
|
}
|
2024-09-20 18:27:13 +08:00
|
|
|
|
}
|
2025-01-07 00:27:15 +08:00
|
|
|
|
|
2024-09-20 18:27:13 +08:00
|
|
|
|
_OutOfSQLPool.Add(_conn, new Haoyue_PoolTime
|
|
|
|
|
{
|
|
|
|
|
time = time(),
|
|
|
|
|
FuncStr = FuncStr
|
|
|
|
|
});
|
2025-01-07 00:27:15 +08:00
|
|
|
|
|
2024-09-20 18:27:13 +08:00
|
|
|
|
return _conn;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
public static void EnqueueSQLConn(MySqlConnection BackConn)
|
|
|
|
|
{
|
|
|
|
|
lock (_sync)
|
|
|
|
|
{
|
|
|
|
|
if (_OutOfSQLPool.ContainsKey(BackConn))
|
|
|
|
|
{
|
|
|
|
|
_OutOfSQLPool.Remove(BackConn);
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
Console.WriteLine("出队遗漏的数据出现了!");
|
|
|
|
|
}
|
2025-01-08 13:30:58 +08:00
|
|
|
|
if (_ConQueue.Count > MaxLimit)
|
2024-09-20 18:27:13 +08:00
|
|
|
|
{
|
2025-01-08 13:30:58 +08:00
|
|
|
|
Console.WriteLine("已经不需要回收了,多余了,SQLPool.Count>" + _ConQueue.Count);
|
2024-09-20 18:27:13 +08:00
|
|
|
|
BackConn.Close();
|
2025-01-07 00:27:15 +08:00
|
|
|
|
BackConn.Dispose();
|
2024-09-20 18:27:13 +08:00
|
|
|
|
BackConn = null;
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
2025-01-08 13:30:58 +08:00
|
|
|
|
_ConQueue.Enqueue(BackConn);
|
|
|
|
|
Console.WriteLine("回收SQLPool.Count>" + _ConQueue.Count);
|
2024-09-20 18:27:13 +08:00
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public static void CheckPoolTimeOut()
|
|
|
|
|
{
|
|
|
|
|
lock (_sync)
|
|
|
|
|
{
|
|
|
|
|
long now = time();
|
|
|
|
|
List<MySqlConnection> removeTemp = new List<MySqlConnection>();
|
|
|
|
|
foreach (KeyValuePair<MySqlConnection, Haoyue_PoolTime> o2 in _OutOfSQLPool)
|
|
|
|
|
{
|
|
|
|
|
if (now - o2.Value.time >= 120)
|
|
|
|
|
{
|
|
|
|
|
if (_DicTimeOutSqlRunFunNum.ContainsKey(o2.Value.FuncStr))
|
|
|
|
|
{
|
|
|
|
|
_DicTimeOutSqlRunFunNum[o2.Value.FuncStr]++;
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
_DicTimeOutSqlRunFunNum[o2.Value.FuncStr] = 1L;
|
|
|
|
|
}
|
2025-01-08 13:30:58 +08:00
|
|
|
|
if (_ConQueue.Count > MaxLimit)
|
2024-09-20 18:27:13 +08:00
|
|
|
|
{
|
2025-01-08 13:30:58 +08:00
|
|
|
|
Console.WriteLine("[超时回收]" + o2.Value.FuncStr + "已经不需要回收了,多余了,SQLPool.Count>" + _ConQueue.Count);
|
2024-09-20 18:27:13 +08:00
|
|
|
|
o2.Key.Close();
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
2025-01-08 13:30:58 +08:00
|
|
|
|
Console.WriteLine("[超时回收]" + o2.Value.FuncStr + "回收SQLPool.Count>" + _ConQueue.Count);
|
|
|
|
|
_ConQueue.Enqueue(o2.Key);
|
2024-09-20 18:27:13 +08:00
|
|
|
|
}
|
|
|
|
|
removeTemp.Add(o2.Key);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
if (removeTemp.Count() <= 0)
|
|
|
|
|
{
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
foreach (MySqlConnection o in removeTemp)
|
|
|
|
|
{
|
|
|
|
|
if (_OutOfSQLPool.ContainsKey(o))
|
|
|
|
|
{
|
|
|
|
|
_OutOfSQLPool.Remove(o);
|
|
|
|
|
Console.WriteLine("[超时回收]_OutOfSQLPool清理");
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
Console.WriteLine("[超时回收]_OutOfSQLPool清理异常???????");
|
|
|
|
|
}
|
|
|
|
|
}
|
2025-01-08 13:30:58 +08:00
|
|
|
|
Console.WriteLine("[超时回收]处理结束SQLPool.Count>" + _ConQueue.Count);
|
2024-09-20 18:27:13 +08:00
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
public static long time()
|
|
|
|
|
{
|
|
|
|
|
return Convert.ToInt64((DateTime.UtcNow - new DateTime(1970, 1, 1, 0, 0, 0, 0)).TotalSeconds);
|
|
|
|
|
}
|
|
|
|
|
public static void GetPoolState()
|
|
|
|
|
{
|
|
|
|
|
Console.WriteLine("-----------------查询统计-----------------");
|
|
|
|
|
foreach (KeyValuePair<string, long> dic2 in _DicSqlRunFunNum)
|
|
|
|
|
{
|
|
|
|
|
Console.WriteLine(dic2.Key + ":" + dic2.Value);
|
|
|
|
|
}
|
|
|
|
|
Console.WriteLine("-----------------超时统计-----------------");
|
|
|
|
|
foreach (KeyValuePair<string, long> dic in _DicTimeOutSqlRunFunNum)
|
|
|
|
|
{
|
|
|
|
|
Console.WriteLine(dic.Key + ":" + dic.Value);
|
|
|
|
|
}
|
|
|
|
|
Console.WriteLine("------------------------------------------");
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public class Haoyue_PoolTime
|
|
|
|
|
{
|
|
|
|
|
public long time { get; set; }
|
|
|
|
|
public string FuncStr { get; set; }
|
|
|
|
|
}
|
|
|
|
|
}
|