dooms

1.0.0 • Public • Published

Dooms

A RPC microservices framework for Node.js, loads a directory as a microservice, calls remote functions in it like s1.say.hi() or call('s1:/say/hi'). Dooms is based on gRPC-node, but no proto files needed, more easy to use.

Server Environment

1. Install Docker (Docker CE recommended)

2. Install Redis in Docker
1) Install: docker pull redis
2) Start: docker run --restart=always --name redis -d -p 6379:6379 -it redis redis-server

Install

npm install dooms --save

Test

Download this repo

git clone https://github.com/hiowenluke/dooms.git
cd dooms
npm install

Test

npm test

TRY IT!

To run this demo, download this repo first if not yet (see above).

1. Run microservices

1) Open a new tab in terminal, then:

node ./examples/service1
# Service s1 is running... 

2) Open a new tab in terminal, then:

node ./examples/service2
# Service s2 is running... 

2. Run client

1) Open a new tab in terminal, then:

node ./examples/client-with-object-style
 
# Microservices #1 
# Microservices #2 
# { msg: 'Hi, I\'m owen, 100 years old.' } 

2) Open a new tab in terminal, then:

node ./examples/client-with-message-style
 
# Microservices #1 
# Microservices #2 
# { msg: 'Hi, I\'m owen, 100 years old.' } 

Usage

1. Create function files in directory "./src" in server project, such as below:

module.exports = async (name, age) => {
    return {msg: `Hi, I'm ${name}${age} years old.`};
};

2. Load the directory "./src" as a microservice named "s1" in index.js.

// "s1"
//      The name of this microservice.
//      It can be omitted if you have only one microservice.
 
// "./src"
//      The root folder name of business files such as "src/say/hi.js".
//      It can be omitted or replaced with other names such as "./biz", "./src", etc.
//      It should be started with ".".
 
require('dooms').initService('s1', './src');

3. Call like s1.say.hi()

const services = require('dooms').initClient();
 
const main = async () => {
    const {s1} = await services();
    const result = await s1.say.hi('owen', 100);
    console.log(result); // {msg: 'Hi, I\'m owen, 100 years old.'}
};
 
main();

4. Call like call('s1:/say/hi')

const call = require('dooms').initCall();
 
const main = async () => {
    const result = await call('s1:/say/hi', 'owen', 100);
    console.log(result); // {msg: 'Hi, I\'m owen, 100 years old.'}
};
 
main();

Options

1. For server

const options = {
 
    // Specify the gRPC options.
    // It can be omitted if the host is "localhost".
    gRPC: {
        host: 'localhost',      // gRPC host
    },
 
    // Specify the Redis options.
    // It can be omitted if it is the default options (like below) of Redis.
    redis: {
        host: 'localhost',      // Redis host
        // port: '6379',           // Redis port
        // db: 0,                  // Redis database number
        // family: 4,              // 4 (IPv4) or 6 (IPv6)
    },
};

Use it

require('dooms').initService('s1', './src', options);

2. For client

Only redis options required.

const options = {
    // Specify the Redis options.
    // It can be omitted if it is the default options (like below) of Redis.
    redis: {
        host: 'localhost',      // Redis host
        // port: '6379',           // Redis port
        // db: 0,                  // Redis database number
        // family: 4,              // 4 (IPv4) or 6 (IPv6)
    },
};

Use it

require('dooms').initClient(options);

Or

require('dooms').initCall(options);

Example

See files in directory examples to learn more.

Performance

Dooms is extended from gRPC-node. It is as fast as gRPC-node, much faster than socket.io-based RPC. (See Benchmark)

Why

License

MIT

Copyright (c) 2019, Owen Luke

Readme

Keywords

none

Package Sidebar

Install

npm i dooms

Weekly Downloads

1

Version

1.0.0

License

MIT

Unpacked Size

23.6 kB

Total Files

26

Last publish

Collaborators

  • owenluke