A simple Node.js stream throttler.
Using yarn:
$ yarn add @kldzj/stream-throttle
Using npm:
$ npm i -S @kldzj/stream-throttle
rate
: The rate in bytes per second at which to emit data.burst
: The burst rate in bytes per second. Must be greather than or equal torate
. Defaults torate
.chunkSize
: The size of chunks to split the received data into. Must be less than or equal torate
. Defaults torate / 10
.
Used to throttle the output rate of a single stream.
import { Throttle } from '@kldzj/stream-throttle';
const throttle = new Throttle({ rate: 10 });
process.stdin.pipe(throttle).pipe(process.stdout);
Used to throttle the output rate across multiple streams.
import { createConnection } from 'net';
import { ThrottleGroup } from '@kldzj/stream-throttle';
const group = new ThrottleGroup({ rate: 1024 * 1024 });
const addr = { host: 'www.google.com', port: 80 };
const throttled1 = createConnection(addr).pipe(group.createThrottle());
const throttled2 = createConnection(addr).pipe(group.createThrottle());
// ...
const group = new ThrottleGroup({ rate: 1024 * 1024 });
// or group = new Throttle({ rate: 1024 * 1024 }).group;
// ...
group.setRate(4 * 1024 * 1024);
// in case you calculate the chunkSize differently
// you should call `setChunkSize` as well, as `setRate`
// recalculates `chunkSize`
group.setChunkSize(group.rate / 6);
// in addition, you can also call `setBurst` if
// you want to change the burst rate
group.setBurst(group.rate * 1.5);
// ...
- @tjgq for the initial implementation (
stream-throttle
).