Writing Micro Service in Scala
Overview
This article was also published on the site: https://dzone.com/articles/a-small-micro-service-developed-in-scala-using-hex.
Scala is a language that I have been using extensively in my work, but with the focus on Big Data using Spark for data processing.
Scala was in my playlist of languages that I wanted to delve into a bit more and not only experiments for the area of Big Data using Spark, but to write a micro service using http and rest for studies.
The idea is to apply the concept of Hexagonal Architecture (ports and adapters). My micro-service is called a Sparrow Account, and the source code is available in GitHub. I also did a similar experiment in using the Clojure language that you can see in GitHub.
Let’s go to the requirements.
1. Micro-Service Requirements
Create a micro-service that checks and creates a hypothetical bank account.
It must comprise a HTTP Server with two endpoints:
- One to insert a new monetary transaction, money in or out, for a given user;
- One to return a user’s current balance.
Requirements:
- It must not be possible to withdraw money for a given user when they don’t have enough balance;
- You should take concurrency issues into consideration;
- Store data in memory;
- Designer partners and good coding practices:
- Immutability;
- Separation of concerns;
- Unit and integration tests;
- API design;
- Error handling;
- Language idiomatic use;
- Use functional programming paradigm.
Proposed Solution:
The architecture of the proposed solution follows the Hexagonal Architecture concept. The design is based on two books:
Example Diagram of a Hexagonal Architecture:
Organization Application Package Diagram:
1.1 Http Rest Server
To build a request and response Http Rest Server, Finagle-Finch was used:
Piece of code where the server is used: src/main/scala/sparrow/account/ServerApp.scala
The EndPoints available on the server:
Method | EndPoint | Example Parameter |
---|---|---|
POST | /account | {“uuid”:”1”, “amount”:100.50} |
GET | /balance | not required |
Piece of code of the routes with the EndPoints: src/main/scala/sparrow/account/ServerApp.scala
There are two EndPoints fillAccount that can create an account and deposit a value, as well as can withdraw using the negative value. And the EndPoint balanceAccount to see the balance available to the user.
1.2 Transactional Memory and Concurrency Control
When we are talking about micro-service, we have to guarantee the atomicity of the code, so that no undue competition occurs. To control concurrency the ScalaSTM was used.
Piece of code where atomicity is used: src/main/scala/sparrow/account/controller/AccountController.scala
1.3 Other Tools Used
Other tools used in the project are in the order below:
1.4 Building the Project
To build the project can follow the instructions in the own repository of the git hub located here:
Conclusion
We saw in this short article how easy and simple it is to create a micro-service application using Scala language. It could also have used other libraries such as the AKKA that I predict will soon make an article about it.
Thanks!