When come to enterprise, security is a big concern. When communicating with a Message Broker your messages are communicated with the broker along the network. Thus it is needed to encrypt the communicated messages in TCP layer for enhanced security.
With WSO2 Message Broker 2.2.0 and onwards (we have already distributed a patch with this capability to our enterprise partners) we will support "Communicating With SSL". This post explains how this new feature can be enabled and configured to suit your environment.
Server Side Configurations
WSO2 Message Broker can enable non-ssl port (default - 5672), and ssl-port (default- 5671) at the same time or strictly SSL only. If some of your clients are within the secured network they can communicate with non-ssl and other clients which are outside the secured network can communicate with the broker using ssl. For such a use case, fist option can be used. 
To configure "strictly SSL" or not,  use following configuration at Broker side. You need to edit
<MB_HOME>/repository/conf/advanced/qpidconfig.xml file. 
<! To enable SSL edit the keystorePath and keystorePassword and set enabled to true. To disasble NonSSL port set sslOnly to true > <ssl> <enabled>true</enabled> <sslOnly>false</sslOnly> <keystorePath>repository/resources/security/wso2carbon.jks</keystorePath> <keystorePassword>wso2carbon</keystorePassword> </ssl>
- <enabled> : By default SSL is enabled in WSO2 MB hence this value is set to 'true'. If you set this to 'false' broker will be only starting in nonssl port.
- <sslOnly> : States whether to allow/not allow making connections to broker via secured port only. If set to 'true' nonssl port is disabled.
- <keystorePath> : Add the path to the keystore here.
- <keystorePassword> : Specify the password to access the keystore. 
Generally for Carbon servers we put keystore file at <MB_HOME>/repository/resources/security folder. 
Configuring JMS Clients to use SSL
SSL parameters are configured and sent to the broker as broker options in the
TCPConnectionURL defined by the client. It is needed set 'ssl=true' in the url and specify the
keystore and client trust store paths and passwords. Use the below connection url format to
pass the SSL parameters.
String connectionURL = "amqp://<USERNAME>:<PASSWORD>@carbon/carbon?brokerlist='tcp://<IP>:<SSL_POR T>?ssl='true'&ssl_cert_alias='<CERTIFICATE_ALIAS_IN_TRUSTSTORE>' &trust_store='<PATH_TO_TRUST_STORE>'&trust_store_password='< TRUSTSTORE_PASSWORD>'&key_store='<PATH_TO_KEY_STORE>'& key_store_password='<KEYSTORE_PASSWORD>''";Note the setting 'ssl_cert_alias' property is not mandatory and can be used as an optional way of specifying which certificate the broker should use if the truststore contains multiple entries.
An example connection url which uses default keystores and trust stores in WSO2 carbon
products is as follows.
String conUrl =
"amqp://admin:admin@carbon/carbon?brokerlist='tcp://localhost:8672?ssl='true'&ssl_cert_alias
='RootCA'&trust_store='MB_HOME/repository/resources/security/client-truststore.jks'&trust_sto
re_password='wso2carbon'&key_store='MB_HOME/repository/resources/security/wso2carbon.j
ks'&key_store_password='wso2carbon''";
Failover Configuration to Servers with Different Private Keys
Say you have configured a WSO2 Message Broker cluster and you need to configure fail-over. If those broker nodes have different certs in place, when configuring fail-over connection url at client side, you can individually specify a client trust store and a key store for each broker in broker list. Or else, you can import certs of all brokers in the cluster to a single trust store with different cert alias and differentiate the cert to use when failing over by the alias. 
Configure WSO2 ESB to Communicate with WSO2 MB with SSL
simply, what you need to do is configure above ssl-url at <ESB_HOME>/repository/conf/jndi.properties file.


 
 
