node-mysql2使用conn.release()vs conn.end()

在这里看一下asynchronous/等待的例子:

https://github.com/sidorares/node-mysql2/blob/master/documentation/Promise-Wrapper.md 

作者使用c.end()

  let mysql = require('mysql2/promise'); let pool = mysql.createPool({database: test}); // execute in parallel, next console.log in 3 seconds await Promise.all([pool.query('select sleep(2)'), pool.query('select sleep(3)')]); console.log('3 seconds after'); await pool.end(); await conn.end(); 

然而,上面只有几行,他使用conn.release()

 pool.getConnection() .then((conn) => { var res = conn.query('select foo from bar'); conn.release(); return res; }) 

一旦我们完成使用连接对象,什么是使用?

应该是conn.release()还是conn.end()?

这些例子并不意味着要做同样的事情。 而且,第一个例子(在你的代码中)引用了一个永远不会使用的variables( conn )。 我认为这只是示例代码中的一个错误。

第一个示例演示如何创build池,运行两个并发查询(使用池),等待所有查询完成,然后清理。 就像我之前说过的, conn.end()在这里没有意义。

第二个例子说明了如何从池中请求一个空闲的连接,使用该连接运行一个查询(由promise res表示),将连接返回到池(通过调用conn.release() ),然后传播结果放下承诺链。

第二个例子可以改写为:

 let conn = await pool.getConnection(); let res = conn.query('select foo from bar'); conn.release(); let result = await res; 

因此, conn.release()用于释放连接回连接池。 它不closures连接,只是使其可用于其他查询。

conn.end() (我假设)closures连接,我想你应该只在你明确地创build连接的时候调用它(不像从池中检索连接,应该由池pipe理 )。