Commit d513df23 authored by Gaston Dombiak's avatar Gaston Dombiak Committed by gato

Improved thread pool configuration to use more processing threads. JM-680

git-svn-id: http://svn.igniterealtime.org/svn/repos/wildfire/trunk@3862 b35dd754-fafc-0310-a699-88a17e54d16e
parent 900b1fb6
...@@ -12,12 +12,12 @@ ...@@ -12,12 +12,12 @@
package org.jivesoftware.wildfire.net; package org.jivesoftware.wildfire.net;
import org.dom4j.Element; import org.dom4j.Element;
import org.jivesoftware.util.JiveGlobals;
import org.jivesoftware.util.Log;
import org.jivesoftware.wildfire.PacketRouter; import org.jivesoftware.wildfire.PacketRouter;
import org.jivesoftware.wildfire.auth.UnauthorizedException; import org.jivesoftware.wildfire.auth.UnauthorizedException;
import org.jivesoftware.wildfire.interceptor.PacketRejectedException; import org.jivesoftware.wildfire.interceptor.PacketRejectedException;
import org.jivesoftware.wildfire.server.IncomingServerSession; import org.jivesoftware.wildfire.server.IncomingServerSession;
import org.jivesoftware.util.JiveGlobals;
import org.jivesoftware.util.Log;
import org.xmlpull.v1.XmlPullParserException; import org.xmlpull.v1.XmlPullParserException;
import org.xmpp.packet.*; import org.xmpp.packet.*;
...@@ -38,7 +38,7 @@ import java.util.concurrent.TimeUnit; ...@@ -38,7 +38,7 @@ import java.util.concurrent.TimeUnit;
* could be routed at the same time. To avoid creating new threads every time a packet is received * could be routed at the same time. To avoid creating new threads every time a packet is received
* each <tt>ServerSocketReader</tt> instance uses a {@link ThreadPoolExecutor}. By default the * each <tt>ServerSocketReader</tt> instance uses a {@link ThreadPoolExecutor}. By default the
* maximum number of threads that the executor may have is 50. However, this value may be modified * maximum number of threads that the executor may have is 50. However, this value may be modified
* by changing the property <b>xmpp.server.processing.threads</b>. * by changing the property <b>xmpp.server.processing.max.threads</b>.
* *
* @author Gaston Dombiak * @author Gaston Dombiak
*/ */
...@@ -54,10 +54,12 @@ public class ServerSocketReader extends SocketReader { ...@@ -54,10 +54,12 @@ public class ServerSocketReader extends SocketReader {
super(router, serverName, socket, connection); super(router, serverName, socket, connection);
// Create a pool of threads that will process received packets. If more threads are // Create a pool of threads that will process received packets. If more threads are
// required then the command will be executed on the SocketReader process // required then the command will be executed on the SocketReader process
int maxThreads = JiveGlobals.getIntProperty("xmpp.server.processing.threads", 50); int coreThreads = JiveGlobals.getIntProperty("xmpp.server.processing.core.threads", 2);
int maxThreads = JiveGlobals.getIntProperty("xmpp.server.processing.max.threads", 50);
int queueSize = JiveGlobals.getIntProperty("xmpp.server.processing.queue", 50);
threadPool = threadPool =
new ThreadPoolExecutor(1, maxThreads, 60, TimeUnit.SECONDS, new ThreadPoolExecutor(coreThreads, maxThreads, 60, TimeUnit.SECONDS,
new LinkedBlockingQueue<Runnable>(), new LinkedBlockingQueue<Runnable>(queueSize),
new ThreadPoolExecutor.CallerRunsPolicy()); new ThreadPoolExecutor.CallerRunsPolicy());
} }
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment