Skip to content

Latest commit

 

History

History
 
 

loadbalance

Folders and files

NameName
Last commit message
Last commit date

parent directory

..
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

NestCloud - Loadbalance

NPM Version Package License NPM Downloads Travis Linux Coverage

Description

This is a software load balancers primary for rest calls.

Installation

$ npm i --save @nestcloud/loadbalance

Quick Start

Import Module

Before you import the lb module, you need import @nestcloud/service module at first.

import { Module } from '@nestjs/common';
import { LoadbalanceModule } from '@nestcloud/loadbalance';

@Module({
  imports: [
      LoadbalanceModule.forRoot({
        rule: 'RandomRule',
        services: [{
          name: 'test-service',
          rule: 'RoundRobinRule',
        }],
      })
  ],
})
export class AppModule {}

Import With Boot Module

Except @nestcloud/boot module you can also use @nestcloud/config module too.

app.module.ts:

import { Module } from '@nestjs/common';
import { BOOT } from "@nestcloud/common";
import { BootModule } from "@nestcloud/boot";
import { LoadbalanceModule } from '@nestcloud/loadbalance';
import { resolve } from 'path';

@Module({
  imports: [
    BootModule.forRoot({
      filePath: resolve(__dirname, 'config.yaml'),
    }),
    LoadbalanceModule.forRootAsync({ inject: [BOOT] }),
  ]
})
export class AppModule {
}

config.yaml:

loadbalance:
  rule: RandomRule
  services:
    - name: test-service
      rule: RoundRobinRule

Usage

import { Injectalbe } from '@nestjs/common';
import { InjectLoadbalancee, Loadbalance } from '@nestcloud/loadbalance';

@Injectalbe()
export class TestService {
  constructor(
    @InjectLoadbalancee() private readonly lb: Loadbalance
  ) {
  }

  chooseOneNode() {
      const node = this.lb.choose('your-service-name');
  }
}

Use Choose decorator

It will call lb.choose every you use this.server.

import { Injectable } from '@nestjs/common';
import { Choose, Server } from '@nestcloud/loadbalance';

@Injectable()
export class TestService {
  @Choose('test-service')
  private readonly server: Server;
}

Custom Loadbalance Rule

import { Rule, Loadbalancer } from '@nestcloud/loadbalance';

export class CustomLoadbalanceRule implements Rule {
    private loadbalancer: Loadbalancer;
    
    init(loadbalancer: Loadbalancer) {
        this.loadbalancer = loadbalancer;
    }

    choose() {
        const servers = this.loadbalancer.servers;
        return servers[0];
    }
}
import { Injectable } from '@nestjs/common';
import { UseRules } from '@nestcloud/loadbalance';
import { CustomLoadbalanceRule } from './CustomLoadbalanceRule';

@Injectable()
@UseRules(CustomLoadbalanceRule)
export class LoadbalanceRuleRegister {
}

API

class LoadbalanceModule

static forRoot(options): DynamicModule

Import loadbalance module.

field type description
options.rule string global lb rule name
options.services ServiceOptions set service rule

static forRootAsync(options): DynamicModule

Import loadbalance module.

field type description
options.inject string[] BOOT CONFIG SERVICE

class Loadbalance

choose(service: string): Server

Choose a node that running the specific service.

field type description
service string the service name

state(): {[service: string]: IServer[]}

List all servers info for all services.

chooseLoadbalancer(service: string): Loadbalancer

Get loadbalancer.

field type description
service string the service name

Stay in touch

License

NestCloud is MIT licensed.