diff options
Diffstat (limited to '')
-rw-r--r-- | OpenSim/Framework/Servers/HttpServer/PollServiceRequestManager.cs | 25 |
1 files changed, 14 insertions, 11 deletions
diff --git a/OpenSim/Framework/Servers/HttpServer/PollServiceRequestManager.cs b/OpenSim/Framework/Servers/HttpServer/PollServiceRequestManager.cs index cb0c41f..94a9490 100644 --- a/OpenSim/Framework/Servers/HttpServer/PollServiceRequestManager.cs +++ b/OpenSim/Framework/Servers/HttpServer/PollServiceRequestManager.cs | |||
@@ -194,17 +194,20 @@ namespace OpenSim.Framework.Servers.HttpServer | |||
194 | { | 194 | { |
195 | m_running = false; | 195 | m_running = false; |
196 | 196 | ||
197 | Thread.Sleep(1000); // let the world move | 197 | Thread.Sleep(100); // let the world move |
198 | 198 | ||
199 | foreach (Thread t in m_workerThreads) | 199 | foreach (Thread t in m_workerThreads) |
200 | Watchdog.AbortThread(t.ManagedThreadId); | 200 | Watchdog.AbortThread(t.ManagedThreadId); |
201 | 201 | ||
202 | m_threadPool.Shutdown(); | ||
203 | |||
202 | // any entry in m_bycontext should have a active request on the other queues | 204 | // any entry in m_bycontext should have a active request on the other queues |
203 | // so just delete contents to easy GC | 205 | // so just delete contents to easy GC |
204 | foreach (Queue<PollServiceHttpRequest> qu in m_bycontext.Values) | 206 | foreach (Queue<PollServiceHttpRequest> qu in m_bycontext.Values) |
205 | qu.Clear(); | 207 | qu.Clear(); |
206 | m_bycontext.Clear(); | 208 | m_bycontext.Clear(); |
207 | 209 | ||
210 | /* | ||
208 | try | 211 | try |
209 | { | 212 | { |
210 | foreach (PollServiceHttpRequest req in m_retryRequests) | 213 | foreach (PollServiceHttpRequest req in m_retryRequests) |
@@ -217,8 +220,9 @@ namespace OpenSim.Framework.Servers.HttpServer | |||
217 | } | 220 | } |
218 | 221 | ||
219 | PollServiceHttpRequest wreq; | 222 | PollServiceHttpRequest wreq; |
223 | */ | ||
220 | m_retryRequests.Clear(); | 224 | m_retryRequests.Clear(); |
221 | 225 | /* | |
222 | while (m_requests.Count() > 0) | 226 | while (m_requests.Count() > 0) |
223 | { | 227 | { |
224 | try | 228 | try |
@@ -231,7 +235,7 @@ namespace OpenSim.Framework.Servers.HttpServer | |||
231 | { | 235 | { |
232 | } | 236 | } |
233 | } | 237 | } |
234 | 238 | */ | |
235 | m_requests.Clear(); | 239 | m_requests.Clear(); |
236 | } | 240 | } |
237 | 241 | ||
@@ -242,7 +246,6 @@ namespace OpenSim.Framework.Servers.HttpServer | |||
242 | while (m_running) | 246 | while (m_running) |
243 | { | 247 | { |
244 | PollServiceHttpRequest req = m_requests.Dequeue(5000); | 248 | PollServiceHttpRequest req = m_requests.Dequeue(5000); |
245 | |||
246 | Watchdog.UpdateThread(); | 249 | Watchdog.UpdateThread(); |
247 | if(req == null) | 250 | if(req == null) |
248 | continue; | 251 | continue; |
@@ -277,16 +280,16 @@ namespace OpenSim.Framework.Servers.HttpServer | |||
277 | try | 280 | try |
278 | { | 281 | { |
279 | req.DoHTTPGruntWork(m_server, responsedata); | 282 | req.DoHTTPGruntWork(m_server, responsedata); |
283 | } | ||
284 | catch (ObjectDisposedException) { } | ||
285 | finally | ||
286 | { | ||
280 | if(req.HttpContext.CanSend() && req.PollServiceArgs.Type == PollServiceEventArgs.EventType.Poll | 287 | if(req.HttpContext.CanSend() && req.PollServiceArgs.Type == PollServiceEventArgs.EventType.Poll |
281 | && (Environment.TickCount - req.RequestTime) > req.PollServiceArgs.TimeOutms) | 288 | && (Environment.TickCount - req.RequestTime) > req.PollServiceArgs.TimeOutms) |
282 | ReQueueEvent(req); | 289 | ReQueueEvent(req); |
283 | else | 290 | else |
284 | byContextDequeue(req); | 291 | byContextDequeue(req); |
285 | } | 292 | } |
286 | catch (ObjectDisposedException) // Browser aborted before we could read body, server closed the stream | ||
287 | { | ||
288 | // Ignore it, no need to reply | ||
289 | } | ||
290 | return null; | 293 | return null; |
291 | }, null); | 294 | }, null); |
292 | } | 295 | } |
@@ -300,11 +303,11 @@ namespace OpenSim.Framework.Servers.HttpServer | |||
300 | { | 303 | { |
301 | req.DoHTTPGruntWork(m_server, | 304 | req.DoHTTPGruntWork(m_server, |
302 | req.PollServiceArgs.NoEvents(req.RequestID, req.PollServiceArgs.Id)); | 305 | req.PollServiceArgs.NoEvents(req.RequestID, req.PollServiceArgs.Id)); |
303 | byContextDequeue(req); | ||
304 | } | 306 | } |
305 | catch (ObjectDisposedException) | 307 | catch (ObjectDisposedException) {} |
308 | finally | ||
306 | { | 309 | { |
307 | // Ignore it, no need to reply | 310 | byContextDequeue(req); |
308 | } | 311 | } |
309 | return null; | 312 | return null; |
310 | }, null); | 313 | }, null); |