Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/hemerajs/aither
An example microservice system in Node.js using Hemera and best of today.
https://github.com/hemerajs/aither
hapi hemera jaegertracing microservices-architecture nats traefik
Last synced: 2 months ago
JSON representation
An example microservice system in Node.js using Hemera and best of today.
- Host: GitHub
- URL: https://github.com/hemerajs/aither
- Owner: hemerajs
- License: gpl-3.0
- Created: 2017-01-09T22:34:45.000Z (about 8 years ago)
- Default Branch: master
- Last Pushed: 2018-04-12T19:05:18.000Z (almost 7 years ago)
- Last Synced: 2024-11-01T10:35:19.023Z (3 months ago)
- Topics: hapi, hemera, jaegertracing, microservices-architecture, nats, traefik
- Language: JavaScript
- Homepage:
- Size: 6.01 MB
- Stars: 119
- Watchers: 8
- Forks: 26
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
![aither](https://github.com/hemerajs/aither/blob/master/logo.png?raw=true)
# aitherAither shows an approach how to bootstrap a microservice system in Node.js with [Hemera 5](https://hemerajs.github.io/hemera/) and docker.
You can scale your worker in seconds and because we use NATS as “nervous system" for our distributed system we do not have to worry about service-discovery or load-balancing of hemera-services. We use traefik to load-balancing the api-gateway.This configuration will setup:
* [Hapi](https://github.com/hapijs/hapi) http server which act as api-gateway to the Hemera services.
* [Microservice](https://github.com/hemerajs/aither/blob/master/worker/index.js) which is responsible to add two numbers.
* [NATS](https://github.com/nats-io/gnatsd) server the underlying messaging system for Hemera.
* [Jaeger](https://github.com/jaegertracing/jaeger) CNCF Jaeger, a Distributed Tracing System.
* [Natsboard](https://github.com/devfacet/natsboard) dashboard to monitoring your NATS system in realtime.
* [Traefik](https://traefik.io/) modern HTTP reverse proxy and load balancer made to deploy microservices with ease.
* [Redis](https://redis.io) in memory cache for Hemera.## Versions
* Hapi 17
* Hemera 5## Architecture
![aither](https://github.com/hemerajs/aither/blob/master/aither-architecture.png?raw=true)
## Getting started
* Running the system `docker-compose up`
* Start a request against load balancer [OPEN](http://localhost:8182/api/add?a=1&b=10)
* Scale the system `docker-compose scale math-service=5 api=2`## Dashboards
- Traefik [http://localhost:8181/](http://localhost:8181/)
- NATS Dashboard [http://localhost:3000/](http://localhost:3000/)
- NATS Endpoint [http://localhost:8222/](http://localhost:8222/)
- Jaeger [http://localhost:16686/](http://localhost:16686/)## Run load test
```bash
npm install -g artillery
artillery run loadtest.yml
```
Print the html artillery report with `artillery report `## Previews
### Traefik
![traefik](/traefik.png)
### NATS dashboard
![nats](/nats.png)
### NATS monitoring endpoint
![nats-monitoring](/nats-monitoring.png)
### Jaeger dashboard
![jaeger](/jaeger.png)
## Thank you
thanks most of all to the community who create these awesome opensource software and thereby making it possible.