Mirror of Apache ActiveMQ Artemis
Go to file
Michael André Pearce a610748c09 ARTEMIS-994 Support Netty Native Epoll on Linux
The following changes are made to support Epoll.

Refactored SharedNioEventLoopGroup into renamed SharedEventLoopGroup to be generic (as so we can re-use for both Nio and Epoll)

Add support and toggles for Epoll in NettyAcceptor and NettyConnector (with fall back to NIO if cannot load Epoll)

Removal from code of PartialPooledByteBufAllocator, caused bad address when doing native, and no longer needed - see jira discussion

New Connector Properties:

useEpoll - toggles to use epoll or not, default true (but we failback to nio gracefully)
remotingThreads = same behaviour as nioRemotingThreads. Previous property is depreated.
useGlobalWorkerPool = same behaviour as useNioGlobalWorkerPool. Old property is deprecated.

New Acceptor Properties:

useEpoll - toggles to use epoll or not, default true (but we failback to nio gracefully)
useGlobalWorkerPool = same behaviour as useNioGlobalWorkerPool but for Epoll.

This closes #1093
2017-03-23 18:16:48 -05:00
.mvn/wrapper ARTEMIS-613 Artemis build enhancements 2016-07-05 15:13:35 -04:00
.settings ACTIVEMQ6-1 - Initial HornetQ Donation Commit 2014-11-10 10:31:25 -06:00
artemis-boot [maven-release-plugin] prepare for next development iteration 2017-03-10 14:54:33 +00:00
artemis-cdi-client [maven-release-plugin] prepare for next development iteration 2017-03-10 14:54:33 +00:00
artemis-cli ARTEMIS-1054 JVM Monitoring pauses logs 2017-03-22 23:33:25 -04:00
artemis-commons [maven-release-plugin] prepare for next development iteration 2017-03-10 14:54:33 +00:00
artemis-core-client ARTEMIS-994 Support Netty Native Epoll on Linux 2017-03-23 18:16:48 -05:00
artemis-distribution [maven-release-plugin] prepare for next development iteration 2017-03-10 14:54:33 +00:00
artemis-dto [maven-release-plugin] prepare for next development iteration 2017-03-10 14:54:33 +00:00
artemis-features [maven-release-plugin] prepare for next development iteration 2017-03-10 14:54:33 +00:00
artemis-jdbc-store [maven-release-plugin] prepare for next development iteration 2017-03-10 14:54:33 +00:00
artemis-jms-client [maven-release-plugin] prepare for next development iteration 2017-03-10 14:54:33 +00:00
artemis-jms-server [maven-release-plugin] prepare for next development iteration 2017-03-10 14:54:33 +00:00
artemis-journal NO-JIRA: logger on Exception 2017-03-14 09:50:19 -04:00
artemis-junit [maven-release-plugin] prepare for next development iteration 2017-03-10 14:54:33 +00:00
artemis-maven-plugin [maven-release-plugin] prepare for next development iteration 2017-03-10 14:54:33 +00:00
artemis-native [maven-release-plugin] prepare for next development iteration 2017-03-10 14:54:33 +00:00
artemis-protocols ARTEMIS-1061 Ack MQTT PubRel management messages 2017-03-22 23:26:32 -04:00
artemis-ra [maven-release-plugin] prepare for next development iteration 2017-03-10 14:54:33 +00:00
artemis-rest [maven-release-plugin] prepare for next development iteration 2017-03-10 14:54:33 +00:00
artemis-selector [maven-release-plugin] prepare for next development iteration 2017-03-10 14:54:33 +00:00
artemis-server ARTEMIS-994 Support Netty Native Epoll on Linux 2017-03-23 18:16:48 -05:00
artemis-server-osgi [maven-release-plugin] prepare for next development iteration 2017-03-10 14:54:33 +00:00
artemis-service-extensions [maven-release-plugin] prepare for next development iteration 2017-03-10 14:54:33 +00:00
artemis-tools [maven-release-plugin] prepare for next development iteration 2017-03-10 14:54:33 +00:00
artemis-web [maven-release-plugin] prepare for next development iteration 2017-03-10 14:54:33 +00:00
artemis-website [maven-release-plugin] prepare for next development iteration 2017-03-10 14:54:33 +00:00
docs NO-JIRA Refer to Postgres as PostgreSQL or Postgres 2017-03-23 22:04:55 +01:00
etc Add EditorConfig 2016-10-10 10:01:01 +02:00
examples [maven-release-plugin] prepare for next development iteration 2017-03-10 14:54:33 +00:00
integration/activemq-spring-integration [maven-release-plugin] prepare for next development iteration 2017-03-10 14:54:33 +00:00
scripts NO-JIRA Adding script to help debug data on testcases 2016-10-07 14:36:05 -04:00
tests ARTEMIS-1056 Removing PartialPooledByteBufAllocator 2017-03-23 18:16:48 -05:00
.gitignore NO-JIRA: ignore of IDE configurations 2016-11-17 17:49:41 +01:00
.project More name changes to activemq 2014-11-19 16:01:54 -05:00
CMakeLists.txt ARTEMIS-163 First pass on the native AIO refactoring 2015-07-29 22:12:03 -04:00
LICENSE ARTEMIS-565 Replace json.org with javax.json 2016-07-25 21:44:57 -04:00
NOTICE NO-JIRA: update notice 2017-03-09 09:07:09 -05:00
README.md Adding OWASP reporting into pom 2016-09-13 17:06:25 +01:00
RELEASING.md NO-JIRA: Adding releasing information 2016-12-12 10:18:44 -05:00
artemis_doap.rdf Update vendor to ASF 2015-05-30 08:37:28 +02:00
mvnw ARTEMIS-613 Artemis build enhancements 2016-07-05 15:13:35 -04:00
mvnw.cmd ARTEMIS-613 Artemis build enhancements 2016-07-05 15:13:35 -04:00
pom.xml ARTEMIS-1038: Upgrade qpid-jms-client to 0.21.0 2017-03-17 15:08:22 -04:00

