Node.js RPC框架sonorpc介绍

3,621 阅读1分钟

sonorpc

nodejs rpc github地址

简介

sonorpc是一个轻量级、高性能的node rpc框架,由Registry(注册中心)、Provider(服务提供者)、Consumer(服务消费者)组成,提供远程方法调用、负载均衡、服务自动注册和发现功能。

为什么

我们为什么选择开发sonorpc而不是直接使用dubbo、http?

  1. doubbo没有提供js版本的provider,而我们的主要技术栈为nodejs。
  2. http(s)、JSON PRC的性能不够好,我们使用字节传输和连接池来保证性能。
  3. 我们的规模还不需要使用zookeeper(增加系统复杂性),所以自己开发了注册中心来做负载均衡。

如何使用

npm install sonorpc

import { createProvider } from "sonorpc"

Provider服务提供者

创建服务

DemoService.js

const { Service } = requie("sonorpc");

class DemoService extends Service {
    sayHello(arg1, arg2) {
        return {
            success: true,
            data: ['any data']
        }
    }
}

启动Provider服务

scripts/start.js

const { createProvider } = requie("sonorpc");
const provider = createProvider({
    // 日志类示例
    logger: console,
    // 监听端口
    port: 3005,
    // 服务类
    serviceClasses: [DemoService],
    // 注册中心配置
    registry: {
        // 注册中心地址
        host: '127.0.0.1',
        // 注册中心端口
        port: 3006
    }
});

provider.start(() => {
    console.log('服务已启动');
});

Registry注册中心

scripts/registry.js

const { startRegistry } = require('sonorpc');

startRegistry({
    port: 3006
});

Consumer服务消费者

创建消费者

consumer.js

const { registerConsumer } = require('sonorpc');

const consumer = registerConsumer({
    port: 3006
});

module.exports = consumer;

调用服务

DemoService.js

const consumer = require('../consumer');

class DemoService {
    testMe(...args) {
        return new Promise((resolve, reject) => consumer.invoke('demo.testMe', args, (err, data) => {
            err ? reject(err) : resolve(data);
        }));
    }
}