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

时间:2016-09-28 15:52:22

标签: node.js

在此处查看Async / Await示例:

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()?

1 个答案:

答案 0 :(得分:2)

这些例子并不意味着做同样的事情。而且,第一个示例(在您的代码中)引用了一个从未使用过的变量(conn)。我认为这只是示例代码中的一个错误。

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

第二个示例向您展示如何从池请求空闲连接,使用该连接运行查询(由promise res表示),将连接返回到池(通过调用conn.release() }),然后将结果传播到promise链中。

第二个例子可以改写为:

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

conn.release();

let result = await res;

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

conn.end()(我假设)关闭连接,我猜你应该只在自己明确创建连接时调用它(不同于从池中检索的连接,应该是托管在泳池边。)