README.md

ActiveMQ Artemis

This file describes some minimum 'stuff one needs to know' to get started coding in this project.

Source

For details about the modifying the code, building the project, running tests, IDE integration, etc. see our Hacking Guide.

Building the ASYNC IO library

ActiveMQ Artemis provides two journal persistence types, NIO (which uses the Java NIO libraries), and ASYNCIO which interacts with the linux kernel libaio library. The ASYNCIO journal type should be used where possible as it is far superior in terms of performance.

ActiveMQ Artemis does not ship with the Artemis Native ASYNCIO library in the source distribution. These need to be built prior to running "mvn install", to ensure that the ASYNCIO journal type is available in the resulting build. Don't worry if you don't want to use ASYNCIO or your system does not support libaio, ActiveMQ Artemis will check at runtime to see if the required libraries and system dependencies are available, if not it will default to using NIO.

To build the ActiveMQ Artemis ASYNCIO native libraries, please follow the instructions in the artemis-native/README.

Documentation

Our documentation is always in sync with our releases at the Apache ActiveMQ Artemis website.

Or you can also look at the current master version on github.

Examples

To run an example firstly make sure you have run

$ mvn -Prelease install

If the project version has already been released then this is unnecessary.

Each individual example can be run using this command from its corresponding directory:

$ mvn verify

If you wish to run groups of examples then use this command from a parent directory (e.g. examples/features/standard):

$ mvn -Pexamples verify

Recreating the examples

If you are trying to copy the examples somewhere else and modifying them. Consider asking Maven to explicitly list all the dependencies:

# if trying to modify the 'topic' example:
cd examples/jms/topic && mvn dependency:list

Open Web Application Security Project (OWASP) Report

If you wish to generate the report for CCV dependencies, you may run it with the -Powasp profile

$ mvn -Powasp verify

The output will be under ./target/dependency-check-report.html for each sub-module.