aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/OpenSim/Framework/Servers/HttpServer/PollServiceRequestManager.cs
diff options
context:
space:
mode:
Diffstat (limited to '')
-rw-r--r--OpenSim/Framework/Servers/HttpServer/PollServiceRequestManager.cs25
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);