node.js - 使用了node-mysql的代码无法自动停止
伊谢尔伦
伊谢尔伦 2017-04-17 11:09:03
[Node.js讨论组]
// db.js
var mysql = require('mysql');

module.exports = function () {
    var pool = mysql.createPool({
        host: "localhost",
        user: 'xxx',
        password: 'xxx',
        database: 'xxx',
    });

    return pool;
}();


// valid.js
var pool = require('./db.js');

module.exports = function () {
    return {
        isProjectOwner: function (uid, pid, callback) {
            pool.getConnection(function (err, connection) {
                if (err) {
                    callback(err, null);
                }

                var sql = '.....';
                connection.query(sql, [pid, uid], function (err, res, fields) {
                    if (err) {
                        callback(null, false); // Maybe attack
                    }

                    console.log(res);

                    if (res.length) {
                        callback(null, true);
                    } else {
                        callback(null, false);
                    }

                    connection.release();
                });
            });
        },
    };
}();

// tdb.js
var valid = require('./valid.js');

valid.isProjectOwner(2, 1, function (err, result) {
    if (err) {
        throw err;
    }

    console.log(result);
});

在Terminal中运行tdb.js

> $ node tdb.js
[]
false

但是,如果不使用ctrl+c,无法终止进程

我试过用普通的connect(),在回调中没使用connection.end()时也会出现这种问题,使用了的话就能正常结束进程。

新手求教,谢谢~

伊谢尔伦
伊谢尔伦

小伙看你根骨奇佳,潜力无限,来学PHP伐。

全部回复(1)
PHP中文网

连接池没有关闭,自然不会结束

试试pool.end(cb)

热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号