Following changes need to be done in broker.xml.
First thing we need is to add an acceptor for the IP address the client will be calling.
<acceptor name="netty">tcp://192.168.121.77:61617</acceptor>
Next we define an address the client will be connecting to. We don’t need to define a queue as they will be created automatically for the connected clients.
<address name="event.artemis">
<multicast/>
</address>
Settings for the address.
<address-setting match="event.artemis">
<auto-create-queues>true</auto-create-queues>
<max-size-bytes>10485760</max-size-bytes>
<page-size-bytes>1048576</page-size-bytes>
<redelivery-delay>30000</redelivery-delay>
<max-redelivery-delay>3600000</max-redelivery-delay>
<redelivery-delay-multiplier>2</redelivery-delay-multiplier>
<max-delivery-attempts>0</max-delivery-attempts>
</address-setting>
Last change is to divert the messages from default queue to the artemis queue. This will copy all messages coming to event.default and send them to the event.artemis.
<divert name="artemis_divert">
<exclusive>false</exclusive>
<address>event.default</address>
<forwarding-address>event.artemis</forwarding-address>
</divert>
After restart of Candlepin any client can connect and listen to the messages in the event.artemis queue.
In Artemis, Netty is responsible for all things related to the transport layer, so it handles SSL as well. All configuration options are set directly on the acceptor.
Note: the trustStorePath and trustStorePassword variables are optional, in case you want to enable 2-way SSL authentication as described here.
On the broker, the artemis-server.ks
file is the key store file holding the server’s certificate, while artemis-server.ts
file is the file holding the certificates which the broker trusts:
<acceptor name="netty-ssl">tcp://localhost:61617?sslEnabled=true;keyStorePath=${artemis.instance}/certs/artemis-server.ks;keyStorePassword=securepassword;needClientAuth=true;trustStorePath=${artemis.instance}/certs/artemis-server.ts;trustStorePassword=securepassword/acceptor>
On the URL used by the client side, the artemis-client.ts
file is the file holding the certificates which the client trusts, while artemis-client.ks
is the key store file holding the client’s certificate:
tcp://localhost:61617?sslEnabled=true&trustStorePath=<path_to_certs>/artemis-client.ts&trustStorePassword=securepassword&keyStorePath=<path_to_certs>/artemis-client.ks&keyStorePassword=securepassword
By default Candlepin uses broker.xml packaged with it. Candlepin can be set to use external broker.xml by setting its path in Candlepin property candlepin.audit.hornetq.config_path.