This is a software load balancers primary for rest calls.
$ npm i --save @nestcloud/loadbalance
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 {}
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
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');
}
}
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;
}
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 {
}
Import loadbalance module.
field | type | description |
---|---|---|
options.rule | string | global lb rule name |
options.services | ServiceOptions | set service rule |
Import loadbalance module.
field | type | description |
---|---|---|
options.inject | string[] | BOOT CONFIG SERVICE |
Choose a node that running the specific service.
field | type | description |
---|---|---|
service | string | the service name |
List all servers info for all services.
Get loadbalancer.
field | type | description |
---|---|---|
service | string | the service name |
- Author - NestCloud
NestCloud is MIT licensed.