aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/OpenSim/Framework/Monitoring
diff options
context:
space:
mode:
Diffstat (limited to '')
-rw-r--r--OpenSim/Framework/Monitoring/ChecksManager.cs45
-rw-r--r--OpenSim/Framework/Monitoring/StatsManager.cs54
-rw-r--r--OpenSim/Framework/Monitoring/Watchdog.cs16
3 files changed, 54 insertions, 61 deletions
diff --git a/OpenSim/Framework/Monitoring/ChecksManager.cs b/OpenSim/Framework/Monitoring/ChecksManager.cs
index e4a7f8c..ff3b041 100644
--- a/OpenSim/Framework/Monitoring/ChecksManager.cs
+++ b/OpenSim/Framework/Monitoring/ChecksManager.cs
@@ -132,8 +132,8 @@ namespace OpenSim.Framework.Monitoring
132 /// <returns></returns> 132 /// <returns></returns>
133 public static bool RegisterCheck(Check check) 133 public static bool RegisterCheck(Check check)
134 { 134 {
135 SortedDictionary<string, SortedDictionary<string, Check>> category = null, newCategory; 135 SortedDictionary<string, SortedDictionary<string, Check>> category = null;
136 SortedDictionary<string, Check> container = null, newContainer; 136 SortedDictionary<string, Check> container = null;
137 137
138 lock (RegisteredChecks) 138 lock (RegisteredChecks)
139 { 139 {
@@ -146,19 +146,15 @@ namespace OpenSim.Framework.Monitoring
146 // We take a copy-on-write approach here of replacing dictionaries when keys are added or removed. 146 // We take a copy-on-write approach here of replacing dictionaries when keys are added or removed.
147 // This means that we don't need to lock or copy them on iteration, which will be a much more 147 // This means that we don't need to lock or copy them on iteration, which will be a much more
148 // common operation after startup. 148 // common operation after startup.
149 if (container != null) 149 if (container == null)
150 newContainer = new SortedDictionary<string, Check>(container); 150 container = new SortedDictionary<string, Check>();
151 else
152 newContainer = new SortedDictionary<string, Check>();
153 151
154 if (category != null) 152 if (category == null)
155 newCategory = new SortedDictionary<string, SortedDictionary<string, Check>>(category); 153 category = new SortedDictionary<string, SortedDictionary<string, Check>>();
156 else
157 newCategory = new SortedDictionary<string, SortedDictionary<string, Check>>();
158 154
159 newContainer[check.ShortName] = check; 155 container[check.ShortName] = check;
160 newCategory[check.Container] = newContainer; 156 category[check.Container] = container;
161 RegisteredChecks[check.Category] = newCategory; 157 RegisteredChecks[check.Category] = category;
162 } 158 }
163 159
164 return true; 160 return true;
@@ -171,23 +167,24 @@ namespace OpenSim.Framework.Monitoring
171 /// <returns></returns> 167 /// <returns></returns>
172 public static bool DeregisterCheck(Check check) 168 public static bool DeregisterCheck(Check check)
173 { 169 {
174 SortedDictionary<string, SortedDictionary<string, Check>> category = null, newCategory; 170 SortedDictionary<string, SortedDictionary<string, Check>> category = null;
175 SortedDictionary<string, Check> container = null, newContainer; 171 SortedDictionary<string, Check> container = null;
176 172
177 lock (RegisteredChecks) 173 lock (RegisteredChecks)
178 { 174 {
179 if (!TryGetCheckParents(check, out category, out container)) 175 if (!TryGetCheckParents(check, out category, out container))
180 return false; 176 return false;
181 177
182 newContainer = new SortedDictionary<string, Check>(container); 178 if(container != null)
183 newContainer.Remove(check.ShortName); 179 {
184 180 container.Remove(check.ShortName);
185 newCategory = new SortedDictionary<string, SortedDictionary<string, Check>>(category); 181 if(category != null && container.Count == 0)
186 newCategory.Remove(check.Container); 182 {
187 183 category.Remove(check.Container);
188 newCategory[check.Container] = newContainer; 184 if(category.Count == 0)
189 RegisteredChecks[check.Category] = newCategory; 185 RegisteredChecks.Remove(check.Category);
190 186 }
187 }
191 return true; 188 return true;
192 } 189 }
193 } 190 }
diff --git a/OpenSim/Framework/Monitoring/StatsManager.cs b/OpenSim/Framework/Monitoring/StatsManager.cs
index 8787ea0..30926d8 100644
--- a/OpenSim/Framework/Monitoring/StatsManager.cs
+++ b/OpenSim/Framework/Monitoring/StatsManager.cs
@@ -80,8 +80,7 @@ namespace OpenSim.Framework.Monitoring
80 + "'all' will show all statistics.\n" 80 + "'all' will show all statistics.\n"
81 + "A <category> name will show statistics from that category.\n" 81 + "A <category> name will show statistics from that category.\n"
82 + "A <category>.<container> name will show statistics from that category in that container.\n" 82 + "A <category>.<container> name will show statistics from that category in that container.\n"
83 + "More than one name can be given separated by spaces.\n" 83 + "More than one name can be given separated by spaces.\n",
84 + "THIS STATS FACILITY IS EXPERIMENTAL AND DOES NOT YET CONTAIN ALL STATS",
85 HandleShowStatsCommand); 84 HandleShowStatsCommand);
86 85
87 console.Commands.AddCommand( 86 console.Commands.AddCommand(
@@ -91,7 +90,6 @@ namespace OpenSim.Framework.Monitoring
91 "show stats [list|all|(<category>[.<container>])+", 90 "show stats [list|all|(<category>[.<container>])+",
92 "Alias for 'stats show' command", 91 "Alias for 'stats show' command",
93 HandleShowStatsCommand); 92 HandleShowStatsCommand);
94
95 StatsLogger.RegisterConsoleCommands(console); 93 StatsLogger.RegisterConsoleCommands(console);
96 } 94 }
97 95
@@ -361,8 +359,8 @@ namespace OpenSim.Framework.Monitoring
361 /// <returns></returns> 359 /// <returns></returns>
362 public static bool RegisterStat(Stat stat) 360 public static bool RegisterStat(Stat stat)
363 { 361 {
364 SortedDictionary<string, SortedDictionary<string, Stat>> category = null, newCategory; 362 SortedDictionary<string, SortedDictionary<string, Stat>> category = null;
365 SortedDictionary<string, Stat> container = null, newContainer; 363 SortedDictionary<string, Stat> container = null;
366 364
367 lock (RegisteredStats) 365 lock (RegisteredStats)
368 { 366 {
@@ -372,22 +370,15 @@ namespace OpenSim.Framework.Monitoring
372 if (TryGetStatParents(stat, out category, out container)) 370 if (TryGetStatParents(stat, out category, out container))
373 return false; 371 return false;
374 372
375 // We take a copy-on-write approach here of replacing dictionaries when keys are added or removed. 373 if (container == null)
376 // This means that we don't need to lock or copy them on iteration, which will be a much more 374 container = new SortedDictionary<string, Stat>();
377 // common operation after startup.
378 if (container != null)
379 newContainer = new SortedDictionary<string, Stat>(container);
380 else
381 newContainer = new SortedDictionary<string, Stat>();
382 375
383 if (category != null) 376 if (category == null)
384 newCategory = new SortedDictionary<string, SortedDictionary<string, Stat>>(category); 377 category = new SortedDictionary<string, SortedDictionary<string, Stat>>();
385 else
386 newCategory = new SortedDictionary<string, SortedDictionary<string, Stat>>();
387 378
388 newContainer[stat.ShortName] = stat; 379 container[stat.ShortName] = stat;
389 newCategory[stat.Container] = newContainer; 380 category[stat.Container] = container;
390 RegisteredStats[stat.Category] = newCategory; 381 RegisteredStats[stat.Category] = category;
391 } 382 }
392 383
393 return true; 384 return true;
@@ -400,23 +391,24 @@ namespace OpenSim.Framework.Monitoring
400 /// <returns></returns> 391 /// <returns></returns>
401 public static bool DeregisterStat(Stat stat) 392 public static bool DeregisterStat(Stat stat)
402 { 393 {
403 SortedDictionary<string, SortedDictionary<string, Stat>> category = null, newCategory; 394 SortedDictionary<string, SortedDictionary<string, Stat>> category = null;
404 SortedDictionary<string, Stat> container = null, newContainer; 395 SortedDictionary<string, Stat> container = null;
405 396
406 lock (RegisteredStats) 397 lock (RegisteredStats)
407 { 398 {
408 if (!TryGetStatParents(stat, out category, out container)) 399 if (!TryGetStatParents(stat, out category, out container))
409 return false; 400 return false;
410 401
411 newContainer = new SortedDictionary<string, Stat>(container); 402 if(container != null)
412 newContainer.Remove(stat.ShortName); 403 {
413 404 container.Remove(stat.ShortName);
414 newCategory = new SortedDictionary<string, SortedDictionary<string, Stat>>(category); 405 if(category != null && container.Count == 0)
415 newCategory.Remove(stat.Container); 406 {
416 407 category.Remove(stat.Container);
417 newCategory[stat.Container] = newContainer; 408 if(category.Count == 0)
418 RegisteredStats[stat.Category] = newCategory; 409 RegisteredStats.Remove(stat.Category);
419 410 }
411 }
420 return true; 412 return true;
421 } 413 }
422 } 414 }
diff --git a/OpenSim/Framework/Monitoring/Watchdog.cs b/OpenSim/Framework/Monitoring/Watchdog.cs
index b2c1fb1..ff439f5 100644
--- a/OpenSim/Framework/Monitoring/Watchdog.cs
+++ b/OpenSim/Framework/Monitoring/Watchdog.cs
@@ -332,18 +332,18 @@ namespace OpenSim.Framework.Monitoring
332 if (callback != null) 332 if (callback != null)
333 { 333 {
334 List<ThreadWatchdogInfo> callbackInfos = null; 334 List<ThreadWatchdogInfo> callbackInfos = null;
335 List<ThreadWatchdogInfo> threadsInfo; 335 List<ThreadWatchdogInfo> threadsToRemove = null;
336 336
337 lock (m_threads) 337 lock (m_threads)
338 { 338 {
339 // get a copy since we may change m_threads 339 foreach(ThreadWatchdogInfo threadInfo in m_threads.Values)
340 threadsInfo = m_threads.Values.ToList();
341
342 foreach(ThreadWatchdogInfo threadInfo in threadsInfo)
343 { 340 {
344 if(threadInfo.Thread.ThreadState == ThreadState.Stopped) 341 if(threadInfo.Thread.ThreadState == ThreadState.Stopped)
345 { 342 {
346 RemoveThread(threadInfo.Thread.ManagedThreadId); 343 if(threadsToRemove == null)
344 threadsToRemove = new List<ThreadWatchdogInfo>();
345
346 threadsToRemove.Add(threadInfo);
347 347
348 if(callbackInfos == null) 348 if(callbackInfos == null)
349 callbackInfos = new List<ThreadWatchdogInfo>(); 349 callbackInfos = new List<ThreadWatchdogInfo>();
@@ -365,6 +365,10 @@ namespace OpenSim.Framework.Monitoring
365 } 365 }
366 } 366 }
367 } 367 }
368
369 if(threadsToRemove != null)
370 foreach(ThreadWatchdogInfo twi in threadsToRemove)
371 RemoveThread(twi.Thread.ManagedThreadId);
368 } 372 }
369 373
370 if(callbackInfos != null) 374 if(callbackInfos != null)