Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/funcode50/moleculer-docker-development
A very simple development enviroment for moleculer with Docker.
https://github.com/funcode50/moleculer-docker-development
Last synced: 2 months ago
JSON representation
A very simple development enviroment for moleculer with Docker.
- Host: GitHub
- URL: https://github.com/funcode50/moleculer-docker-development
- Owner: funcode50
- License: mit
- Created: 2020-04-19T00:51:01.000Z (over 4 years ago)
- Default Branch: master
- Last Pushed: 2018-11-23T20:02:32.000Z (about 6 years ago)
- Last Synced: 2024-08-03T02:03:39.486Z (5 months ago)
- Size: 241 KB
- Stars: 0
- Watchers: 0
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- awesome-moleculer - moleculer-docker-development - Simple development enviroment for moleculer with Docker (Examples / Repositories)
README
# Moleculer Services Development Environment
Moleculer is a very powerful microservice development tool, but getting up to speed if you've never built microservices before can be a bit complex.
This repo is designed to short cut your ability to get up to speed by giving you a simple local development enviroment to get started using Moleculer with Docker.
# What's in this repo:
* Two simple Moleculer services.
* The official Moeleculer API gateway to route calls to the appropriate service.
* A full docker-compose example that spins up containers for each service along with containers for Redis, Postgres DB, and Traefic for rapid development.
* Hot reloading of your Moleculer services for faster development.# To get started:
* Install Docker
* Clone this repo
* npm install
* docker-compose up
* Visit http://localhost:3000/api/serviceOne/askServiceTwo to see one microservice talk to another.
* Open up serviceTwo.service.js and change the "askServiceTwo" function to return something else. Save this file.
* Revisit http://localhost:3000/api/serviceOne/askServiceTwo and see that your change has been hotreloaded.# What is happening at a high level:
* We've got an api gateway setup that calls our services.
* By visiting http://localhost:3000/api/serviceOne/askServiceTwo, the api gateway is calling serviceOne's function "askServiceTwo."
* serviceOne in turn calls a function from serviceTwo named "respondToServiceOne."
* When serviceOne recieves the response from serviceTwo, the api gateway returns the response to the browser.# Moleculer's Magic:
If you've ever worked on a microservices project you'll know that "service discovery" and messaging between services are two of the most common challenges to getting started.Moleculer solves both of these problems out of the box by using a transport mechanism for both service discovery and messaging between services.
In this repo we use Redis, but Moleculer supports several other transport layers out of the box.