The group wide microservices standards recommendation.
The purpose of this repository is to gather all the requirements which enable cooperation between different teams and companies in development of microservices.
- Keep service small enough to stay focused.
- Every microservice should have own repository with proper README file:
- the microservice purpose section
- installation steps/setup guide or provide setup script
- how to develop/contribute to it
- holding the documentation, e.g. also describes the fired events (and event data)
- The application must be containerized, which means Dockefile must be included.
- Applcation should expose health check i.e.
/health
endpoint. - If application is using database, cache or any other resources, they have to be exlusive per this service only.
- Credentials and all configuration settings that are depending on the environment are always stored/received from environment variables. Samples should be included in the documentation.
- If http API is exposed, swagger/open api spec documentation should be exposed with common url (e.g. /swagger or /doc)
- Unit tests should be include, other type of tests depends of the type of the application.
- Microservice should emit some events to nofity other systems about the actions/state changes.
- Asychronous comunication is preffed than sychronous to avoid tight coupling of microservices. For asynchronous comunication
correlationID
should be included in all type of messages. - Required deployment files should be included i.e. terraform files or Kubernetes helm charts/yaml files.
Although microservices do not have defined exact programming languages and frameworks, they should be developed in the technology which is appropriate to the problem it solves. You should prefer using known languages in the group to enable other team/companies reviewing it.
Preferered languages:
- node.js
- php
- Java or C#
- Usage of DBAL.
- Prepare for scalability/stateless.
- REST API.
- Abstraction for logging.
- docker-compose.yml with all depedencies i.e. database.
- Abstraction for caching.