From 42f003d625f20e84750ac81fa773925b3cde01b6 Mon Sep 17 00:00:00 2001 From: Thomas Segismont Date: Mon, 23 Jan 2023 15:54:41 +0100 Subject: [PATCH] Add MySQL/MariaDB pipelining-limit and use-affected-rows config properties - pipelining limit controls the maximum number of inflight queries (disabled by default) - affected rows changes how rows are counted when executing UPDATE queries --- .../runtime/DataSourceReactiveMySQLConfig.java | 14 ++++++++++++++ .../mysql/client/runtime/MySQLPoolRecorder.java | 8 ++++++++ 2 files changed, 22 insertions(+) diff --git a/extensions/reactive-mysql-client/runtime/src/main/java/io/quarkus/reactive/mysql/client/runtime/DataSourceReactiveMySQLConfig.java b/extensions/reactive-mysql-client/runtime/src/main/java/io/quarkus/reactive/mysql/client/runtime/DataSourceReactiveMySQLConfig.java index b950e3d1a00075..e887b4930992df 100644 --- a/extensions/reactive-mysql-client/runtime/src/main/java/io/quarkus/reactive/mysql/client/runtime/DataSourceReactiveMySQLConfig.java +++ b/extensions/reactive-mysql-client/runtime/src/main/java/io/quarkus/reactive/mysql/client/runtime/DataSourceReactiveMySQLConfig.java @@ -53,4 +53,18 @@ public class DataSourceReactiveMySQLConfig { */ @ConfigItem(defaultValueDocumentation = "default") public Optional authenticationPlugin = Optional.empty(); + + /** + * The maximum number of inflight database commands that can be pipelined. + * By default, pipelining is disabled. + */ + @ConfigItem + public OptionalInt pipeliningLimit = OptionalInt.empty(); + + /** + * Whether to return the number of rows matched by the WHERE clause in UPDATE statements, instead of the + * number of rows actually changed. + */ + @ConfigItem(defaultValueDocumentation = "false") + public Optional useAffectedRows = Optional.empty(); } diff --git a/extensions/reactive-mysql-client/runtime/src/main/java/io/quarkus/reactive/mysql/client/runtime/MySQLPoolRecorder.java b/extensions/reactive-mysql-client/runtime/src/main/java/io/quarkus/reactive/mysql/client/runtime/MySQLPoolRecorder.java index 11921d864bfc4a..e9662b066db8d5 100644 --- a/extensions/reactive-mysql-client/runtime/src/main/java/io/quarkus/reactive/mysql/client/runtime/MySQLPoolRecorder.java +++ b/extensions/reactive-mysql-client/runtime/src/main/java/io/quarkus/reactive/mysql/client/runtime/MySQLPoolRecorder.java @@ -173,6 +173,14 @@ private MySQLConnectOptions toMySQLConnectOptions(DataSourceRuntimeConfig dataSo mysqlConnectOptions.setCollation(dataSourceReactiveMySQLConfig.collation.get()); } + if (dataSourceReactiveMySQLConfig.pipeliningLimit.isPresent()) { + mysqlConnectOptions.setPipeliningLimit(dataSourceReactiveMySQLConfig.pipeliningLimit.getAsInt()); + } + + if (dataSourceReactiveMySQLConfig.useAffectedRows.isPresent()) { + mysqlConnectOptions.setUseAffectedRows(dataSourceReactiveMySQLConfig.useAffectedRows.get()); + } + if (dataSourceReactiveMySQLConfig.sslMode.isPresent()) { final SslMode sslMode = dataSourceReactiveMySQLConfig.sslMode.get(); mysqlConnectOptions.setSslMode(sslMode);