This closes #870

This commit is contained in:
Clebert Suconic 2016-10-28 16:31:41 -04:00
commit 51fa840617
3 changed files with 1 additions and 32 deletions

View File

@ -144,7 +144,6 @@ Out of the box, Apache ActiveMQ Artemis currently uses
network library. network library.
Our Netty transport can be configured in several different ways; to use Our Netty transport can be configured in several different ways; to use
old (blocking) Java IO, or NIO (non-blocking), also to use
straightforward TCP sockets, SSL, or to tunnel over HTTP or HTTPS.. straightforward TCP sockets, SSL, or to tunnel over HTTP or HTTPS..
We believe this caters for the vast majority of transport requirements. We believe this caters for the vast majority of transport requirements.

View File

@ -132,16 +132,6 @@ tuning:
consumer-window-size. This effectively disables consumer flow consumer-window-size. This effectively disables consumer flow
control. control.
- Socket NIO vs Socket Old IO. By default Apache ActiveMQ Artemis uses old (blocking)
on the server and the client side (see the chapter on configuring
transports for more information [Configuring the Transport](configuring-transports.md). NIO is much more scalable but
can give you some latency hit compared to old blocking IO. If you
need to be able to service many thousands of connections on the
server, then you should make sure you're using NIO on the server.
However, if don't expect many thousands of connections on the server
you can keep the server acceptors using old IO, and might get a
small performance advantage.
- Use the core API not JMS. Using the JMS API you will have slightly - Use the core API not JMS. Using the JMS API you will have slightly
lower performance than using the core API, since all JMS operations lower performance than using the core API, since all JMS operations
need to be translated into core operations before the server can need to be translated into core operations before the server can

View File

@ -13,27 +13,7 @@ a scheduled thread pool for scheduled use. A Java scheduled thread pool
cannot be configured to use a standard thread pool, otherwise we could cannot be configured to use a standard thread pool, otherwise we could
use a single thread pool for both scheduled and non scheduled activity. use a single thread pool for both scheduled and non scheduled activity.
A separate thread pool is also used to service connections. Apache ActiveMQ Artemis can Apache ActiveMQ Artemis will, by default, cap its thread pool
use "old" (blocking) IO or "new" (non-blocking) IO also called NIO. Both
of these options use a separate thread pool, but each of them behaves
uniquely.
Since old IO requires a thread per connection its thread pool is
unbounded. The thread pool is created via `
java.util.concurrent.Executors.newCachedThreadPool(ThreadFactory)`.
As the JavaDoc for this method states: “Creates a thread pool that
creates new threads as needed, but will reuse previously constructed
threads when they are available, and uses the provided ThreadFactory to
create new threads when needed.” Threads from this pool which are idle
for more than 60 seconds will time out and be removed. If old IO
connections were serviced from the standard pool the pool would easily
get exhausted if too many connections were made, resulting in the server
"hanging" since it has no remaining threads to do anything else.
However, even an unbounded thread pool can run into trouble if it
becomes too large. If you require the server to handle many concurrent
connections you should use NIO, not old IO.
When using new IO (NIO), Apache ActiveMQ Artemis will, by default, cap its thread pool
at three times the number of cores (or hyper-threads) as reported by ` at three times the number of cores (or hyper-threads) as reported by `
Runtime.getRuntime().availableProcessors()` for processing Runtime.getRuntime().availableProcessors()` for processing
incoming packets. To override this value, you can set the number of incoming packets. To override this value, you can set the number of