如何为我的整个Node.js应用程序使用相同的MySQL连接?

 手机用户2602933613 发布于 2023-02-10 12:24

我有一个app.js.我从那里运行我的整个应用程序.

在app.js里面,我有require许多包含代码的文件.

对于这些文件中的每一个,我这样做:

var mysql = require('mysql');
var mclient = mysql.createConnection({
    host: settings.MYSQL.HOST,
    user: settings.MYSQL.USER,
    password: settings.MYSQL.PASSWORD,
    database: settings.MYSQL.DB,
});

基本上,我正在为每个文件启动一个新连接.

我希望我的app.js建立一个连接,然后在require行期间将其传递给每个文件.如何将连接传递给它们以便这些文件可以使用它?

(或者我如何将连接池传递给他们?)

1 个回答
  • 您可以创建一个单独的模块,调用它mysqlLib.js来负责创建池并返回连接:

    var mysql = require("mysql");
    var pool = mysql.createPool(/* credentials go here */);
    
    exports.getConnection = function(callback) {
      pool.getConnection(function(err, conn) {
        if(err) {
          return callback(err);
        }
        callback(err, conn);
      });
    };
    

    在任何需要mysql连接的模块/文件中,您可以这样做:

    var mysqlLib = require("mysqlLib");
    
    mysqlLib.getConnection(function(err, mclient) {
      //do queries that you need
    });
    

    方式require()有效,代码mysqlLib.js只会运行一次,因此即使require("mysqlLib.js"}在多个文件中调用,也只会创建一个池.有关模块缓存的说明,请参见node.js文档的此部分.

    2023-02-10 12:27 回答
撰写答案
今天,你开发时遇到什么问题呢?
立即提问
热门标签
PHP1.CN | 中国最专业的PHP中文社区 | PNG素材下载 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有