From aebdccb6a5a649be67eeaaa9c6bb20cbff6e769b Mon Sep 17 00:00:00 2001 From: Georgii Petrov Date: Tue, 4 Jun 2024 12:03:22 +0300 Subject: [PATCH] [feature] Added mysql timeouts to config --- Common/config/default.json | 5 ++++- DocService/sources/databaseConnectors/mysqlConnector.js | 7 ++++++- 2 files changed, 10 insertions(+), 2 deletions(-) diff --git a/Common/config/default.json b/Common/config/default.json index 170d3868f..80bc963d9 100644 --- a/Common/config/default.json +++ b/Common/config/default.json @@ -241,7 +241,10 @@ "idleTimeoutMillis": 30000 } }, - "mysqlExtraOptions": {} + "mysqlExtraOptions": { + "connectTimeout": 60000, + "queryTimeout": 60000 + } }, "redis": { "name": "redis", diff --git a/DocService/sources/databaseConnectors/mysqlConnector.js b/DocService/sources/databaseConnectors/mysqlConnector.js index d46d4511b..106236c32 100644 --- a/DocService/sources/databaseConnectors/mysqlConnector.js +++ b/DocService/sources/databaseConnectors/mysqlConnector.js @@ -53,6 +53,11 @@ const connectionConfiguration = { const additionalOptions = configSql.get('mysqlExtraOptions'); const configuration = Object.assign({}, connectionConfiguration, additionalOptions); +let queryTimeout = 60000; +if (configuration.queryTimeout) { + queryTimeout = configuration.queryTimeout; + delete configuration.queryTimeout; +} let pool = mysql.createPool(configuration); @@ -68,7 +73,7 @@ async function executeQuery(ctx, sqlCommand, values = [], noModifyRes = false, n try { connection = await pool.getConnection(); - const result = await connection.query(sqlCommand, values); + const result = await connection.query({ sql: sqlCommand, timeout: queryTimeout, values }); let output; if (!noModifyRes) {