From 4f3cc90f2e14b0a949436831831644b19e158ee9 Mon Sep 17 00:00:00 2001 From: Tanmoy Sarkar <57363826+tanmoysrt@users.noreply.github.com> Date: Fri, 29 Nov 2024 11:39:53 +0530 Subject: [PATCH] feat(proxysql): add support to configure max database connection --- agent/proxysql.py | 15 +++++++++++---- agent/web.py | 1 + 2 files changed, 12 insertions(+), 4 deletions(-) diff --git a/agent/proxysql.py b/agent/proxysql.py index 077469ad..d7bb8fc0 100644 --- a/agent/proxysql.py +++ b/agent/proxysql.py @@ -25,9 +25,16 @@ def proxysql_execute(self, command): return self.execute(command) @job("Add User to ProxySQL") - def add_user_job(self, username, password, database, backend): + def add_user_job( + self, + username: str, + password: str, + database: str, + backend: dict, + max_connections: int = 4, + ): self.add_backend(backend) - self.add_user(username, password, database, backend) + self.add_user(username, password, database, max_connections, backend) @job("Add Backend to ProxySQL") def add_backend_job(self, backend): @@ -48,7 +55,7 @@ def add_backend(self, backend): self.proxysql_execute(command) @step("Add User to ProxySQL") - def add_user(self, username, password, database, backend): + def add_user(self, username: str, password: str, database: str, max_connections: int, backend: dict): backend_id = backend["id"] commands = [ ( @@ -57,7 +64,7 @@ def add_user(self, username, password, database, backend): "use_ssl, max_connections) " "VALUES ( " f'"{username}", "{password}", {backend_id}, "{database}", ' - "1, 16)" + f"1, {max_connections})" ), "LOAD MYSQL USERS TO RUNTIME", "SAVE MYSQL USERS FROM RUNTIME", diff --git a/agent/web.py b/agent/web.py index 28264039..e0e2eaa2 100644 --- a/agent/web.py +++ b/agent/web.py @@ -1037,6 +1037,7 @@ def proxysql_add_user(): data["password"], data["database"], data["backend"], + max_connections=data["max_connections"], ) return {"job": job}