2017-05-10 16:20:38 +02:00
# Akka Extensions
2011-12-15 01:27:59 +01:00
2012-02-25 14:59:50 +01:00
If you want to add features to Akka, there is a very elegant, but powerful mechanism for doing so.
2017-05-10 16:20:38 +02:00
It's called Akka Extensions and is comprised of 2 basic components: an `Extension` and an `ExtensionId` .
2012-02-25 14:59:50 +01:00
2017-05-10 16:20:38 +02:00
Extensions will only be loaded once per `ActorSystem` , which will be managed by Akka.
You can choose to have your Extension loaded on-demand or at `ActorSystem` creation time through the Akka configuration.
2012-02-25 14:59:50 +01:00
Details on how to make that happens are below, in the "Loading from Configuration" section.
2017-05-10 16:20:38 +02:00
@@@ warning
Since an extension is a way to hook into Akka itself, the implementor of the extension needs to
ensure the thread safety of his/her extension.
2012-02-25 14:59:50 +01:00
2017-05-10 16:20:38 +02:00
@@@
2011-12-15 01:27:59 +01:00
2017-05-10 16:20:38 +02:00
## Building an Extension
2011-12-15 01:27:59 +01:00
2018-05-15 08:11:03 +02:00
So let's create a sample extension that lets us count the number of times something has happened.
2011-12-15 01:27:59 +01:00
2017-05-10 16:20:38 +02:00
First, we define what our `Extension` should do:
2011-12-15 01:27:59 +01:00
2017-06-14 18:01:27 +09:00
Scala
2018-09-13 10:49:51 +02:00
: @@snip [ExtensionDocSpec.scala ](/akka-docs/src/test/scala/docs/extension/ExtensionDocSpec.scala ) { #extension }
2017-06-14 18:01:27 +09:00
Java
2018-09-13 10:49:51 +02:00
: @@snip [ExtensionDocTest.java ](/akka-docs/src/test/java/jdocs/extension/ExtensionDocTest.java ) { #imports #extension }
2011-12-15 01:27:59 +01:00
2017-05-10 16:20:38 +02:00
Then we need to create an `ExtensionId` for our extension so we can grab a hold of it.
2011-12-15 01:27:59 +01:00
2017-06-14 18:01:27 +09:00
Scala
2018-09-13 10:49:51 +02:00
: @@snip [ExtensionDocSpec.scala ](/akka-docs/src/test/scala/docs/extension/ExtensionDocSpec.scala ) { #extensionid }
2017-06-14 18:01:27 +09:00
Java
2018-09-13 10:49:51 +02:00
: @@snip [ExtensionDocTest.java ](/akka-docs/src/test/java/jdocs/extension/ExtensionDocTest.java ) { #imports #extensionid }
2011-12-15 01:27:59 +01:00
Wicked! Now all we need to do is to actually use it:
2017-06-14 18:01:27 +09:00
Scala
2018-09-13 10:49:51 +02:00
: @@snip [ExtensionDocSpec.scala ](/akka-docs/src/test/scala/docs/extension/ExtensionDocSpec.scala ) { #extension -usage }
2017-06-14 18:01:27 +09:00
Java
2018-09-13 10:49:51 +02:00
: @@snip [ExtensionDocTest.java ](/akka-docs/src/test/java/jdocs/extension/ExtensionDocTest.java ) { #extension -usage }
2011-12-15 01:27:59 +01:00
Or from inside of an Akka Actor:
2017-06-14 18:01:27 +09:00
Scala
2018-09-13 10:49:51 +02:00
: @@snip [ExtensionDocSpec.scala ](/akka-docs/src/test/scala/docs/extension/ExtensionDocSpec.scala ) { #extension -usage-actor }
2017-06-14 18:01:27 +09:00
Java
2018-09-13 10:49:51 +02:00
: @@snip [ExtensionDocTest.java ](/akka-docs/src/test/java/jdocs/extension/ExtensionDocTest.java ) { #extension -usage-actor }
2017-06-14 18:01:27 +09:00
@@@ div { .group-scala }
2011-12-15 01:27:59 +01:00
You can also hide extension behind traits:
2018-09-13 10:49:51 +02:00
@@snip [ExtensionDocSpec.scala ](/akka-docs/src/test/scala/docs/extension/ExtensionDocSpec.scala ) { #extension -usage-actor-trait }
2011-12-15 01:27:59 +01:00
2017-06-14 18:01:27 +09:00
@@@
2011-12-15 01:27:59 +01:00
That's all there is to it!
2017-05-10 16:20:38 +02:00
## Loading from Configuration
2011-12-15 13:46:37 +01:00
2017-05-10 16:20:38 +02:00
To be able to load extensions from your Akka configuration you must add FQCNs of implementations of either `ExtensionId` or `ExtensionIdProvider`
in the `akka.extensions` section of the config you provide to your `ActorSystem` .
2011-12-15 13:46:37 +01:00
2017-06-14 18:01:27 +09:00
Scala
2018-09-13 10:49:51 +02:00
: @@snip [ExtensionDocSpec.scala ](/akka-docs/src/test/scala/docs/extension/ExtensionDocSpec.scala ) { #config }
2017-06-14 18:01:27 +09:00
Java
: @@@vars
```
akka {
extensions = ["docs.extension.ExtensionDocTest.CountExtension"]
}
```
@@@
2012-01-30 16:47:33 +01:00
2017-05-10 16:20:38 +02:00
## Applicability
2011-12-15 01:27:59 +01:00
The sky is the limit!
2017-05-10 16:20:38 +02:00
By the way, did you know that Akka's `Typed Actors` , `Serialization` and other features are implemented as Akka Extensions?
2012-01-20 11:30:33 +01:00
2017-05-11 17:27:57 +02:00
< a id = "extending-akka-settings" > < / a >
2017-05-10 16:20:38 +02:00
### Application specific settings
2012-01-20 11:30:33 +01:00
2017-05-11 17:27:57 +02:00
The @ref: [configuration ](general/configuration.md ) can be used for application specific settings. A good practice is to place those settings in an Extension.
2012-01-20 11:30:33 +01:00
Sample configuration:
2018-09-13 10:49:51 +02:00
@@snip [SettingsExtensionDocSpec.scala ](/akka-docs/src/test/scala/docs/extension/SettingsExtensionDocSpec.scala ) { #config }
2012-01-20 11:30:33 +01:00
2017-05-10 16:20:38 +02:00
The `Extension` :
2012-01-20 11:30:33 +01:00
2017-06-14 18:01:27 +09:00
Scala
2018-09-13 10:49:51 +02:00
: @@snip [SettingsExtensionDocSpec.scala ](/akka-docs/src/test/scala/docs/extension/SettingsExtensionDocSpec.scala ) { #imports #extension #extensionid }
2017-06-14 18:01:27 +09:00
Java
2018-09-13 10:49:51 +02:00
: @@snip [SettingsExtensionDocTest.java ](/akka-docs/src/test/java/jdocs/extension/SettingsExtensionDocTest.java ) { #imports #extension #extensionid }
2012-01-20 11:30:33 +01:00
Use it:
2017-06-14 18:01:27 +09:00
Scala
2018-09-13 10:49:51 +02:00
: @@snip [SettingsExtensionDocSpec.scala ](/akka-docs/src/test/scala/docs/extension/SettingsExtensionDocSpec.scala ) { #extension -usage-actor }
2017-06-14 18:01:27 +09:00
Java
2018-09-13 10:49:51 +02:00
: @@snip [SettingsExtensionDocTest.java ](/akka-docs/src/test/java/jdocs/extension/SettingsExtensionDocTest.java ) { #extension -usage-actor }
2012-01-20 11:30:33 +01:00
2017-05-10 16:20:38 +02:00
## Library extensions
2016-04-15 15:12:35 +02:00
A third part library may register it's extension for auto-loading on actor system startup by appending it to
2017-05-10 16:20:38 +02:00
`akka.library-extensions` in its `reference.conf` .
2016-04-15 15:12:35 +02:00
2017-05-10 16:20:38 +02:00
```
akka.library-extensions += "docs.extension.ExampleExtension"
```
2016-04-15 15:12:35 +02:00
As there is no way to selectively remove such extensions, it should be used with care and only when there is no case
where the user would ever want it disabled or have specific support for disabling such sub-features. One example where
this could be important is in tests.
2017-05-10 16:20:38 +02:00
@@@ warning
The``akka.library-extensions`` must never be assigned (` = ["Extension"]`) instead of appending as this will break
the library-extension mechanism and make behavior depend on class path ordering.
2018-09-13 10:49:51 +02:00
@@@