diff options
Diffstat (limited to 'OpenSim/Framework')
-rw-r--r-- | OpenSim/Framework/Monitoring/BaseStatsCollector.cs | 21 | ||||
-rw-r--r-- | OpenSim/Framework/Monitoring/JobEngine.cs | 111 | ||||
-rw-r--r-- | OpenSim/Framework/Monitoring/Watchdog.cs | 18 | ||||
-rw-r--r-- | OpenSim/Framework/Util.cs | 2 |
4 files changed, 70 insertions, 82 deletions
diff --git a/OpenSim/Framework/Monitoring/BaseStatsCollector.cs b/OpenSim/Framework/Monitoring/BaseStatsCollector.cs index 96536e8..8c2bec6 100644 --- a/OpenSim/Framework/Monitoring/BaseStatsCollector.cs +++ b/OpenSim/Framework/Monitoring/BaseStatsCollector.cs | |||
@@ -56,22 +56,25 @@ namespace OpenSim.Framework.Monitoring | |||
56 | Math.Round((MemoryWatchdog.AverageHeapAllocationRate * 1000) / 1024.0 / 1024, 3)); | 56 | Math.Round((MemoryWatchdog.AverageHeapAllocationRate * 1000) / 1024.0 / 1024, 3)); |
57 | 57 | ||
58 | Process myprocess = Process.GetCurrentProcess(); | 58 | Process myprocess = Process.GetCurrentProcess(); |
59 | if (!myprocess.HasExited) | 59 | // if (!myprocess.HasExited) |
60 | try | ||
60 | { | 61 | { |
61 | myprocess.Refresh(); | 62 | myprocess.Refresh(); |
62 | sb.AppendFormat( | 63 | sb.AppendFormat( |
63 | "Process memory: Physical {0} MB \t Paged {1} MB \t Virtual {2} MB\n", | 64 | "Process memory: Physical {0} MB \t Paged {1} MB \t Virtual {2} MB\n", |
64 | Math.Round(Process.GetCurrentProcess().WorkingSet64 / 1024.0 / 1024.0), | 65 | Math.Round(myprocess.WorkingSet64 / 1024.0 / 1024.0), |
65 | Math.Round(Process.GetCurrentProcess().PagedMemorySize64 / 1024.0 / 1024.0), | 66 | Math.Round(myprocess.PagedMemorySize64 / 1024.0 / 1024.0), |
66 | Math.Round(Process.GetCurrentProcess().VirtualMemorySize64 / 1024.0 / 1024.0)); | 67 | Math.Round(myprocess.VirtualMemorySize64 / 1024.0 / 1024.0)); |
67 | sb.AppendFormat( | 68 | sb.AppendFormat( |
68 | "Peak process memory: Physical {0} MB \t Paged {1} MB \t Virtual {2} MB\n", | 69 | "Peak process memory: Physical {0} MB \t Paged {1} MB \t Virtual {2} MB\n", |
69 | Math.Round(Process.GetCurrentProcess().PeakWorkingSet64 / 1024.0 / 1024.0), | 70 | Math.Round(myprocess.PeakWorkingSet64 / 1024.0 / 1024.0), |
70 | Math.Round(Process.GetCurrentProcess().PeakPagedMemorySize64 / 1024.0 / 1024.0), | 71 | Math.Round(myprocess.PeakPagedMemorySize64 / 1024.0 / 1024.0), |
71 | Math.Round(Process.GetCurrentProcess().PeakVirtualMemorySize64 / 1024.0 / 1024.0)); | 72 | Math.Round(myprocess.PeakVirtualMemorySize64 / 1024.0 / 1024.0)); |
72 | } | 73 | } |
73 | else | 74 | catch |
74 | sb.Append("Process reported as Exited \n"); | 75 | { } |
76 | // else | ||
77 | // sb.Append("Process reported as Exited \n"); | ||
75 | 78 | ||
76 | return sb.ToString(); | 79 | return sb.ToString(); |
77 | } | 80 | } |
diff --git a/OpenSim/Framework/Monitoring/JobEngine.cs b/OpenSim/Framework/Monitoring/JobEngine.cs index 6db9a67..7709f62 100644 --- a/OpenSim/Framework/Monitoring/JobEngine.cs +++ b/OpenSim/Framework/Monitoring/JobEngine.cs | |||
@@ -40,6 +40,8 @@ namespace OpenSim.Framework.Monitoring | |||
40 | 40 | ||
41 | public int LogLevel { get; set; } | 41 | public int LogLevel { get; set; } |
42 | 42 | ||
43 | private object JobLock = new object(); | ||
44 | |||
43 | public string Name { get; private set; } | 45 | public string Name { get; private set; } |
44 | 46 | ||
45 | public string LoggingName { get; private set; } | 47 | public string LoggingName { get; private set; } |
@@ -76,7 +78,7 @@ namespace OpenSim.Framework.Monitoring | |||
76 | /// </remarks> | 78 | /// </remarks> |
77 | private bool m_warnOverMaxQueue = true; | 79 | private bool m_warnOverMaxQueue = true; |
78 | 80 | ||
79 | private BlockingCollection<Job> m_jobQueue; | 81 | private BlockingCollection<Job> m_jobQueue = new BlockingCollection<Job>(new ConcurrentQueue<Job>(), 5000); |
80 | 82 | ||
81 | private CancellationTokenSource m_cancelSource; | 83 | private CancellationTokenSource m_cancelSource; |
82 | 84 | ||
@@ -95,7 +97,7 @@ namespace OpenSim.Framework.Monitoring | |||
95 | 97 | ||
96 | public void Start() | 98 | public void Start() |
97 | { | 99 | { |
98 | lock (this) | 100 | lock (JobLock) |
99 | { | 101 | { |
100 | if (IsRunning) | 102 | if (IsRunning) |
101 | return; | 103 | return; |
@@ -104,7 +106,6 @@ namespace OpenSim.Framework.Monitoring | |||
104 | 106 | ||
105 | m_finishedProcessingAfterStop.Reset(); | 107 | m_finishedProcessingAfterStop.Reset(); |
106 | 108 | ||
107 | m_jobQueue = new BlockingCollection<Job>(new ConcurrentQueue<Job>(), 5000); | ||
108 | m_cancelSource = new CancellationTokenSource(); | 109 | m_cancelSource = new CancellationTokenSource(); |
109 | 110 | ||
110 | WorkManager.StartThread( | 111 | WorkManager.StartThread( |
@@ -120,43 +121,22 @@ namespace OpenSim.Framework.Monitoring | |||
120 | 121 | ||
121 | public void Stop() | 122 | public void Stop() |
122 | { | 123 | { |
123 | lock (this) | 124 | lock (JobLock) |
124 | { | 125 | { |
125 | try | 126 | try |
126 | { | 127 | { |
127 | if (!IsRunning) | 128 | if (!IsRunning) |
128 | return; | 129 | return; |
129 | 130 | ||
130 | IsRunning = false; | 131 | m_log.DebugFormat("[JobEngine] Stopping {0}", Name); |
131 | 132 | ||
132 | int requestsLeft = m_jobQueue.Count; | 133 | IsRunning = false; |
133 | 134 | ||
134 | if (requestsLeft <= 0) | 135 | m_finishedProcessingAfterStop.Reset(); |
135 | { | 136 | if(m_jobQueue.Count <= 0) |
136 | m_cancelSource.Cancel(); | 137 | m_cancelSource.Cancel(); |
137 | } | 138 | |
138 | else | 139 | m_finishedProcessingAfterStop.WaitOne(RequestProcessTimeoutOnStop); |
139 | { | ||
140 | m_log.InfoFormat("[{0}]: Waiting to write {1} events after stop.", LoggingName, requestsLeft); | ||
141 | |||
142 | while (requestsLeft > 0) | ||
143 | { | ||
144 | if (!m_finishedProcessingAfterStop.WaitOne(RequestProcessTimeoutOnStop)) | ||
145 | { | ||
146 | // After timeout no events have been written | ||
147 | if (requestsLeft == m_jobQueue.Count) | ||
148 | { | ||
149 | m_log.WarnFormat( | ||
150 | "[{0}]: No requests processed after {1} ms wait. Discarding remaining {2} requests", | ||
151 | LoggingName, RequestProcessTimeoutOnStop, requestsLeft); | ||
152 | |||
153 | break; | ||
154 | } | ||
155 | } | ||
156 | |||
157 | requestsLeft = m_jobQueue.Count; | ||
158 | } | ||
159 | } | ||
160 | } | 140 | } |
161 | finally | 141 | finally |
162 | { | 142 | { |
@@ -245,48 +225,51 @@ namespace OpenSim.Framework.Monitoring | |||
245 | 225 | ||
246 | private void ProcessRequests() | 226 | private void ProcessRequests() |
247 | { | 227 | { |
248 | try | 228 | while(IsRunning || m_jobQueue.Count > 0) |
249 | { | 229 | { |
250 | while (IsRunning || m_jobQueue.Count > 0) | 230 | try |
251 | { | 231 | { |
252 | try | 232 | CurrentJob = m_jobQueue.Take(m_cancelSource.Token); |
253 | { | 233 | } |
254 | CurrentJob = m_jobQueue.Take(m_cancelSource.Token); | 234 | catch(ObjectDisposedException e) |
255 | } | 235 | { |
256 | catch (ObjectDisposedException e) | 236 | // If we see this whilst not running then it may be due to a race where this thread checks |
237 | // IsRunning after the stopping thread sets it to false and disposes of the cancellation source. | ||
238 | if(IsRunning) | ||
239 | throw e; | ||
240 | else | ||
257 | { | 241 | { |
258 | // If we see this whilst not running then it may be due to a race where this thread checks | 242 | m_log.DebugFormat("[JobEngine] {0} stopping ignoring {1} jobs in queue", |
259 | // IsRunning after the stopping thread sets it to false and disposes of the cancellation source. | 243 | Name,m_jobQueue.Count); |
260 | if (IsRunning) | 244 | break; |
261 | throw e; | ||
262 | else | ||
263 | break; | ||
264 | } | 245 | } |
246 | } | ||
247 | catch(OperationCanceledException) | ||
248 | { | ||
249 | break; | ||
250 | } | ||
265 | 251 | ||
266 | if (LogLevel >= 1) | 252 | if(LogLevel >= 1) |
267 | m_log.DebugFormat("[{0}]: Processing job {1}", LoggingName, CurrentJob.Name); | 253 | m_log.DebugFormat("[{0}]: Processing job {1}",LoggingName,CurrentJob.Name); |
268 | 254 | ||
269 | try | 255 | try |
270 | { | 256 | { |
271 | CurrentJob.Action(); | 257 | CurrentJob.Action(); |
272 | } | 258 | } |
273 | catch (Exception e) | 259 | catch(Exception e) |
274 | { | 260 | { |
275 | m_log.Error( | 261 | m_log.Error( |
276 | string.Format( | 262 | string.Format( |
277 | "[{0}]: Job {1} failed, continuing. Exception ", LoggingName, CurrentJob.Name), e); | 263 | "[{0}]: Job {1} failed, continuing. Exception ",LoggingName,CurrentJob.Name),e); |
278 | } | 264 | } |
279 | 265 | ||
280 | if (LogLevel >= 1) | 266 | if(LogLevel >= 1) |
281 | m_log.DebugFormat("[{0}]: Processed job {1}", LoggingName, CurrentJob.Name); | 267 | m_log.DebugFormat("[{0}]: Processed job {1}",LoggingName,CurrentJob.Name); |
282 | 268 | ||
283 | CurrentJob = null; | 269 | CurrentJob = null; |
284 | } | ||
285 | } | ||
286 | catch (OperationCanceledException) | ||
287 | { | ||
288 | } | 270 | } |
289 | 271 | ||
272 | Watchdog.RemoveThread(false); | ||
290 | m_finishedProcessingAfterStop.Set(); | 273 | m_finishedProcessingAfterStop.Set(); |
291 | } | 274 | } |
292 | 275 | ||
@@ -338,4 +321,4 @@ namespace OpenSim.Framework.Monitoring | |||
338 | } | 321 | } |
339 | } | 322 | } |
340 | } | 323 | } |
341 | } \ No newline at end of file | 324 | } |
diff --git a/OpenSim/Framework/Monitoring/Watchdog.cs b/OpenSim/Framework/Monitoring/Watchdog.cs index 4485a9c..b2c1fb1 100644 --- a/OpenSim/Framework/Monitoring/Watchdog.cs +++ b/OpenSim/Framework/Monitoring/Watchdog.cs | |||
@@ -332,29 +332,31 @@ 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 | 336 | ||
336 | lock (m_threads) | 337 | lock (m_threads) |
337 | { | 338 | { |
338 | // get a copy since we may change m_threads | 339 | // get a copy since we may change m_threads |
339 | List<ThreadWatchdogInfo> threadsInfo = m_threads.Values.ToList(); | 340 | threadsInfo = m_threads.Values.ToList(); |
340 | foreach (ThreadWatchdogInfo threadInfo in threadsInfo) | 341 | |
342 | foreach(ThreadWatchdogInfo threadInfo in threadsInfo) | ||
341 | { | 343 | { |
342 | if (threadInfo.Thread.ThreadState == ThreadState.Stopped) | 344 | if(threadInfo.Thread.ThreadState == ThreadState.Stopped) |
343 | { | 345 | { |
344 | RemoveThread(threadInfo.Thread.ManagedThreadId); | 346 | RemoveThread(threadInfo.Thread.ManagedThreadId); |
345 | 347 | ||
346 | if (callbackInfos == null) | 348 | if(callbackInfos == null) |
347 | callbackInfos = new List<ThreadWatchdogInfo>(); | 349 | callbackInfos = new List<ThreadWatchdogInfo>(); |
348 | 350 | ||
349 | callbackInfos.Add(threadInfo); | 351 | callbackInfos.Add(threadInfo); |
350 | } | 352 | } |
351 | else if (!threadInfo.IsTimedOut && now - threadInfo.LastTick >= threadInfo.Timeout) | 353 | else if(!threadInfo.IsTimedOut && now - threadInfo.LastTick >= threadInfo.Timeout) |
352 | { | 354 | { |
353 | threadInfo.IsTimedOut = true; | 355 | threadInfo.IsTimedOut = true; |
354 | 356 | ||
355 | if (threadInfo.AlarmIfTimeout) | 357 | if(threadInfo.AlarmIfTimeout) |
356 | { | 358 | { |
357 | if (callbackInfos == null) | 359 | if(callbackInfos == null) |
358 | callbackInfos = new List<ThreadWatchdogInfo>(); | 360 | callbackInfos = new List<ThreadWatchdogInfo>(); |
359 | 361 | ||
360 | // Send a copy of the watchdog info to prevent race conditions where the watchdog | 362 | // Send a copy of the watchdog info to prevent race conditions where the watchdog |
@@ -365,7 +367,7 @@ namespace OpenSim.Framework.Monitoring | |||
365 | } | 367 | } |
366 | } | 368 | } |
367 | 369 | ||
368 | if (callbackInfos != null) | 370 | if(callbackInfos != null) |
369 | foreach (ThreadWatchdogInfo callbackInfo in callbackInfos) | 371 | foreach (ThreadWatchdogInfo callbackInfo in callbackInfos) |
370 | callback(callbackInfo); | 372 | callback(callbackInfo); |
371 | } | 373 | } |
diff --git a/OpenSim/Framework/Util.cs b/OpenSim/Framework/Util.cs index 4dafaef..4aad578 100644 --- a/OpenSim/Framework/Util.cs +++ b/OpenSim/Framework/Util.cs | |||
@@ -753,7 +753,7 @@ namespace OpenSim.Framework | |||
753 | newy *= Constants.RegionSize; | 753 | newy *= Constants.RegionSize; |
754 | if (oldy + oldsizey + drawdist < newy) | 754 | if (oldy + oldsizey + drawdist < newy) |
755 | return true; | 755 | return true; |
756 | if (newy + newsizey + drawdist< oldy) | 756 | if (newy + newsizey + drawdist < oldy) |
757 | return true; | 757 | return true; |
758 | 758 | ||
759 | return false; | 759 | return false; |