https://github.com/deadislove/nestjs-microkernel-architecture-template
NestJS Microkernel Architecture Template with Docker β A scalable, modular backend template with dynamic plugin loading, including Docker and Docker Compose support for easy setup and deployment.
https://github.com/deadislove/nestjs-microkernel-architecture-template
docker docker-compose env microkernel-architecture nestjs typeorm typescript
Last synced: 7 months ago
JSON representation
NestJS Microkernel Architecture Template with Docker β A scalable, modular backend template with dynamic plugin loading, including Docker and Docker Compose support for easy setup and deployment.
- Host: GitHub
- URL: https://github.com/deadislove/nestjs-microkernel-architecture-template
- Owner: deadislove
- License: mit
- Created: 2025-04-15T16:15:56.000Z (about 1 year ago)
- Default Branch: main
- Last Pushed: 2025-09-26T01:44:51.000Z (8 months ago)
- Last Synced: 2025-09-26T03:46:20.621Z (8 months ago)
- Topics: docker, docker-compose, env, microkernel-architecture, nestjs, typeorm, typescript
- Language: TypeScript
- Homepage:
- Size: 162 KB
- Stars: 2
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
[circleci-image]: https://img.shields.io/circleci/build/github/nestjs/nest/master?token=abc123def456
[circleci-url]: https://circleci.com/gh/nestjs/nest
A progressive Node.js framework for building efficient and scalable server-side applications.


## π§© Project Overview
This template implements a Microkernel (Plug-in) architecture with NestJS. It enables modular design, dynamic feature loading, and scalable domain separation. Itβs well-suited for building feature-rich and extensible backend systems.
## π Architecture Concept
This system is divided into 3 major containers:
- Core Container
- Coordinates plugin lifecycle and provides core services (Logger, Registry, Loader).
- Plugin Container
- Holds feature modules (User, Product, etc.), each as an independent plugin.
- Infrastructure Container
- Provides shared infrastructure like database connections using DatabaseFactory.
The structure promotes low coupling, testability, and scalability.
## π§± Project Structure
Based on the architecture graph, hereβs the folder layout:
```
ββββsrc
β ββββcore
β β ββββcore.module.ts
β β ββββcore.service.ts
β β ββββlogger
β β β ββββlogger.service.ts
β β ββββplugin
β β β ββββplugin.registry.ts
β β β ββββdynamic.loader.ts
β β ββββcore.interface.ts
β β
β ββββplugins
β β ββββuser
β β β ββββuser.module.ts
β β β ββββuser.controller.ts
β β β ββββuser.service.ts
β β β ββββuser.repository.ts
β β β ββββuser.entity.ts
β β ββββproduct
β β ββββproduct.module.ts
β β ββββproduct.controller.ts
β β ββββproduct.service.ts
β β ββββproduct.repository.ts
β β ββββproduct.entity.ts
β β
β ββββinfrastructure
β β ββββdatabase
β β β ββββdatabase.module.ts
β β β ββββdatabase.factory.ts
β β β ββββsqlite
β β β ββββpostgres
β β β ββββmysql
β β
β ββββshared
β ββββmain.ts
ββββtest
```
## π§© Plugin Development Guide
When developing a new plugin, follow the steps below:
1. Create a directory under ```src/plugins```, e.g., order
2. Implement the following components:
- ```order.module.ts```
- ```order.controller.ts```
- ```order.service.ts```
- ```order.repository.ts```
- ```order.entity.ts```
3. Register the plugin in the ```PluginRegistry```
4. (Optional) Implement the ```initialize()``` and ```shutdown()``` lifecycle hooks
5. For logging, use ```LoggerService``` via dependency injection (DI)
## Project setup
```bash
$ npm install
```
## Compile and run the project
```bash
# development
$ npm run start
# watch mode
$ npm run start:dev
# production mode
$ npm run start:prod
```
## Run tests
```bash
# unit tests
$ npm run test
# e2e tests
$ npm run test:e2e
# test coverage
$ npm run test:cov
```
## Deployment
When you're ready to deploy your NestJS application to production, there are some key steps you can take to ensure it runs as efficiently as possible. Check out the [deployment documentation](https://docs.nestjs.com/deployment) for more information.
If you are looking for a cloud-based platform to deploy your NestJS application, check out [Mau](https://mau.nestjs.com), our official platform for deploying NestJS applications on AWS. Mau makes deployment straightforward and fast, requiring just a few simple steps:
```bash
$ npm install -g mau
$ mau deploy
```
With Mau, you can deploy your application in just a few clicks, allowing you to focus on building features rather than managing infrastructure.
## Resources
Check out a few resources that may come in handy when working with NestJS:
- Visit the [NestJS Documentation](https://docs.nestjs.com) to learn more about the framework.
- For questions and support, please visit our [Discord channel](https://discord.gg/G7Qnnhy).
- To dive deeper and get more hands-on experience, check out our official video [courses](https://courses.nestjs.com/).
- Deploy your application to AWS with the help of [NestJS Mau](https://mau.nestjs.com) in just a few clicks.
- Visualize your application graph and interact with the NestJS application in real-time using [NestJS Devtools](https://devtools.nestjs.com).
- Need help with your project (part-time to full-time)? Check out our official [enterprise support](https://enterprise.nestjs.com).
- To stay in the loop and get updates, follow us on [X](https://x.com/nestframework) and [LinkedIn](https://linkedin.com/company/nestjs).
- Looking for a job, or have a job to offer? Check out our official [Jobs board](https://jobs.nestjs.com).
## Support
Nest is an MIT-licensed open source project. It can grow thanks to the sponsors and support by the amazing backers. If you'd like to join them, please [read more here](https://docs.nestjs.com/support).
## Stay in touch
- Author - [Da-Wei Lin](https://www.linkedin.com/in/da-wei-lin-689a35107/)
- Website - [David Weblog](https://davidskyspace.com/)
- Twitter - [@nestframework](https://twitter.com/nestframework)
## License
Nest is [MIT licensed](https://github.com/nestjs/nest/blob/master/LICENSE).