Spaces:
Runtime error
Runtime error
# Class: BalancedPool | |
Extends: `undici.Dispatcher` | |
A pool of [Pool](Pool.md) instances connected to multiple upstreams. | |
Requests are not guaranteed to be dispatched in order of invocation. | |
## `new BalancedPool(upstreams [, options])` | |
Arguments: | |
* **upstreams** `URL | string | string[]` - It should only include the **protocol, hostname, and port**. | |
* **options** `BalancedPoolOptions` (optional) | |
### Parameter: `BalancedPoolOptions` | |
Extends: [`PoolOptions`](Pool.md#parameter-pooloptions) | |
* **factory** `(origin: URL, opts: Object) => Dispatcher` - Default: `(origin, opts) => new Pool(origin, opts)` | |
The `PoolOptions` are passed to each of the `Pool` instances being created. | |
## Instance Properties | |
### `BalancedPool.upstreams` | |
Returns an array of upstreams that were previously added. | |
### `BalancedPool.closed` | |
Implements [Client.closed](Client.md#clientclosed) | |
### `BalancedPool.destroyed` | |
Implements [Client.destroyed](Client.md#clientdestroyed) | |
### `Pool.stats` | |
Returns [`PoolStats`](PoolStats.md) instance for this pool. | |
## Instance Methods | |
### `BalancedPool.addUpstream(upstream)` | |
Add an upstream. | |
Arguments: | |
* **upstream** `string` - It should only include the **protocol, hostname, and port**. | |
### `BalancedPool.removeUpstream(upstream)` | |
Removes an upstream that was previously addded. | |
### `BalancedPool.close([callback])` | |
Implements [`Dispatcher.close([callback])`](Dispatcher.md#dispatcherclosecallback-promise). | |
### `BalancedPool.destroy([error, callback])` | |
Implements [`Dispatcher.destroy([error, callback])`](Dispatcher.md#dispatcherdestroyerror-callback-promise). | |
### `BalancedPool.connect(options[, callback])` | |
See [`Dispatcher.connect(options[, callback])`](Dispatcher.md#dispatcherconnectoptions-callback). | |
### `BalancedPool.dispatch(options, handlers)` | |
Implements [`Dispatcher.dispatch(options, handlers)`](Dispatcher.md#dispatcherdispatchoptions-handler). | |
### `BalancedPool.pipeline(options, handler)` | |
See [`Dispatcher.pipeline(options, handler)`](Dispatcher.md#dispatcherpipelineoptions-handler). | |
### `BalancedPool.request(options[, callback])` | |
See [`Dispatcher.request(options [, callback])`](Dispatcher.md#dispatcherrequestoptions-callback). | |
### `BalancedPool.stream(options, factory[, callback])` | |
See [`Dispatcher.stream(options, factory[, callback])`](Dispatcher.md#dispatcherstreamoptions-factory-callback). | |
### `BalancedPool.upgrade(options[, callback])` | |
See [`Dispatcher.upgrade(options[, callback])`](Dispatcher.md#dispatcherupgradeoptions-callback). | |
## Instance Events | |
### Event: `'connect'` | |
See [Dispatcher Event: `'connect'`](Dispatcher.md#event-connect). | |
### Event: `'disconnect'` | |
See [Dispatcher Event: `'disconnect'`](Dispatcher.md#event-disconnect). | |
### Event: `'drain'` | |
See [Dispatcher Event: `'drain'`](Dispatcher.md#event-drain). | |