Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/lamondlu/Library
A microservice project using .NET Core 2.0, DDD, CQRS, Event Sourcing, Redis and RabbitMQ
https://github.com/lamondlu/Library
consul consul-template cqrs ddd-architecture eda eventsourcing microservice netcore nginx rabbitmq service-discovery signalr
Last synced: 2 months ago
JSON representation
A microservice project using .NET Core 2.0, DDD, CQRS, Event Sourcing, Redis and RabbitMQ
- Host: GitHub
- URL: https://github.com/lamondlu/Library
- Owner: lamondlu
- License: apache-2.0
- Created: 2017-09-24T13:33:14.000Z (over 7 years ago)
- Default Branch: master
- Last Pushed: 2019-02-28T02:14:14.000Z (almost 6 years ago)
- Last Synced: 2024-08-04T09:05:24.465Z (6 months ago)
- Topics: consul, consul-template, cqrs, ddd-architecture, eda, eventsourcing, microservice, netcore, nginx, rabbitmq, service-discovery, signalr
- Language: JavaScript
- Homepage:
- Size: 29.7 MB
- Stars: 132
- Watchers: 17
- Forks: 63
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- awesome-list-microservice - Library
- awesome_dotnet_cloud_ecosystem - Library
README
# Library
A microservice project using .NET Core 2.0, DDD, CQRS, Event Sourcing, Redis and RabbitMQ.## Components
![Components](https://github.com/lamondlu/BookLibrary/blob/master/docs/Architecture/20180108201702.png)## System Architecture
![System Architecture](https://github.com/lamondlu/BookLibrary/blob/master/docs/Architecture/20171107104353.png)## Prerequisites
- Visual Studio 2017 (For development and debug propose)
- RabbitMQ
- Redis
- Consul (Service Discovery and registeration)
- Consult Template (Update and Restart Nginx)
- Nginx (For Load Balance)
- MongoDB (For Event Store)## EDA
![EDA](https://github.com/lamondlu/BookLibrary/blob/master/docs/Architecture/20171108152513.png)## Service Discovery
We will use the Nginx, Consul, Consul Template to create an service discovery and service registeration mechanism.![Service Discovery](https://github.com/lamondlu/BookLibrary/blob/master/docs/Architecture/20180108211340.png)
- The nginx will do the load balance work.
- All the web or api instances will be registered in the consul server with the `SelfRegister` method.
- Consul template will listen the consul server, if there is new instance, consul template will update the nginx.conf with assigned template and restart the nginx server, so the new instance will be connected with the nginx server correctlyUse the Log service as an example.
public void SelfRegister()
{
var serviceDiscovery = InjectContainer.GetInstance();
serviceDiscovery.RegisterService(new Infrastructure.Operation.Core.Models.Service
{
Port = 5003,
ServiceName = "LogService",
Tag = "Microservice API"
});Console.WriteLine("Register to consul successfully.");
}