Version 1.0.1.6 mysqlPool.js configuration is better, but can be better, check MySQL Workbench Connections

This commit is contained in:
ISA
2024-09-05 15:26:42 +02:00
parent 094e27e147
commit 98e8bdf96e

View File

@@ -1,5 +1,4 @@
import mysql from "mysql2/promise"; import mysql from "mysql2/promise";
// Variablen für den Singleton-Pool // Variablen für den Singleton-Pool
let cachedPool; let cachedPool;
let connectionCount = 0; // Zähler für die aktiven Verbindungen let connectionCount = 0; // Zähler für die aktiven Verbindungen
@@ -13,28 +12,41 @@ function getPool() {
password: process.env.DB_PASSWORD, password: process.env.DB_PASSWORD,
database: process.env.DB_NAME, database: process.env.DB_NAME,
port: process.env.DB_PORT, port: process.env.DB_PORT,
connectionLimit: 10, // Setze ein Limit für gleichzeitige Verbindungen connectionLimit: 20, // Setze ein Limit für gleichzeitige Verbindungen
waitForConnections: true, waitForConnections: true,
queueLimit: 0, // Unbegrenzte Warteschlange für Verbindungen queueLimit: 10, // Warteschlangenlimit für Verbindungen
connectTimeout: 5000, // Timeout für Verbindungsversuche (5 Sekunden)
acquireTimeout: 10000, // Timeout für Verbindungsanforderungen aus dem Pool (10 Sekunden)
idleTimeout: 60000, // 1 Minute
}); });
// Ereignisse für das Protokollieren der Verbindungsstatistiken // Ereignisse für das Protokollieren der Verbindungsstatistiken
cachedPool.on("acquire", () => { cachedPool.on("acquire", () => {
connectionCount++; connectionCount++;
console.log("Connection acquired. Active connections: ", connectionCount); console.log(`[ACQUIRE] Active connections: ${connectionCount}`);
}); });
cachedPool.on("release", () => { cachedPool.on("release", () => {
connectionCount--; connectionCount--;
console.log("Connection released. Active connections: ", connectionCount); console.log(`[RELEASE] Active connections: ${connectionCount}`);
}); });
cachedPool.on("enqueue", () => { cachedPool.on("enqueue", () => {
console.log("Waiting for available connection slot."); console.log(`[ENQUEUE] Waiting for available connection slot.`);
}); });
} }
return cachedPool; return cachedPool;
} }
// Optionale Funktion zum Schließen aller Verbindungen im Pool (manuell aufzurufen)
export function closePool() {
if (cachedPool) {
cachedPool.end(() => {
console.log("All pool connections closed.");
});
cachedPool = null; // Setze den Pool auf null, um sicherzustellen, dass er neu erstellt wird, falls benötigt.
}
}
export default getPool; export default getPool;