javascript - Node.js pg 池在第二次执行时速度缓慢

标签 javascript node.js postgresql connection-pooling node-pg-pool

我遇到了一个奇怪的问题,我似乎无法解决。

我在 Node.js 应用程序中使用 pg 池,它在第一次执行时运行得非常快,然后在第二次执行时速度显着变慢(30/50 秒)。

我已阅读 GitHub 页面 https://github.com/brianc/node-postgres/wiki/Example 上的文档

这似乎需要使用全局变量,以便不创建多个池,我尝试按如下方式执行此操作。

我的主服务器文件如下

var express = require("express");
var path = require("path");
var app = express();
var port = 3000;

app.use("/public", express.static(process.cwd() + "/public"));

app.set("views", process.cwd() + "/public/views");
app.set("view engine", "ejs");

var login_route = require("./public/logic/login/login_route.js");
app.use(login_route);

app.listen(port, function() {

   var message = "Server Started: Port " + port;
   console.log(message);

});

它使用执行数据库查询的路由文件

var express = require("express");
var router = express.Router();

var pg = require("pg");

var credentials = {
   host: "127.0.0.1",
   port: "5432",
   database: "altaltalt",
   user: "postgres",
   password: "postgres",
   max: 100,
   idleTimeoutMillis: 30000
};

var pool = new pg.Pool(credentials);

// this bit of code is executed
// when a button is clicked
router.get("/exec", function(req, res) {

   pool.connect (
      function(error, client, done) {

         if(error) {
            console.log("connection failed");
         }

         client.query(

            "select * from dummytable",
             function(error, result) {

               done();

               if(error) {
                  console.log(error);
               }

               alert(result.rows);

             }

         );

      }
   );

});

module.exports = router;

当我向该路由发出 get 请求时,一旦按下按钮,它就会执行得非常快,但在此之后的任何时候按下它都会变得非常慢。

我在代码中遗漏了什么吗?是否需要额外的步骤来处理多个请求?

最佳答案

Node 中不存在

alert()。另外,当您接受 HTTP 请求时,您应该发回响应。最后,如果您只想运行一个查询,可以使用pool.query()

一起:

router.get('/exec', function(req, res) {
  pool.query('select * from dummytable', function(error, result) {
    if (error) {
      console.log('query failed');
      return res.sendStatus(500);
    }
    res.send(result.rows);
  });
});

并使用pool.connect():

router.get('/exec', function(req, res) {
  pool.connect(function(error, client, done) {
    if (error) {
      console.log('connection failed');
      return res.sendStatus(500);
    }

    client.query('select * from dummytable', function(error, result) {
      done(error);
      if (error) {
        console.log('query failed');
        return res.sendStatus(500);
      }
      res.send(result.rows);
    });
  });
});

关于javascript - Node.js pg 池在第二次执行时速度缓慢,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/43346895/

相关文章:

javascript - IE 11 使用 Spring Boot/Spring Data REST 通过 ReactJS 中的 Stompjs 使用 Web 套接字检索旧版本的对象

javascript - 将 object.keys 复制到新对象

node.js - Socket.io 0.9 和 1.0 向所有房间成员广播

node.js - 在 Mac 上更新 Node.js : Error while updating Node. js

postgresql - 如何跟踪查询中的多个标识列

arrays - 无法插入 : ERROR: array value must start with "{" or dimension information

python - 在数据库中存储复杂的时间间隔

javascript - 检查元素是否具有给定数组中的任何属性

javascript - 使用父 onclick 事件显示和隐藏隐藏的 div

node.js - 子进程和fork进程 Node js之间共享对象