Version 1.0.1.6 mysqlPool.js configuration is better, but can be better, check MySQL Workbench Connections
This commit is contained in:
@@ -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;
|
||||||
|
|||||||
Reference in New Issue
Block a user