aboutsummaryrefslogtreecommitdiffstatshomepage
diff options
context:
space:
mode:
-rw-r--r--OpenSim/Services/Connectors/Asset/AssetServicesConnector.cs19
1 files changed, 14 insertions, 5 deletions
diff --git a/OpenSim/Services/Connectors/Asset/AssetServicesConnector.cs b/OpenSim/Services/Connectors/Asset/AssetServicesConnector.cs
index 048ba69..99119d3 100644
--- a/OpenSim/Services/Connectors/Asset/AssetServicesConnector.cs
+++ b/OpenSim/Services/Connectors/Asset/AssetServicesConnector.cs
@@ -51,6 +51,7 @@ namespace OpenSim.Services.Connectors
51 private string m_ServerURI = String.Empty; 51 private string m_ServerURI = String.Empty;
52 private IImprovedAssetCache m_Cache = null; 52 private IImprovedAssetCache m_Cache = null;
53 private int m_retryCounter; 53 private int m_retryCounter;
54 private bool m_inRetries;
54 private List<AssetBase>[] m_sendRetries = new List<AssetBase>[MAXSENDRETRIESLEN]; 55 private List<AssetBase>[] m_sendRetries = new List<AssetBase>[MAXSENDRETRIESLEN];
55 private System.Timers.Timer m_retryTimer; 56 private System.Timers.Timer m_retryTimer;
56 private int m_maxAssetRequestConcurrency = 30; 57 private int m_maxAssetRequestConcurrency = 30;
@@ -114,7 +115,7 @@ namespace OpenSim.Services.Connectors
114 115
115 m_retryTimer = new System.Timers.Timer(); 116 m_retryTimer = new System.Timers.Timer();
116 m_retryTimer.Elapsed += new ElapsedEventHandler(retryCheck); 117 m_retryTimer.Elapsed += new ElapsedEventHandler(retryCheck);
117 m_retryTimer.AutoReset = false; 118 m_retryTimer.AutoReset = true;
118 m_retryTimer.Interval = 60000; 119 m_retryTimer.Interval = 60000;
119 120
120 Uri serverUri = new Uri(m_ServerURI); 121 Uri serverUri = new Uri(m_ServerURI);
@@ -168,6 +169,13 @@ namespace OpenSim.Services.Connectors
168 169
169 protected void retryCheck(object source, ElapsedEventArgs e) 170 protected void retryCheck(object source, ElapsedEventArgs e)
170 { 171 {
172 lock(m_sendRetries)
173 {
174 if(m_inRetries)
175 return;
176 m_inRetries = true;
177 }
178
171 m_retryCounter++; 179 m_retryCounter++;
172 if(m_retryCounter >= 61 ) // avoid overflow 60 is max in use below 180 if(m_retryCounter >= 61 ) // avoid overflow 60 is max in use below
173 m_retryCounter = 1; 181 m_retryCounter = 1;
@@ -218,8 +226,10 @@ namespace OpenSim.Services.Connectors
218 226
219 lock(m_sendRetries) 227 lock(m_sendRetries)
220 { 228 {
221 if(inUse > 0 && !m_retryTimer.Enabled) 229 if(inUse == 0 )
222 m_retryTimer.Start(); 230 m_retryTimer.Stop();
231
232 m_inRetries = false;
223 } 233 }
224 } 234 }
225 235
@@ -512,8 +522,7 @@ namespace OpenSim.Services.Connectors
512 m_queue.Add(asset); 522 m_queue.Add(asset);
513 m_log.WarnFormat("[Assets] Upload failed: {0} type {1} will retry later", 523 m_log.WarnFormat("[Assets] Upload failed: {0} type {1} will retry later",
514 asset.ID.ToString(), asset.Type.ToString()); 524 asset.ID.ToString(), asset.Type.ToString());
515 if(!m_retryTimer.Enabled) 525 m_retryTimer.Start();
516 m_retryTimer.Start();
517 } 526 }
518 } 527 }
519 else 528 else