coopernurse / node-pool

Generic resource pooling for node.js
2.38k stars 259 forks source link

How to properly fail `factory.create` ? #273

Open silverbucket opened 5 years ago

silverbucket commented 5 years ago

From the documentation it seems that you should not handle exceptions during .createPool() but instead during .aquire(). However if the factory.create() function fails, it continues to retry. I've tried both throwing an exception and rejecting the promise and I'm unable to get any controlled failure path from the operation.

const genericPool = require('generic-pool');
const pool = genericPool.createPool({
  create: () => {
    console.log('create called');
    return new Promise((resolve, reject) => {
      console.log('rejecting promise');
      throw new Error('connection problem');
      //reject('connection problem');
    });
  },
  destroy: () => {
    return new Promise((resolve, reject) => { resolve(); });
  }
}, { max: 2 });

console.log("acquire");
pool.acquire().then((client) => {
  console.log("success");
}, (err) => {
  console.log("controlled failure 1");
}).catch((err) => {
  console.log("controlled failure 2");
});

In the above example, aquire is never reached, and I get an endless loop of 'create called' and 'rejecting promise'. The behaviour is the same if I reject or throw.

...
create called
rejecting promise
create called
rejecting promise
create called
rejecting promise
create called
rejecting promise
^C

How can I reliably handle, for example, connection errors to a database, if the user provides incorrect config? Currently either I get a timeout unhandled exception from the DB library, or a hang/endless loop.

martin-randall-tanium commented 2 years ago

Potential fix and workaround: #221

silverbucket commented 2 years ago

@Kikobeats @sandfox any update on this issue? It continues to be a source of debugging trouble, with any connection error silently causing an endless loop.

alanwu4321 commented 2 years ago

Can we use this to prevent the issue https://github.com/coopernurse/node-pool/issues/175#issuecomment-501826583