npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2026 – Pkg Stats / Ryan Hefner

micro-service-maker

v1.1.6

Published

This monorepo serves as the main entry point and controller for all microservices under a single gateway. It uses TypeScript, Express, and custom tooling to streamline development.

Downloads

41

Readme

🚀 Project architecture

This monorepo serves as the main entry point and controller for all microservices under a single gateway. It uses TypeScript, Express, and custom tooling to streamline development.


📁 Project Structure

microservice/
├── services/
│   └── gateway/            # Main gateway application
├── src/
│   ├── app.ts              # Configurations of concurrently running services
│   ├── servers.json        # List of all services
│   ├── install-all.ts      # Installs all services' dependencies
│   └── uninstall-all.ts    # Removes all services' node_modules
├── dist/                   # Compiled JavaScript
├── package.json
└── tsconfig.json

Recommended:

To avoid configuration mistakes and save setup time, it is recommended to clone the ready-made repository from the link below instead of creating the project structure manually.

🔗 Repo link-

After cloning this repository to your system, run the following command in the root directory to install the micro-service-maker package:

npm install micro-service-maker

⬇️ After this section, you can continue with the next process or steps as required.

📦 Scripts

| Command | Description | |--------|-------------| | npx msm | 🔧 Create a new service inside the services/ folder. You will be prompted to enter a service name. | | npm run install-all | 📦 Installs dependencies in all services by running. | | npm run uninstall-all | ❌ Deletes node_modules from each service folder. | | npm run dev | 🛠️ Runs the gateway in development mode using ts-node-dev. |


🧰 Tech Stack

  • Node.js
  • Express.js
  • TypeScript
  • Mongoose
  • ts-node-dev
  • msm (Service Generator)

🧪 Creating a New Service

To scaffold a new microservice:

npx msm

👉 Then type the desired service name when prompted.
📁 The new service will be generated automatically inside the services/ folder.


🐳 Docker Compose

This project comes with built-in support for Redis and RabbitMQ using Docker Compose.

docker-compose.yml

version: '3.9'

services:
  redis:
    image: redis:7-alpine
    container_name: redis
    restart: unless-stopped
    ports:
      - "6379:6379"
    volumes:
      - redis_data:/data

  rabbitmq:
    image: rabbitmq:3-management
    container_name: rabbitmq
    restart: unless-stopped
    ports:
      - "5672:5672"
      - "15672:15672"
    environment:
      RABBITMQ_DEFAULT_USER: admin
      RABBITMQ_DEFAULT_PASS: admin

volumes:
  redis_data:

To start services:

docker-compose up -d

To stop services:

docker-compose down

📋 Prerequisites

  • Node.js v16+
  • npm
  • Docker & Docker Compose

👨‍💻 Maintained by

Satyam Sharma
🔗 Satyam Sharma