Setting max_connections to 1 is possible on MySQL 5.7 and 8.0, but doesn't work with recent versions of MariaDB. The documentation seems to indicate it should work as it gives the range from 1 to 100000.
MariaDB [(none)]> SHOW GLOBAL VARIABLES LIKE 'max_connections';
I changed the limit to ensure that a user doesn't do anything wrong by accident.
There is no reason to assume that an application will only make one connection to the database.
For example, even the mysql client will on occasions open another connection to the server (for kill).
Another issue, is that if you do anything wrong with one connection (starting a long transaction), there
is now to fix it than killing the serve.
In practice, limiting the connection to 1, may cause unexpected results for the user, so I thought it's better to avoid the issue.
Logging in as the super user and making the server read only is a better way to avoid conflicts than relying on max_connections. Another way is to start server with bootstrap, in which case you know that you are alone.
Michael Widenius
added a comment - I changed the limit to ensure that a user doesn't do anything wrong by accident.
There is no reason to assume that an application will only make one connection to the database.
For example, even the mysql client will on occasions open another connection to the server (for kill).
Another issue, is that if you do anything wrong with one connection (starting a long transaction), there
is now to fix it than killing the serve.
In practice, limiting the connection to 1, may cause unexpected results for the user, so I thought it's better to avoid the issue.
Logging in as the super user and making the server read only is a better way to avoid conflicts than relying on max_connections. Another way is to start server with bootstrap, in which case you know that you are alone.
Thought I should add that in PostgreSQL in addition to max_connections they have a system variable superuser_reserved_connections.
Perhaps that could be an idea for MariaDB as well.
Karl Levik
added a comment - Thought I should add that in PostgreSQL in addition to max_connections they have a system variable superuser_reserved_connections .
Perhaps that could be an idea for MariaDB as well.
MariaDB always have one reserved connection for a superuser. Additionally it can listen on a separate port, it'll be available even when max_connections limit is reached
Sergei Golubchik
added a comment - MariaDB always have one reserved connection for a superuser. Additionally it can listen on a separate port, it'll be available even when max_connections limit is reached
People
Michael Widenius
Karl Levik
Votes:
0Vote for this issue
Watchers:
5Start watching this issue
Dates
Created:
Updated:
Resolved:
Git Integration
Error rendering 'com.xiplink.jira.git.jira_git_plugin:git-issue-webpanel'. Please contact your Jira administrators.
{"report":{"fcp":1227.9000000953674,"ttfb":346.30000019073486,"pageVisibility":"visible","entityId":71899,"key":"jira.project.issue.view-issue","isInitial":true,"threshold":1000,"elementTimings":{},"userDeviceMemory":8,"userDeviceProcessors":64,"apdex":0.5,"journeyId":"f34237df-b18f-4a35-86a6-ee090e594cc9","navigationType":0,"readyForUser":1305.2000000476837,"redirectCount":0,"resourceLoadedEnd":1306.7000000476837,"resourceLoadedStart":352.2000000476837,"resourceTiming":[{"duration":377.90000009536743,"initiatorType":"link","name":"https://jira.mariadb.org/s/2c21342762a6a02add1c328bed317ffd-CDN/lu2cib/820016/12ta74/0a8bac35585be7fc6c9cc5a0464cd4cf/_/download/contextbatch/css/_super/batch.css","startTime":352.2000000476837,"connectEnd":0,"connectStart":0,"domainLookupEnd":0,"domainLookupStart":0,"fetchStart":352.2000000476837,"redirectEnd":0,"redirectStart":0,"requestStart":0,"responseEnd":730.1000001430511,"responseStart":0,"secureConnectionStart":0},{"duration":378.40000009536743,"initiatorType":"link","name":"https://jira.mariadb.org/s/7ebd35e77e471bc30ff0eba799ebc151-CDN/lu2cib/820016/12ta74/494e4c556ecbb29f90a3d3b4f09cb99c/_/download/contextbatch/css/jira.browse.project,project.issue.navigator,jira.view.issue,jira.general,jira.global,atl.general,-_super/batch.css?agile_global_admin_condition=true&jag=true&jira.create.linked.issue=true&slack-enabled=true&whisper-enabled=true","startTime":352.40000009536743,"connectEnd":0,"connectStart":0,"domainLookupEnd":0,"domainLookupStart":0,"fetchStart":352.40000009536743,"redirectEnd":0,"redirectStart":0,"requestStart":0,"responseEnd":730.8000001907349,"responseStart":0,"secureConnectionStart":0},{"duration":433,"initiatorType":"script","name":"https://jira.mariadb.org/s/0917945aaa57108d00c5076fea35e069-CDN/lu2cib/820016/12ta74/0a8bac35585be7fc6c9cc5a0464cd4cf/_/download/contextbatch/js/_super/batch.js?locale=en","startTime":352.7000000476837,"connectEnd":352.7000000476837,"connectStart":352.7000000476837,"domainLookupEnd":352.7000000476837,"domainLookupStart":352.7000000476837,"fetchStart":352.7000000476837,"redirectEnd":0,"redirectStart":0,"requestStart":352.7000000476837,"responseEnd":785.7000000476837,"responseStart":785.7000000476837,"secureConnectionStart":352.7000000476837},{"duration":486.69999980926514,"initiatorType":"script","name":"https://jira.mariadb.org/s/2d8175ec2fa4c816e8023260bd8c1786-CDN/lu2cib/820016/12ta74/494e4c556ecbb29f90a3d3b4f09cb99c/_/download/contextbatch/js/jira.browse.project,project.issue.navigator,jira.view.issue,jira.general,jira.global,atl.general,-_super/batch.js?agile_global_admin_condition=true&jag=true&jira.create.linked.issue=true&locale=en&slack-enabled=true&whisper-enabled=true","startTime":352.80000019073486,"connectEnd":352.80000019073486,"connectStart":352.80000019073486,"domainLookupEnd":352.80000019073486,"domainLookupStart":352.80000019073486,"fetchStart":352.80000019073486,"redirectEnd":0,"redirectStart":0,"requestStart":352.80000019073486,"responseEnd":839.5,"responseStart":839.5,"secureConnectionStart":352.80000019073486},{"duration":489.80000019073486,"initiatorType":"script","name":"https://jira.mariadb.org/s/a9324d6758d385eb45c462685ad88f1d-CDN/lu2cib/820016/12ta74/c92c0caa9a024ae85b0ebdbed7fb4bd7/_/download/contextbatch/js/atl.global,-_super/batch.js?locale=en","startTime":353,"connectEnd":353,"connectStart":353,"domainLookupEnd":353,"domainLookupStart":353,"fetchStart":353,"redirectEnd":0,"redirectStart":0,"requestStart":353,"responseEnd":842.8000001907349,"responseStart":842.8000001907349,"secureConnectionStart":353},{"duration":490,"initiatorType":"script","name":"https://jira.mariadb.org/s/d41d8cd98f00b204e9800998ecf8427e-CDN/lu2cib/820016/12ta74/1.0/_/download/batch/jira.webresources:calendar-en/jira.webresources:calendar-en.js","startTime":353.2000000476837,"connectEnd":353.2000000476837,"connectStart":353.2000000476837,"domainLookupEnd":353.2000000476837,"domainLookupStart":353.2000000476837,"fetchStart":353.2000000476837,"redirectEnd":0,"redirectStart":0,"requestStart":353.2000000476837,"responseEnd":843.2000000476837,"responseStart":843.2000000476837,"secureConnectionStart":353.2000000476837},{"duration":490.2000000476837,"initiatorType":"script","name":"https://jira.mariadb.org/s/d41d8cd98f00b204e9800998ecf8427e-CDN/lu2cib/820016/12ta74/1.0/_/download/batch/jira.webresources:calendar-localisation-moment/jira.webresources:calendar-localisation-moment.js","startTime":353.40000009536743,"connectEnd":353.40000009536743,"connectStart":353.40000009536743,"domainLookupEnd":353.40000009536743,"domainLookupStart":353.40000009536743,"fetchStart":353.40000009536743,"redirectEnd":0,"redirectStart":0,"requestStart":353.40000009536743,"responseEnd":843.6000001430511,"responseStart":843.6000001430511,"secureConnectionStart":353.40000009536743},{"duration":570.2000000476837,"initiatorType":"link","name":"https://jira.mariadb.org/s/b04b06a02d1959df322d9cded3aeecc1-CDN/lu2cib/820016/12ta74/a2ff6aa845ffc9a1d22fe23d9ee791fc/_/download/contextbatch/css/jira.global.look-and-feel,-_super/batch.css","startTime":353.60000014305115,"connectEnd":0,"connectStart":0,"domainLookupEnd":0,"domainLookupStart":0,"fetchStart":353.60000014305115,"redirectEnd":0,"redirectStart":0,"requestStart":0,"responseEnd":923.8000001907349,"responseStart":0,"secureConnectionStart":0},{"duration":490.2999999523163,"initiatorType":"script","name":"https://jira.mariadb.org/rest/api/1.0/shortcuts/820016/47140b6e0a9bc2e4913da06536125810/shortcuts.js?context=issuenavigation&context=issueaction","startTime":353.7000000476837,"connectEnd":353.7000000476837,"connectStart":353.7000000476837,"domainLookupEnd":353.7000000476837,"domainLookupStart":353.7000000476837,"fetchStart":353.7000000476837,"redirectEnd":0,"redirectStart":0,"requestStart":353.7000000476837,"responseEnd":844,"responseStart":844,"secureConnectionStart":353.7000000476837},{"duration":570,"initiatorType":"link","name":"https://jira.mariadb.org/s/3ac36323ba5e4eb0af2aa7ac7211b4bb-CDN/lu2cib/820016/12ta74/d176f0986478cc64f24226b3d20c140d/_/download/contextbatch/css/com.atlassian.jira.projects.sidebar.init,-_super,-project.issue.navigator,-jira.view.issue/batch.css?jira.create.linked.issue=true","startTime":353.90000009536743,"connectEnd":0,"connectStart":0,"domainLookupEnd":0,"domainLookupStart":0,"fetchStart":353.90000009536743,"redirectEnd":0,"redirectStart":0,"requestStart":0,"responseEnd":923.9000000953674,"responseStart":0,"secureConnectionStart":0},{"duration":490.39999985694885,"initiatorType":"script","name":"https://jira.mariadb.org/s/5d5e8fe91fbc506585e83ea3b62ccc4b-CDN/lu2cib/820016/12ta74/d176f0986478cc64f24226b3d20c140d/_/download/contextbatch/js/com.atlassian.jira.projects.sidebar.init,-_super,-project.issue.navigator,-jira.view.issue/batch.js?jira.create.linked.issue=true&locale=en","startTime":354.10000014305115,"connectEnd":354.10000014305115,"connectStart":354.10000014305115,"domainLookupEnd":354.10000014305115,"domainLookupStart":354.10000014305115,"fetchStart":354.10000014305115,"redirectEnd":0,"redirectStart":0,"requestStart":354.10000014305115,"responseEnd":844.5,"responseStart":844.5,"secureConnectionStart":354.10000014305115},{"duration":831.1999998092651,"initiatorType":"script","name":"https://jira.mariadb.org/s/d41d8cd98f00b204e9800998ecf8427e-CDN/lu2cib/820016/12ta74/1.0/_/download/batch/jira.webresources:bigpipe-js/jira.webresources:bigpipe-js.js","startTime":354.80000019073486,"connectEnd":354.80000019073486,"connectStart":354.80000019073486,"domainLookupEnd":354.80000019073486,"domainLookupStart":354.80000019073486,"fetchStart":354.80000019073486,"redirectEnd":0,"redirectStart":0,"requestStart":354.80000019073486,"responseEnd":1186,"responseStart":1186,"secureConnectionStart":354.80000019073486},{"duration":951.7999999523163,"initiatorType":"script","name":"https://jira.mariadb.org/s/d41d8cd98f00b204e9800998ecf8427e-CDN/lu2cib/820016/12ta74/1.0/_/download/batch/jira.webresources:bigpipe-init/jira.webresources:bigpipe-init.js","startTime":354.90000009536743,"connectEnd":354.90000009536743,"connectStart":354.90000009536743,"domainLookupEnd":354.90000009536743,"domainLookupStart":354.90000009536743,"fetchStart":354.90000009536743,"redirectEnd":0,"redirectStart":0,"requestStart":354.90000009536743,"responseEnd":1306.7000000476837,"responseStart":1306.7000000476837,"secureConnectionStart":354.90000009536743},{"duration":251.70000004768372,"initiatorType":"xmlhttprequest","name":"https://jira.mariadb.org/rest/webResources/1.0/resources","startTime":934.9000000953674,"connectEnd":934.9000000953674,"connectStart":934.9000000953674,"domainLookupEnd":934.9000000953674,"domainLookupStart":934.9000000953674,"fetchStart":934.9000000953674,"redirectEnd":0,"redirectStart":0,"requestStart":934.9000000953674,"responseEnd":1186.6000001430511,"responseStart":1186.6000001430511,"secureConnectionStart":934.9000000953674},{"duration":191.60000014305115,"initiatorType":"script","name":"https://www.google-analytics.com/analytics.js","startTime":1221.7000000476837,"connectEnd":0,"connectStart":0,"domainLookupEnd":0,"domainLookupStart":0,"fetchStart":1221.7000000476837,"redirectEnd":0,"redirectStart":0,"requestStart":0,"responseEnd":1413.3000001907349,"responseStart":0,"secureConnectionStart":0}],"fetchStart":0,"domainLookupStart":0,"domainLookupEnd":0,"connectStart":0,"connectEnd":0,"requestStart":183,"responseStart":346,"responseEnd":348,"domLoading":350,"domInteractive":1418,"domContentLoadedEventStart":1418,"domContentLoadedEventEnd":1458,"domComplete":1964,"loadEventStart":1964,"loadEventEnd":1964,"userAgent":"Mozilla/5.0 AppleWebKit/537.36 (KHTML, like Gecko; compatible; ClaudeBot/1.0; +claudebot@anthropic.com)","marks":[{"name":"bigPipe.sidebar-id.start","time":1357.8000001907349},{"name":"bigPipe.sidebar-id.end","time":1358.6000001430511},{"name":"bigPipe.activity-panel-pipe-id.start","time":1358.6000001430511},{"name":"bigPipe.activity-panel-pipe-id.end","time":1360.7000000476837},{"name":"activityTabFullyLoaded","time":1473.2000000476837}],"measures":[],"correlationId":"273f2eb3bed466","effectiveType":"4g","downlink":10,"rtt":0,"serverDuration":102,"dbReadsTimeInMs":15,"dbConnsTimeInMs":25,"applicationHash":"9d11dbea5f4be3d4cc21f03a88dd11d8c8687422","experiments":[]}}
I changed the limit to ensure that a user doesn't do anything wrong by accident.
There is no reason to assume that an application will only make one connection to the database.
For example, even the mysql client will on occasions open another connection to the server (for kill).
Another issue, is that if you do anything wrong with one connection (starting a long transaction), there
is now to fix it than killing the serve.
In practice, limiting the connection to 1, may cause unexpected results for the user, so I thought it's better to avoid the issue.
Logging in as the super user and making the server read only is a better way to avoid conflicts than relying on max_connections. Another way is to start server with bootstrap, in which case you know that you are alone.