2014-12-11 07:17:29 -05:00
|
|
|
# Configuring the Transport
|
2014-12-04 10:25:29 -05:00
|
|
|
|
2018-03-09 10:07:38 -05:00
|
|
|
In this chapter we'll describe the concepts required for understanding Apache
|
|
|
|
ActiveMQ Artemis transports and where and how they're configured.
|
2014-12-04 10:25:29 -05:00
|
|
|
|
2018-03-08 15:46:38 -05:00
|
|
|
## Acceptors
|
2014-12-04 10:25:29 -05:00
|
|
|
|
2015-04-27 17:32:30 -04:00
|
|
|
One of the most important concepts in Apache ActiveMQ Artemis transports is the
|
2018-03-09 10:07:38 -05:00
|
|
|
*acceptor*. Let's dive straight in and take a look at an acceptor defined in
|
|
|
|
xml in the configuration file `broker.xml`.
|
2014-12-04 10:25:29 -05:00
|
|
|
|
2018-03-08 15:46:38 -05:00
|
|
|
```xml
|
2018-03-09 10:07:38 -05:00
|
|
|
<acceptor name="netty">tcp://localhost:61617</acceptor>
|
2018-03-08 15:46:38 -05:00
|
|
|
```
|
2014-12-04 10:25:29 -05:00
|
|
|
|
2018-03-09 10:07:38 -05:00
|
|
|
Acceptors are always defined inside an `acceptors` element. There can be one or
|
|
|
|
more acceptors defined in the `acceptors` element. There's no upper limit to
|
|
|
|
the number of acceptors per server.
|
2014-12-04 10:25:29 -05:00
|
|
|
|
2018-03-09 10:07:38 -05:00
|
|
|
Each acceptor defines a way in which connections can be made to the Apache
|
|
|
|
ActiveMQ Artemis server.
|
2014-12-04 10:25:29 -05:00
|
|
|
|
|
|
|
In the above example we're defining an acceptor that uses
|
2018-03-09 10:07:38 -05:00
|
|
|
[Netty](https://netty.io/) to listen for connections at port `61617`.
|
|
|
|
|
|
|
|
The `acceptor` element contains a `URL` that defines the kind of Acceptor to
|
|
|
|
create along with its configuration. The `schema` part of the `URL` defines the
|
|
|
|
Acceptor type which can either be `tcp` or `vm` which is `Netty` or an In VM
|
|
|
|
Acceptor respectively. For `Netty` the host and the port of the `URL` define
|
|
|
|
what host and port the `acceptor` will bind to. For In VM the `Authority` part
|
|
|
|
of the `URL` defines a unique server id.
|
|
|
|
|
|
|
|
The `acceptor` can also be configured with a set of key=value pairs used to
|
|
|
|
configure the specific transport, the set of valid key=value pairs depends on
|
|
|
|
the specific transport be used and are passed straight through to the
|
|
|
|
underlying transport. These are set on the `URL` as part of the query, like so:
|
2014-12-04 10:25:29 -05:00
|
|
|
|
2018-03-08 15:46:38 -05:00
|
|
|
```xml
|
|
|
|
<acceptor name="netty">tcp://localhost:61617?sslEnabled=true&keyStorePath=/path</acceptor>
|
|
|
|
```
|
2014-12-04 10:25:29 -05:00
|
|
|
|
2018-03-08 15:46:38 -05:00
|
|
|
## Connectors
|
2014-12-04 10:25:29 -05:00
|
|
|
|
2018-03-09 10:07:38 -05:00
|
|
|
Whereas acceptors are used on the server to define how we accept connections,
|
|
|
|
connectors are used to define how to connect to a server.
|
2014-12-04 10:25:29 -05:00
|
|
|
|
2017-08-31 11:43:56 -04:00
|
|
|
Let's look at a connector defined in our `broker.xml` file:
|
2014-12-04 10:25:29 -05:00
|
|
|
|
2018-03-08 15:46:38 -05:00
|
|
|
```xml
|
2018-03-09 10:07:38 -05:00
|
|
|
<connector name="netty">tcp://localhost:61617</connector>
|
2018-03-08 15:46:38 -05:00
|
|
|
```
|
2014-12-04 10:25:29 -05:00
|
|
|
|
2018-03-09 10:07:38 -05:00
|
|
|
Connectors can be defined inside a `connectors` element. There can be one or
|
|
|
|
more connectors defined in the `connectors` element. There's no upper limit to
|
|
|
|
the number of connectors per server.
|
2014-12-04 10:25:29 -05:00
|
|
|
|
2017-08-31 11:43:56 -04:00
|
|
|
A `connector` is used when the server acts as a client itself, e.g.:
|
2014-12-04 10:25:29 -05:00
|
|
|
|
2018-03-09 10:07:38 -05:00
|
|
|
- When one server is bridged to another
|
|
|
|
- When a server takes part in a cluster
|
2014-12-04 10:25:29 -05:00
|
|
|
|
2017-08-31 11:43:56 -04:00
|
|
|
In these cases the server needs to know how to connect to other servers.
|
|
|
|
That's defined by `connectors`.
|
2014-12-04 10:25:29 -05:00
|
|
|
|
2018-03-08 15:46:38 -05:00
|
|
|
## Configuring the Transport Directly from the Client
|
2014-12-04 10:25:29 -05:00
|
|
|
|
2018-03-09 10:07:38 -05:00
|
|
|
How do we configure a core `ClientSessionFactory` with the information that it
|
|
|
|
needs to connect with a server?
|
2014-12-04 10:25:29 -05:00
|
|
|
|
2017-08-31 11:43:56 -04:00
|
|
|
Connectors are also used indirectly when configuring a core
|
2018-03-09 10:07:38 -05:00
|
|
|
`ClientSessionFactory` to directly talk to a server. Although in this case
|
|
|
|
there's no need to define such a connector in the server side configuration,
|
|
|
|
instead we just specify the appropriate URI.
|
2014-12-04 10:25:29 -05:00
|
|
|
|
2018-03-09 10:07:38 -05:00
|
|
|
Here's an example of creating a `ClientSessionFactory` which will connect
|
|
|
|
directly to the acceptor we defined earlier in this chapter, it uses the
|
|
|
|
standard Netty TCP transport and will try and connect on port 61617 to
|
|
|
|
localhost (default):
|
2014-12-04 10:25:29 -05:00
|
|
|
|
2018-03-08 15:46:38 -05:00
|
|
|
```java
|
2017-08-31 11:43:56 -04:00
|
|
|
ServerLocator locator = ActiveMQClient.createServerLocator("tcp://localhost:61617");
|
2014-12-04 10:25:29 -05:00
|
|
|
|
2014-12-11 07:17:29 -05:00
|
|
|
ClientSessionFactory sessionFactory = locator.createClientSessionFactory();
|
2014-12-04 10:25:29 -05:00
|
|
|
|
2014-12-11 07:17:29 -05:00
|
|
|
ClientSession session = sessionFactory.createSession(...);
|
|
|
|
```
|
2014-12-04 10:25:29 -05:00
|
|
|
|
2018-03-09 10:07:38 -05:00
|
|
|
Similarly, if you're using JMS, you can configure the JMS connection factory
|
|
|
|
directly on the client side:
|
2014-12-04 10:25:29 -05:00
|
|
|
|
2018-03-08 15:46:38 -05:00
|
|
|
```java
|
2017-08-31 11:43:56 -04:00
|
|
|
ConnectionFactory connectionFactory = new ActiveMQConnectionFactory("tcp://localhost:61617");
|
2014-12-04 10:25:29 -05:00
|
|
|
|
2014-12-11 07:17:29 -05:00
|
|
|
Connection jmsConnection = connectionFactory.createConnection();
|
|
|
|
```
|
2014-12-04 10:25:29 -05:00
|
|
|
|
2014-12-11 07:17:29 -05:00
|
|
|
## Configuring the Netty transport
|
2014-12-04 10:25:29 -05:00
|
|
|
|
2015-04-27 17:32:30 -04:00
|
|
|
Out of the box, Apache ActiveMQ Artemis currently uses
|
2018-03-09 10:07:38 -05:00
|
|
|
[Netty](https://netty.io/), a high performance low level network library.
|
2014-12-04 10:25:29 -05:00
|
|
|
|
|
|
|
Our Netty transport can be configured in several different ways; to use
|
|
|
|
straightforward TCP sockets, SSL, or to tunnel over HTTP or HTTPS..
|
|
|
|
|
|
|
|
We believe this caters for the vast majority of transport requirements.
|
|
|
|
|
2018-03-08 15:46:38 -05:00
|
|
|
### Single Port Support
|
2014-12-04 10:25:29 -05:00
|
|
|
|
2018-03-09 10:07:38 -05:00
|
|
|
Apache ActiveMQ Artemis supports using a single port for all protocols, Apache
|
|
|
|
ActiveMQ Artemis will automatically detect which protocol is being used CORE,
|
2020-02-06 12:30:40 -05:00
|
|
|
AMQP, STOMP, MQTT or OPENWIRE and use the appropriate Apache ActiveMQ Artemis
|
2018-03-09 10:07:38 -05:00
|
|
|
handler. It will also detect whether protocols such as HTTP or Web Sockets are
|
2020-02-06 12:30:40 -05:00
|
|
|
being used and also use the appropriate decoders. Web Sockets are supported for
|
|
|
|
AMQP, STOMP, and MQTT.
|
2014-12-04 10:25:29 -05:00
|
|
|
|
2018-03-09 10:07:38 -05:00
|
|
|
It is possible to limit which protocols are supported by using the `protocols`
|
|
|
|
parameter on the Acceptor like so:
|
2014-12-04 10:25:29 -05:00
|
|
|
|
2018-03-08 15:46:38 -05:00
|
|
|
```xml
|
|
|
|
<acceptor name="netty">tcp://localhost:61617?protocols=CORE,AMQP</acceptor>
|
|
|
|
```
|
2015-02-23 04:50:08 -05:00
|
|
|
|
2018-03-08 15:46:38 -05:00
|
|
|
### Configuring Netty TCP
|
2014-12-04 10:25:29 -05:00
|
|
|
|
2017-08-31 11:43:56 -04:00
|
|
|
Netty TCP is a simple unencrypted TCP sockets based transport. If you're
|
2018-03-09 10:07:38 -05:00
|
|
|
running connections across an untrusted network please bear in mind this
|
|
|
|
transport is unencrypted. You may want to look at the SSL or HTTPS
|
|
|
|
configurations.
|
2014-12-04 10:25:29 -05:00
|
|
|
|
2018-03-09 10:07:38 -05:00
|
|
|
With the Netty TCP transport all connections are initiated from the client side
|
|
|
|
(i.e. the server does not initiate any connections to the client). This works
|
|
|
|
well with firewall policies that typically only allow connections to be
|
|
|
|
initiated in one direction.
|
2014-12-04 10:25:29 -05:00
|
|
|
|
2017-08-31 11:43:56 -04:00
|
|
|
All the valid keys for the `tcp` URL scheme used for Netty are defined in the
|
2018-03-09 10:07:38 -05:00
|
|
|
class
|
|
|
|
`org.apache.activemq.artemis.core.remoting.impl.netty.TransportConstants`.
|
|
|
|
Most parameters can be used either with acceptors or connectors, some only work
|
|
|
|
with acceptors. The following parameters can be used to configure Netty for
|
|
|
|
simple TCP:
|
2014-12-04 10:25:29 -05:00
|
|
|
|
2018-03-09 10:07:38 -05:00
|
|
|
> **Note:**
|
2015-02-23 04:50:08 -05:00
|
|
|
>
|
2018-03-09 10:07:38 -05:00
|
|
|
> The `host` and `port` parameters are only used in the core API, in XML
|
|
|
|
> configuration these are set in the URI host and port.
|
|
|
|
|
|
|
|
- `host`. This specifies the host name or IP address to connect to (when
|
|
|
|
configuring a connector) or to listen on (when configuring an acceptor). The
|
|
|
|
default value for this property is `localhost`. When configuring acceptors,
|
|
|
|
multiple hosts or IP addresses can be specified by separating them with commas.
|
|
|
|
It is also possible to specify `0.0.0.0` to accept connection from all the
|
|
|
|
host's network interfaces. It's not valid to specify multiple addresses when
|
|
|
|
specifying the host for a connector; a connector makes a connection to one
|
|
|
|
specific address.
|
|
|
|
|
|
|
|
> **Note:**
|
|
|
|
>
|
|
|
|
> Don't forget to specify a host name or IP address! If you want your server
|
|
|
|
> able to accept connections from other nodes you must specify a hostname or
|
|
|
|
> IP address at which the acceptor will bind and listen for incoming
|
|
|
|
> connections. The default is localhost which of course is not accessible
|
|
|
|
> from remote nodes!
|
|
|
|
|
|
|
|
- `port`. This specified the port to connect to (when configuring a connector)
|
|
|
|
or to listen on (when configuring an acceptor). The default value for this
|
|
|
|
property is `61616`.
|
|
|
|
|
|
|
|
- `tcpNoDelay`. If this is `true` then [Nagle's
|
|
|
|
algorithm](https://en.wikipedia.org/wiki/Nagle%27s_algorithm) will be
|
|
|
|
disabled. This is a [Java (client) socket
|
|
|
|
option](https://docs.oracle.com/javase/8/docs/technotes/guides/net/socketOpt.html).
|
|
|
|
The default value for this property is `true`.
|
|
|
|
|
|
|
|
- `tcpSendBufferSize`. This parameter determines the size of the TCP send
|
|
|
|
buffer in bytes. The default value for this property is `32768` bytes
|
|
|
|
(32KiB).
|
|
|
|
|
|
|
|
TCP buffer sizes should be tuned according to the bandwidth and latency of
|
|
|
|
your network. Here's a good link that explains the theory behind
|
|
|
|
[this](http://www-didc.lbl.gov/TCP-tuning/).
|
|
|
|
|
|
|
|
In summary TCP send/receive buffer sizes should be calculated as:
|
|
|
|
|
|
|
|
buffer_size = bandwidth * RTT.
|
|
|
|
|
|
|
|
Where bandwidth is in *bytes per second* and network round trip time (RTT) is
|
|
|
|
in seconds. RTT can be easily measured using the `ping` utility.
|
|
|
|
|
|
|
|
For fast networks you may want to increase the buffer sizes from the
|
|
|
|
defaults.
|
|
|
|
|
|
|
|
- `tcpReceiveBufferSize`. This parameter determines the size of the TCP receive
|
|
|
|
buffer in bytes. The default value for this property is `32768` bytes
|
|
|
|
(32KiB).
|
2017-04-06 05:33:29 -04:00
|
|
|
|
2018-03-09 10:07:38 -05:00
|
|
|
- `writeBufferLowWaterMark`. This parameter determines the low water mark of
|
|
|
|
the Netty write buffer. Once the number of bytes queued in the write buffer
|
|
|
|
exceeded the high water mark and then dropped down below this value, Netty's
|
|
|
|
channel will start to be writable again. The default value for this property is
|
|
|
|
`32768` bytes (32KiB).
|
2017-04-06 05:33:29 -04:00
|
|
|
|
2018-03-09 10:07:38 -05:00
|
|
|
- `writeBufferHighWaterMark`. This parameter determines the high water mark of
|
|
|
|
the Netty write buffer. If the number of bytes queued in the write buffer
|
|
|
|
exceeds this value, Netty's channel will start to be not writable. The default
|
|
|
|
value for this property is `131072` bytes (128KiB).
|
|
|
|
|
|
|
|
- `batchDelay`. Before writing packets to the transport, Apache ActiveMQ
|
|
|
|
Artemis can be configured to batch up writes for a maximum of `batchDelay`
|
|
|
|
milliseconds. This can increase overall throughput for very small messages. It
|
|
|
|
does so at the expense of an increase in average latency for message transfer.
|
|
|
|
The default value for this property is `0` ms.
|
|
|
|
|
|
|
|
- `directDeliver`. When a message arrives on the server and is delivered to
|
|
|
|
waiting consumers, by default, the delivery is done on the same thread as
|
|
|
|
that on which the message arrived. This gives good latency in environments with
|
|
|
|
relatively small messages and a small number of consumers, but at the cost of
|
|
|
|
overall throughput and scalability - especially on multi-core machines. If you
|
|
|
|
want the lowest latency and a possible reduction in throughput then you can use
|
|
|
|
the default value for `directDeliver` (i.e. `true`). If you are willing to take
|
|
|
|
some small extra hit on latency but want the highest throughput set
|
|
|
|
`directDeliver` to `false`.
|
|
|
|
|
|
|
|
- `nioRemotingThreads` This is deprecated. It is replaced by `remotingThreads`,
|
|
|
|
if you are using this please update your configuration
|
|
|
|
|
|
|
|
- `remotingThreads`. Apache ActiveMQ Artemis will, by default, use a number of
|
|
|
|
threads equal to three times the number of cores (or hyper-threads) as
|
|
|
|
reported by `Runtime.getRuntime().availableProcessors()` for processing
|
|
|
|
incoming packets. If you want to override this value, you can set the number of
|
|
|
|
threads by specifying this parameter. The default value for this parameter is
|
|
|
|
`-1` which means use the value from
|
|
|
|
`Runtime.getRuntime().availableProcessors()` \* 3.
|
|
|
|
|
|
|
|
- `localAddress`. When configured a Netty Connector it is possible to specify
|
|
|
|
which local address the client will use when connecting to the remote
|
|
|
|
address. This is typically used in the Application Server or when running
|
|
|
|
Embedded to control which address is used for outbound connections. If the
|
|
|
|
local-address is not set then the connector will use any local address
|
|
|
|
available
|
|
|
|
|
|
|
|
- `localPort`. When configured a Netty Connector it is possible to specify
|
|
|
|
which local port the client will use when connecting to the remote address.
|
|
|
|
This is typically used in the Application Server or when running Embedded to
|
|
|
|
control which port is used for outbound connections. If the local-port default
|
|
|
|
is used, which is 0, then the connector will let the system pick up an
|
|
|
|
ephemeral port. valid ports are 0 to 65535
|
|
|
|
|
|
|
|
- `connectionsAllowed`. This is only valid for acceptors. It limits the number
|
|
|
|
of connections which the acceptor will allow. When this limit is reached a
|
|
|
|
DEBUG level message is issued to the log, and the connection is refused. The
|
|
|
|
type of client in use will determine what happens when the connection is
|
|
|
|
refused. In the case of a `core` client, it will result in a
|
|
|
|
`org.apache.activemq.artemis.api.core.ActiveMQConnectionTimedOutException`.
|
|
|
|
|
|
|
|
- `handshake-timeout`. Prevents an unauthorised client opening a large number
|
|
|
|
of connections and just keeping them open. As connections each require a file
|
|
|
|
handle this consumes resources that are then unavailable to other clients. Once
|
|
|
|
the connection is authenticated, the usual rules can be enforced regarding
|
|
|
|
resource consumption. Default value is set to 10 seconds. Each integer is valid
|
|
|
|
value. When set value to zero or negative integer this feature is turned off.
|
|
|
|
Changing value needs to restart server to take effect.
|
2017-11-24 08:15:20 -05:00
|
|
|
|
2018-03-08 15:46:38 -05:00
|
|
|
### Configuring Netty Native Transport
|
2017-08-10 03:24:30 -04:00
|
|
|
|
2018-03-09 10:07:38 -05:00
|
|
|
Netty Native Transport support exists for selected OS platforms. This allows
|
|
|
|
Apache ActiveMQ Artemis to use native sockets/io instead of Java NIO.
|
2017-08-10 03:24:30 -04:00
|
|
|
|
2018-03-09 10:07:38 -05:00
|
|
|
These Native transports add features specific to a particular platform,
|
|
|
|
generate less garbage, and generally improve performance when compared to Java
|
|
|
|
NIO based transport.
|
2017-08-10 03:24:30 -04:00
|
|
|
|
|
|
|
Both Clients and Server can benefit from this.
|
|
|
|
|
|
|
|
Current Supported Platforms.
|
2018-03-09 10:07:38 -05:00
|
|
|
- Linux running 64bit JVM
|
|
|
|
- MacOS running 64bit JVM
|
2017-08-10 03:24:30 -04:00
|
|
|
|
2018-03-09 10:07:38 -05:00
|
|
|
Apache ActiveMQ Artemis will by default enable the corresponding native
|
|
|
|
transport if a supported platform is detected.
|
2017-08-10 03:24:30 -04:00
|
|
|
|
2018-03-09 10:07:38 -05:00
|
|
|
If running on an unsupported platform or any issues loading native libs, Apache
|
|
|
|
ActiveMQ Artemis will fallback onto Java NIO.
|
2017-08-10 03:24:30 -04:00
|
|
|
|
|
|
|
#### Linux Native Transport
|
2015-05-04 12:15:33 -04:00
|
|
|
|
2018-03-09 10:07:38 -05:00
|
|
|
On supported Linux platforms Epoll is used, @see
|
|
|
|
https://en.wikipedia.org/wiki/Epoll.
|
2017-08-10 03:24:30 -04:00
|
|
|
|
|
|
|
The following properties are specific to this native transport:
|
|
|
|
|
2018-03-09 10:07:38 -05:00
|
|
|
- `useEpoll` enables the use of epoll if a supported linux platform is running
|
|
|
|
a 64bit JVM is detected. Setting this to `false` will force the use of Java
|
|
|
|
NIO instead of epoll. Default is `true`
|
2017-08-10 03:24:30 -04:00
|
|
|
|
|
|
|
#### MacOS Native Transport
|
|
|
|
|
2018-03-09 10:07:38 -05:00
|
|
|
On supported MacOS platforms KQueue is used, @see
|
|
|
|
https://en.wikipedia.org/wiki/Kqueue.
|
2017-08-10 03:24:30 -04:00
|
|
|
|
|
|
|
The following properties are specific to this native transport:
|
|
|
|
|
2018-03-09 10:07:38 -05:00
|
|
|
- `useKQueue` enables the use of kqueue if a supported MacOS platform running a
|
|
|
|
64bit JVM is detected. Setting this to `false` will force the use of Java
|
|
|
|
NIO instead of kqueue. Default is `true`
|
2017-08-10 03:24:30 -04:00
|
|
|
|
2018-03-08 15:46:38 -05:00
|
|
|
### Configuring Netty SSL
|
2014-12-04 10:25:29 -05:00
|
|
|
|
2018-03-09 10:07:38 -05:00
|
|
|
Netty SSL is similar to the Netty TCP transport but it provides additional
|
|
|
|
security by encrypting TCP connections using the Secure Sockets Layer SSL
|
2014-12-04 10:25:29 -05:00
|
|
|
|
|
|
|
Please see the examples for a full working example of using Netty SSL.
|
|
|
|
|
2018-03-09 10:07:38 -05:00
|
|
|
Netty SSL uses all the same properties as Netty TCP but adds the following
|
|
|
|
additional properties:
|
|
|
|
|
2020-05-14 08:08:09 -04:00
|
|
|
- `sslContext`
|
|
|
|
|
|
|
|
A key that can be used in conjunction with `org.apache.activemq.artemis.core.remoting.impl.ssl.CachingSSLContextFactory`
|
|
|
|
to cache created SSLContext and avoid recreating. Look [Configuring a SSLContextFactory](#Configuring a SSLContextFactory)
|
|
|
|
for more details.
|
|
|
|
|
2018-03-09 10:07:38 -05:00
|
|
|
- `sslEnabled`
|
|
|
|
|
|
|
|
Must be `true` to enable SSL. Default is `false`.
|
|
|
|
|
|
|
|
- `keyStorePath`
|
|
|
|
|
|
|
|
When used on an `acceptor` this is the path to the SSL key store on the
|
|
|
|
server which holds the server's certificates (whether self-signed or signed by
|
|
|
|
an authority).
|
|
|
|
|
|
|
|
When used on a `connector` this is the path to the client-side SSL key store
|
|
|
|
which holds the client certificates. This is only relevant for a `connector` if
|
|
|
|
you are using 2-way SSL (i.e. mutual authentication). Although this value is
|
|
|
|
configured on the server, it is downloaded and used by the client. If the
|
|
|
|
client needs to use a different path from that set on the server then it can
|
|
|
|
override the server-side setting by either using the customary
|
|
|
|
"javax.net.ssl.keyStore" system property or the ActiveMQ-specific
|
|
|
|
"org.apache.activemq.ssl.keyStore" system property. The ActiveMQ-specific
|
|
|
|
system property is useful if another component on client is already making use
|
|
|
|
of the standard, Java system property.
|
|
|
|
|
|
|
|
- `keyStorePassword`
|
|
|
|
|
|
|
|
When used on an `acceptor` this is the password for the server-side keystore.
|
|
|
|
|
|
|
|
When used on a `connector` this is the password for the client-side keystore.
|
|
|
|
This is only relevant for a `connector` if you are using 2-way SSL (i.e. mutual
|
|
|
|
authentication). Although this value can be configured on the server, it is
|
|
|
|
downloaded and used by the client. If the client needs to use a different
|
|
|
|
password from that set on the server then it can override the server-side
|
|
|
|
setting by either using the customary "javax.net.ssl.keyStorePassword" system
|
|
|
|
property or the ActiveMQ-specific "org.apache.activemq.ssl.keyStorePassword"
|
|
|
|
system property. The ActiveMQ-specific system property is useful if another
|
|
|
|
component on client is already making use of the standard, Java system
|
|
|
|
property.
|
|
|
|
|
|
|
|
- `trustStorePath`
|
|
|
|
|
|
|
|
When used on an `acceptor` this is the path to the server-side SSL key store
|
|
|
|
that holds the keys of all the clients that the server trusts. This is only
|
|
|
|
relevant for an `acceptor` if you are using 2-way SSL (i.e. mutual
|
|
|
|
authentication).
|
|
|
|
|
|
|
|
When used on a `connector` this is the path to the client-side SSL key store
|
|
|
|
which holds the public keys of all the servers that the client trusts. Although
|
|
|
|
this value can be configured on the server, it is downloaded and used by the
|
|
|
|
client. If the client needs to use a different path from that set on the server
|
|
|
|
then it can override the server-side setting by either using the customary
|
|
|
|
"javax.net.ssl.trustStore" system property or the ActiveMQ-specific
|
|
|
|
"org.apache.activemq.ssl.trustStore" system property. The ActiveMQ-specific
|
|
|
|
system property is useful if another component on client is already making use
|
|
|
|
of the standard, Java system property.
|
|
|
|
|
|
|
|
- `trustStorePassword`
|
|
|
|
|
|
|
|
When used on an `acceptor` this is the password for the server-side trust
|
|
|
|
store. This is only relevant for an `acceptor` if you are using 2-way SSL (i.e.
|
|
|
|
mutual authentication).
|
|
|
|
|
|
|
|
When used on a `connector` this is the password for the client-side
|
|
|
|
truststore. Although this value can be configured on the server, it is
|
|
|
|
downloaded and used by the client. If the client needs to use a different
|
|
|
|
password from that set on the server then it can override the server-side
|
|
|
|
setting by either using the customary "javax.net.ssl.trustStorePassword" system
|
|
|
|
property or the ActiveMQ-specific "org.apache.activemq.ssl.trustStorePassword"
|
|
|
|
system property. The ActiveMQ-specific system property is useful if another
|
|
|
|
component on client is already making use of the standard, Java system
|
|
|
|
property.
|
|
|
|
|
|
|
|
- `enabledCipherSuites`
|
|
|
|
|
|
|
|
Whether used on an `acceptor` or `connector` this is a comma separated list
|
|
|
|
of cipher suites used for SSL communication. The default value is `null` which
|
|
|
|
means the JVM's default will be used.
|
|
|
|
|
|
|
|
- `enabledProtocols`
|
|
|
|
|
|
|
|
Whether used on an `acceptor` or `connector` this is a comma separated list
|
|
|
|
of protocols used for SSL communication. The default value is `null` which
|
|
|
|
means the JVM's default will be used.
|
|
|
|
|
|
|
|
- `needClientAuth`
|
|
|
|
|
|
|
|
This property is only for an `acceptor`. It tells a client connecting to this
|
|
|
|
acceptor that 2-way SSL is required. Valid values are `true` or `false`.
|
|
|
|
Default is `false`.
|
2018-02-27 09:47:36 -05:00
|
|
|
|
2018-03-09 10:07:38 -05:00
|
|
|
**Note:** This property takes precedence over `wantClientAuth` and if its
|
|
|
|
value is set to true then `wantClientAuth` will be ignored.
|
2018-02-27 09:47:36 -05:00
|
|
|
|
2018-03-09 10:07:38 -05:00
|
|
|
- `wantClientAuth`
|
2018-02-27 09:47:36 -05:00
|
|
|
|
2018-03-09 10:07:38 -05:00
|
|
|
This property is only for an `acceptor`. It tells a client connecting to this
|
|
|
|
acceptor that 2-way SSL is requested but not required. Valid values are `true`
|
|
|
|
or `false`. Default is `false`.
|
2018-02-27 09:47:36 -05:00
|
|
|
|
2018-03-09 10:07:38 -05:00
|
|
|
**Note:** If the property `needClientAuth` is set to `true` then that
|
|
|
|
property will take precedence and this property will be ignored.
|
2014-12-04 10:25:29 -05:00
|
|
|
|
2018-03-09 10:07:38 -05:00
|
|
|
- `verifyHost`
|
2016-08-11 15:32:56 -04:00
|
|
|
|
2018-03-09 10:07:38 -05:00
|
|
|
When used on an `acceptor` the `CN` of the connecting client's SSL
|
|
|
|
certificate will be compared to its hostname to verify they match. This is
|
|
|
|
useful only for 2-way SSL.
|
2016-08-11 15:32:56 -04:00
|
|
|
|
2018-03-09 10:07:38 -05:00
|
|
|
When used on a `connector` the `CN` of the server's SSL certificate will be
|
|
|
|
compared to its hostname to verify they match. This is useful for both 1-way
|
|
|
|
and 2-way SSL.
|
2016-08-11 15:32:56 -04:00
|
|
|
|
2018-03-09 10:07:38 -05:00
|
|
|
Valid values are `true` or `false`. Default is `false`.
|
2017-10-18 10:07:23 -04:00
|
|
|
|
2018-03-09 10:07:38 -05:00
|
|
|
- `trustAll`
|
2017-10-18 10:07:23 -04:00
|
|
|
|
2018-03-09 10:07:38 -05:00
|
|
|
When used on a `connector` the client will trust the provided server
|
|
|
|
certificate implicitly, regardless of any configured trust store. **Warning:**
|
|
|
|
This setting is primarily for testing purposes only and should not be used in
|
|
|
|
production.
|
2017-10-18 10:07:23 -04:00
|
|
|
|
2018-03-09 10:07:38 -05:00
|
|
|
Valid values are `true` or `false`. Default is `false`.
|
2018-05-25 07:11:26 -04:00
|
|
|
|
2018-03-09 10:07:38 -05:00
|
|
|
- `forceSSLParameters`
|
2018-05-25 07:11:26 -04:00
|
|
|
|
2018-03-09 10:07:38 -05:00
|
|
|
When used on a `connector` any SSL settings that are set as parameters on the
|
|
|
|
connector will be used instead of JVM system properties including both
|
|
|
|
javax.net.ssl and ActiveMQ system properties to configure the SSL context for
|
|
|
|
this connector.
|
2018-05-25 07:11:26 -04:00
|
|
|
|
2018-03-09 10:07:38 -05:00
|
|
|
Valid values are `true` or `false`. Default is `false`.
|
2016-08-11 15:32:56 -04:00
|
|
|
|
2018-03-09 10:07:38 -05:00
|
|
|
- `useDefaultSslContext`
|
2017-04-18 12:40:08 -04:00
|
|
|
|
2018-03-09 10:07:38 -05:00
|
|
|
Only valid on a `connector`. Allows the `connector` to use the "default" SSL
|
|
|
|
context (via `SSLContext.getDefault()`) which can be set programmatically by
|
|
|
|
the client (via `SSLContext.setDefault(SSLContext)`). If set to `true` all
|
|
|
|
other SSL related parameters except for `sslEnabled` are ignored.
|
2017-04-18 12:40:08 -04:00
|
|
|
|
2018-03-09 10:07:38 -05:00
|
|
|
Valid values are `true` or `false`. Default is `false`.
|
2017-04-18 12:40:08 -04:00
|
|
|
|
2018-03-09 10:07:38 -05:00
|
|
|
- `sslProvider`
|
2018-02-05 04:23:18 -05:00
|
|
|
|
2018-03-09 10:07:38 -05:00
|
|
|
Used to change the SSL Provider between `JDK` and `OPENSSL`. The default is
|
|
|
|
`JDK`. If used with `OPENSSL` you can add `netty-tcnative` to your classpath
|
|
|
|
to use the native installed openssl. This can be useful if you want to use
|
|
|
|
special ciphersuite - elliptic curve combinations which are support through
|
|
|
|
openssl but not through the JDK provider. See
|
|
|
|
https://en.wikipedia.org/wiki/Comparison_of_TLS_implementations for more
|
|
|
|
information's.
|
|
|
|
|
2018-09-11 12:06:01 -04:00
|
|
|
- `sniHost`
|
|
|
|
|
|
|
|
When used on an `acceptor` the `sniHost` is a *regular expression* used to
|
|
|
|
match the [`server_name`](https://tools.ietf.org/html/rfc6066) extension on
|
|
|
|
incoming SSL connections. If the name doesn't match then the connection to
|
|
|
|
the acceptor will be rejected. A WARN message will be logged if this happens.
|
|
|
|
If the incoming connection doesn't include the `server_name` extension then
|
|
|
|
the connection will be accepted.
|
|
|
|
|
|
|
|
When used on a `connector` the `sniHost` value is used for the `server_name`
|
|
|
|
extension on the SSL connection.
|
|
|
|
|
2019-12-19 10:03:57 -05:00
|
|
|
- `trustManagerFactoryPlugin`
|
|
|
|
|
|
|
|
This is valid on either an `acceptor` or `connector`. It defines the name
|
|
|
|
of the class which implements `org.apache.activemq.artemis.api.core.TrustManagerFactoryPlugin`.
|
|
|
|
This is a simple interface with a single method which returns a
|
|
|
|
`javax.net.ssl.TrustManagerFactory`. The `TrustManagerFactory` will be used
|
|
|
|
when the underlying `javax.net.ssl.SSLContext` is initialized. This allows
|
|
|
|
fine-grained customization of who/what the broker & client trusts.
|
|
|
|
|
|
|
|
This value takes precedence of all other SSL parameters which apply to the
|
|
|
|
trust manager (i.e. `trustAll`, `truststoreProvider`, `truststorePath`,
|
|
|
|
`truststorePassword`, `crlPath`).
|
|
|
|
|
|
|
|
Any plugin specified will need to be placed on the
|
|
|
|
[broker's classpath](using-server.md#adding-runtime-dependencies).
|
|
|
|
|
|
|
|
|
2020-05-14 08:08:09 -04:00
|
|
|
#### Configuring a SSLContextFactory
|
|
|
|
|
|
|
|
If you have a `JDK` provider you can configure which SSLContextFactory to use.
|
|
|
|
Currently we provide two implementations:
|
|
|
|
- `org.apache.activemq.artemis.core.remoting.impl.ssl.DefaultSSLContextFactory`
|
|
|
|
- `org.apache.activemq.artemis.core.remoting.impl.ssl.CachingSSLContextFactory`
|
|
|
|
but you can also add your own implementation of `org.apache.activemq.artemis.spi.core.remoting.ssl.SSLContextFactory`.
|
|
|
|
|
|
|
|
The implementations are loaded by a ServiceLoader, thus you need to declare your implementation in
|
|
|
|
a `META-INF/services/org.apache.activemq.artemis.spi.core.remoting.ssl.SSLContextFactory` file.
|
|
|
|
If several implementations are available, the one with the highest `priority` will be selected.
|
|
|
|
So for example, if you want to use `org.apache.activemq.artemis.core.remoting.impl.ssl.CachingSSLContextFactory`
|
|
|
|
you need to add a `META-INF/services/org.apache.activemq.artemis.spi.core.remoting.ssl.SSLContextFactory` file
|
|
|
|
to your classpath with the content `org.apache.activemq.artemis.core.remoting.impl.ssl.CachingSSLContextFactory`.
|
|
|
|
|
|
|
|
**Note:** This mechanism doesn't work if you have selected `OPENSSL` as provider.
|
|
|
|
|
|
|
|
|
2018-03-08 15:46:38 -05:00
|
|
|
### Configuring Netty HTTP
|
2014-12-04 10:25:29 -05:00
|
|
|
|
|
|
|
Netty HTTP tunnels packets over the HTTP protocol. It can be useful in
|
|
|
|
scenarios where firewalls only allow HTTP traffic to pass.
|
|
|
|
|
|
|
|
Please see the examples for a full working example of using Netty HTTP.
|
|
|
|
|
|
|
|
Netty HTTP uses the same properties as Netty TCP but adds the following
|
|
|
|
additional properties:
|
|
|
|
|
2018-03-09 10:07:38 -05:00
|
|
|
- `httpEnabled`. This is now no longer needed. With single port support Apache
|
|
|
|
ActiveMQ Artemis will now automatically detect if http is being used and
|
|
|
|
configure itself.
|
2014-12-04 10:25:29 -05:00
|
|
|
|
2018-03-09 10:07:38 -05:00
|
|
|
- `httpClientIdleTime`. How long a client can be idle before sending an empty
|
|
|
|
http request to keep the connection alive
|
2014-12-04 10:25:29 -05:00
|
|
|
|
2018-03-09 10:07:38 -05:00
|
|
|
- `httpClientIdleScanPeriod`. How often, in milliseconds, to scan for idle
|
|
|
|
clients
|
2014-12-04 10:25:29 -05:00
|
|
|
|
2018-03-09 10:07:38 -05:00
|
|
|
- `httpResponseTime`. How long the server can wait before sending an empty http
|
|
|
|
response to keep the connection alive
|
2014-12-04 10:25:29 -05:00
|
|
|
|
2018-03-09 10:07:38 -05:00
|
|
|
- `httpServerScanPeriod`. How often, in milliseconds, to scan for clients
|
|
|
|
needing responses
|
2014-12-04 10:25:29 -05:00
|
|
|
|
2018-03-09 10:07:38 -05:00
|
|
|
- `httpRequiresSessionId`. If `true` the client will wait after the first call
|
|
|
|
to receive a session id. Used the http connector is connecting to servlet
|
|
|
|
acceptor (not recommended)
|
2020-08-04 12:42:55 -04:00
|
|
|
|
|
|
|
|
|
|
|
### Configuring Netty SOCKS Proxy
|
|
|
|
|
|
|
|
All these parameters are only applicable to a `connector` and/or client URL.
|
|
|
|
|
|
|
|
**Note:** Using a loop-back address (e.g. `localhost` or `127.0.0.1`) as the
|
|
|
|
target of the `connector` or URL will circumvent the application of these
|
|
|
|
configuration properties. In other words, no SOCKS proxy support will be
|
|
|
|
configured even if these properties are set.
|
|
|
|
|
|
|
|
- `socksEnabled`. Whether or not to enable SOCKS support on the `connector`.
|
|
|
|
|
|
|
|
- `socksHost`. The name of the SOCKS server to use.
|
|
|
|
|
|
|
|
- `socksPort`. The port of the SOCKS server to use.
|
|
|
|
|
|
|
|
- `socksVersion`. The version of SOCKS to use. Must be an integer. Default is
|
|
|
|
`5`.
|
|
|
|
|
|
|
|
- `socksUsername`. The username to use when connecting to the `socksHost`.
|
|
|
|
|
|
|
|
- `socksPassword`. The password to use when connecting to the `socksHost`. Only
|
|
|
|
applicable if the `socksVersion` is `5`.
|
|
|
|
|
|
|
|
- `socksRemoteDNS`. Whether or not to create remote destination socket
|
|
|
|
unresolved and disable DNS resolution. Default is `false`.
|