This is a simple example. A customer can navigate through all his bank accounts and when they find an account which they want to see more information, they click on the account number, and then a new screen is opened with detailed information of the account and transactions for a given account.
There are two core services for account information and transactions
- One service to get account information for a given account or all accounts for a given customer id. They could be retrieved from any backend system like a RDBMS. (rest-accountinfo-service)
- One service to get all transactions for the given account. (rest-transaction-service)
The example also has a third composite service, which aggregates the results of the two core services and returns aggregaged results. The service invokes account information and also transaction service asynchronously and aggreagtes the results.
The composite service is written in different ways.
- 
Using RxJava (rxjava-account-service): RxJava is a Java VM implementation of Reactive Extensions: a library for composing asynchronous and event-based programs by using observable sequences. With RxJava instead of pulling data from an structure, data is pushed to it which reacts with an event that are listened by a subscriber and acts accordantly. You can find more information in https://github.com/Netflix/RxJava. 
- 
Using Java 8 CompletableFuture (java-account-service): CompletableFuture is a monad and a functor. Both Scala and JavaScript allow registering asynchronous callbacks when future is completed. We don't have to wait and block until it's ready. We can simply say: run this function on a result, when it arrives. Moreover, we can stack such functions, combine multiple futures together, etc. 
- 
Using Akka Actor