Should I deploy the broker inside my JVM or AppServer

 FAQ > Using Apache ActiveMQ Classic > Should I deploy the broker inside my JVM or AppServer

You can deploy the ActiveMQ Classic Broker inside your JVM or Application Server. Whether you do or not has pros and cons depending on how many JVMs you have and what your backup & recovery policy is.

Advantages of embedding the broker

  • embedding a broker means you can use the VM transport which avoids the use of sockets and serialization. Instead ActiveMQ Classic can pass around messages by value.
    • the slight exception to this is ObjectMessage; the JMS specification says you must serialize the body of the ObjectMessage whenever you send it. However you can disable this feature if you want really high performance when using VM transport
  • its only 1 single deployment unit/JVM rather than 2 coupled processes.

Disadvantages of embedding the broker

If you have lots of JVMs (say 100s of them) and have very stringent requirements; you don’t ever want to loose a message and so you want to backup and manage the persistent ActiveMQ Classic database (and/or files) very carefully.

Having an embdded broker inside each JVM could result in large number of sets of files to manage. So it may be simpler to separate the two out, so that your 100s of JVMs talk to a relatively small cluster of brokers (say 2-10 of them) so that you can avoid worrying about persistent state in each JVM and just focus on backing up and managing the files/databases used by the brokers.

Also its typically easier to run and manage ActiveMQ Classic brokers when they are separate; you can have some ClassLoader issues when trying to embed ActiveMQ Classic inside an application server. e.g. you can sometimes get ClassPath Errors

See

Apache, ActiveMQ, Apache ActiveMQ, the Apache feather logo, and the Apache ActiveMQ project logo are trademarks of The Apache Software Foundation. Copyright © 2025, The Apache Software Foundation. Licensed under Apache License 2.0.