* Print out exception information when a mysql asset fetch fails

* Attempt reconnection on fetch and create exceptions.
ThreadPoolClientBranch
Justin Clarke Casey 2008-01-30 17:39:40 +00:00
parent ce07854a45
commit dee0d1e55d
1 changed files with 29 additions and 16 deletions

View File

@ -95,9 +95,12 @@ namespace OpenSim.Framework.Data.MySQL
cmd.Dispose();
}
}
catch (Exception)
catch (Exception e)
{
MainLog.Instance.Warn("ASSETS", "MySql failure fetching asset");
MainLog.Instance.Error(
"ASSETS", "MySql failure fetching asset" + Environment.NewLine + e.ToString()
+ Environment.NewLine + "Attempting reconnection");
_dbConnection.Reconnect();
}
}
return asset;
@ -112,19 +115,29 @@ namespace OpenSim.Framework.Data.MySQL
_dbConnection.Connection);
// need to ensure we dispose
using (cmd)
try
{
MySqlParameter p = cmd.Parameters.Add("?id", MySqlDbType.Binary, 16);
p.Value = asset.FullID.GetBytes();
cmd.Parameters.AddWithValue("?name", asset.Name);
cmd.Parameters.AddWithValue("?description", asset.Description);
cmd.Parameters.AddWithValue("?assetType", asset.Type);
cmd.Parameters.AddWithValue("?invType", asset.InvType);
cmd.Parameters.AddWithValue("?local", asset.Local);
cmd.Parameters.AddWithValue("?temporary", asset.Temporary);
cmd.Parameters.AddWithValue("?data", asset.Data);
cmd.ExecuteNonQuery();
cmd.Dispose();
using (cmd)
{
MySqlParameter p = cmd.Parameters.Add("?id", MySqlDbType.Binary, 16);
p.Value = asset.FullID.GetBytes();
cmd.Parameters.AddWithValue("?name", asset.Name);
cmd.Parameters.AddWithValue("?description", asset.Description);
cmd.Parameters.AddWithValue("?assetType", asset.Type);
cmd.Parameters.AddWithValue("?invType", asset.InvType);
cmd.Parameters.AddWithValue("?local", asset.Local);
cmd.Parameters.AddWithValue("?temporary", asset.Temporary);
cmd.Parameters.AddWithValue("?data", asset.Data);
cmd.ExecuteNonQuery();
cmd.Dispose();
}
}
catch (Exception e)
{
MainLog.Instance.Error(
"ASSETS", "MySql failure creating asset" + Environment.NewLine + e.ToString()
+ Environment.NewLine + "Attempting reconnection");
_dbConnection.Reconnect();
}
}