From 05680472a74ef8546ed760d2e1da4facf013b2cc Mon Sep 17 00:00:00 2001 From: LouisLam Date: Sun, 22 Aug 2021 02:07:10 +0800 Subject: [PATCH] fix high memory usage --- server/database.js | 33 +++++++++++++++++++++++++-------- 1 file changed, 25 insertions(+), 8 deletions(-) diff --git a/server/database.js b/server/database.js index d5eea619..b396fde0 100644 --- a/server/database.js +++ b/server/database.js @@ -1,5 +1,5 @@ const fs = require("fs"); -const { sleep } = require("../src/util"); +const { sleep, debug, isDev } = require("../src/util"); const { R } = require("redbean-node"); const { setSetting, setting } = require("./util-server"); const knex = require("knex"); @@ -23,20 +23,37 @@ class Database { const Dialect = require("knex/lib/dialects/sqlite3/index.js"); Dialect.prototype._driver = () => sqlite3; - // Disable Pool by overriding acquireConnection() - Dialect.prototype.acquireConnection = async () => { - return this.sqliteInstance; + if (isDev) { + Dialect.prototype.acquireConnectionOrg = Dialect.prototype.acquireConnection; + + Dialect.prototype.acquireConnection = async function () { + let a = await this.acquireConnectionOrg(); + debug("acquired Connection"); + return a; + }; } - Dialect.prototype.releaseConnection = async () => { } + + // Always return same connection. + Dialect.prototype.acquireRawConnection = async function () { + return Database.sqliteInstance; + }; + + Dialect.prototype.destroyRawConnection = async () => { } const knexInstance = knex({ client: Dialect, - connection: { - filename: Database.path, - }, + connection: { }, // Do not remove, Leave it empty is ok useNullAsDefault: true, + pool: { + min: 1, + max: 5, + idleTimeoutMillis: 30000, + } }); + console.log( knexInstance.pool) + console.log("pool size") + R.setup(knexInstance); if (process.env.SQL_LOG === "1") {