Added locks around MySql.Open() which was causing issues with concurrency againt the connection pool.
There was a need to serialize access to the connection pool.
This commit is contained in:
@@ -25,32 +25,35 @@ namespace MarketData.Utils
|
|||||||
/// <returns>SqlConnection or null on error.</returns>
|
/// <returns>SqlConnection or null on error.</returns>
|
||||||
public static MySqlConnection CreateMySqlConnection(string datasource,string port,string database,string username,string password)
|
public static MySqlConnection CreateMySqlConnection(string datasource,string port,string database,string username,string password)
|
||||||
{
|
{
|
||||||
try
|
lock(typeof(SqlUtils))
|
||||||
{
|
{
|
||||||
String connectionString=null;
|
try
|
||||||
StringBuilder sb=new StringBuilder();
|
{
|
||||||
sb.Append("server=").Append(datasource).Append("; ");
|
String connectionString=null;
|
||||||
sb.Append("user id=").Append(username).Append("; ");
|
StringBuilder sb=new StringBuilder();
|
||||||
sb.Append("password=").Append(password).Append("; ");
|
sb.Append("server=").Append(datasource).Append("; ");
|
||||||
sb.Append("database=").Append(database).Append("; ");
|
sb.Append("user id=").Append(username).Append("; ");
|
||||||
sb.Append("SslMode=").Append("None").Append("; ");
|
sb.Append("password=").Append(password).Append("; ");
|
||||||
sb.Append("pooling=").Append("true").Append(";");
|
sb.Append("database=").Append(database).Append("; ");
|
||||||
sb.Append("MinimumPoolSize=").Append(MIN_POOL_SIZE).Append(";");
|
sb.Append("SslMode=").Append("None").Append("; ");
|
||||||
sb.Append("MaximumPoolSize=").Append(MAX_POOL_SIZE).Append(";");
|
sb.Append("pooling=").Append("true").Append(";");
|
||||||
sb.Append("allow user variables=").Append("true").Append("; ");
|
sb.Append("MinimumPoolSize=").Append(MIN_POOL_SIZE).Append(";");
|
||||||
sb.Append("default command timeout=").Append("300").Append("; ");
|
sb.Append("MaximumPoolSize=").Append(MAX_POOL_SIZE).Append(";");
|
||||||
sb.Append("connect timeout=").Append("300").Append(";");
|
sb.Append("allow user variables=").Append("true").Append("; ");
|
||||||
sb.Append("charset=").Append("utf8mb4").Append(" ");
|
sb.Append("default command timeout=").Append("300").Append("; ");
|
||||||
connectionString=sb.ToString();
|
sb.Append("connect timeout=").Append("300").Append(";");
|
||||||
MySqlConnection connection=new MySqlConnection(connectionString);
|
sb.Append("charset=").Append("utf8mb4").Append(" ");
|
||||||
connection.Open();
|
connectionString=sb.ToString();
|
||||||
//SetConnectionCollation(connection);
|
MySqlConnection connection=new MySqlConnection(connectionString);
|
||||||
return connection;
|
connection.Open();
|
||||||
}
|
//SetConnectionCollation(connection);
|
||||||
catch(SqlException exception)
|
return connection;
|
||||||
{
|
}
|
||||||
MDTrace.WriteLine(LogLevel.DEBUG,exception.ToString());
|
catch(SqlException exception)
|
||||||
return null;
|
{
|
||||||
|
MDTrace.WriteLine(LogLevel.DEBUG,exception.ToString());
|
||||||
|
return null;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
/// <summary>CreateSqlConnection - Creates an SQL connection.</summary>
|
/// <summary>CreateSqlConnection - Creates an SQL connection.</summary>
|
||||||
@@ -58,51 +61,37 @@ namespace MarketData.Utils
|
|||||||
/// <returns>SqlConnection or null on error.</returns>
|
/// <returns>SqlConnection or null on error.</returns>
|
||||||
public static MySqlConnection CreateMySqlConnection(DataSourceEx datasource)
|
public static MySqlConnection CreateMySqlConnection(DataSourceEx datasource)
|
||||||
{
|
{
|
||||||
try
|
lock(typeof(SqlUtils))
|
||||||
{
|
{
|
||||||
String connectionString=null;
|
try
|
||||||
StringBuilder sb=new StringBuilder();
|
{
|
||||||
sb.Append("server=").Append(datasource.Datasource).Append("; ");
|
String connectionString=null;
|
||||||
sb.Append("user id=").Append(datasource.Username).Append("; ");
|
StringBuilder sb=new StringBuilder();
|
||||||
sb.Append("password=").Append(datasource.Password).Append("; ");
|
sb.Append("server=").Append(datasource.Datasource).Append("; ");
|
||||||
sb.Append("database=").Append(datasource.Database).Append("; ");
|
sb.Append("user id=").Append(datasource.Username).Append("; ");
|
||||||
sb.Append("SslMode=").Append("None").Append("; ");
|
sb.Append("password=").Append(datasource.Password).Append("; ");
|
||||||
sb.Append("pooling=").Append("true").Append(";");
|
sb.Append("database=").Append(datasource.Database).Append("; ");
|
||||||
sb.Append("allow user variables=").Append("true").Append("; ");
|
sb.Append("SslMode=").Append("None").Append("; ");
|
||||||
sb.Append("default command timeout=").Append("300").Append("; ");
|
sb.Append("pooling=").Append("true").Append(";");
|
||||||
sb.Append("connect timeout=").Append("300").Append(";");
|
sb.Append("allow user variables=").Append("true").Append("; ");
|
||||||
sb.Append("MinimumPoolSize=").Append(MIN_POOL_SIZE).Append(";");
|
sb.Append("default command timeout=").Append("300").Append("; ");
|
||||||
sb.Append("MaximumPoolSize=").Append(MAX_POOL_SIZE).Append(";");
|
sb.Append("connect timeout=").Append("300").Append(";");
|
||||||
sb.Append("charset=").Append("utf8mb4").Append(" ");
|
sb.Append("MinimumPoolSize=").Append(MIN_POOL_SIZE).Append(";");
|
||||||
connectionString=sb.ToString();
|
sb.Append("MaximumPoolSize=").Append(MAX_POOL_SIZE).Append(";");
|
||||||
MySqlConnection connection=new MySqlConnection(connectionString);
|
sb.Append("charset=").Append("utf8mb4").Append(" ");
|
||||||
connection.Open();
|
connectionString=sb.ToString();
|
||||||
//SetConnectionCollation(connection);
|
MySqlConnection connection=new MySqlConnection(connectionString);
|
||||||
return connection;
|
connection.Open();
|
||||||
}
|
return connection;
|
||||||
catch(SqlException exception)
|
}
|
||||||
{
|
catch(SqlException exception)
|
||||||
MDTrace.WriteLine(LogLevel.DEBUG,exception.ToString());
|
{
|
||||||
return null;
|
MDTrace.WriteLine(LogLevel.DEBUG,exception.ToString());
|
||||||
|
return null;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
/// <summary>SetConnectionCollation - Set database connection collation. Have to do for MySql 8.0.33</summary>
|
|
||||||
/// <returns>void.</returns>
|
|
||||||
//public static void SetConnectionCollation(MySqlConnection sqlConnection)
|
|
||||||
//{
|
|
||||||
// MySqlCommand sqlCommand=null;
|
|
||||||
// try
|
|
||||||
// {
|
|
||||||
// sqlCommand=sqlConnection.CreateCommand();
|
|
||||||
// sqlCommand.CommandText="SET collation_connection='utf8mb4_general_ci';";
|
|
||||||
// sqlCommand.ExecuteNonQuery();
|
|
||||||
// sqlCommand.Dispose();
|
|
||||||
// }
|
|
||||||
// catch(Exception exception)
|
|
||||||
// {
|
|
||||||
// MDTrace.WriteLine(LogLevel.DEBUG,exception.ToString());
|
|
||||||
// }
|
|
||||||
//}
|
|
||||||
public static String FormatDate(DateTime dateTime)
|
public static String FormatDate(DateTime dateTime)
|
||||||
{
|
{
|
||||||
return Utility.DateTimeToStringYYYYHMMHDD(dateTime);
|
return Utility.DateTimeToStringYYYYHMMHDD(dateTime);
|
||||||
|
|||||||
Reference in New Issue
Block a user