Using a local Unix socket connection via the `--socket-name` or `-S` command line flags should not require SSL by default. (it should set --ssl=False by default)
The MySQL command line interface currently already uses this behavior: https://dev.mysql.com/doc/refman/8.4/en/connection-options.html#option_general_ssl-mode
> Connections over Unix socket files are not encrypted with a mode of PREFERRED. To enforce encryption for Unix socket-file connections, use a mode of REQUIRED or stricter. (However, socket-file transport is secure by default, so encrypting a socket-file connection makes it no more secure and increases CPU load.)
I think MariaDB should also use this behavior, encrypting unix socket connections by default is wasteful and will increase CPU as mentioned above. The default for unix socket should be to not encrypt, with the ability to override and encrypt if required.
Examples:
mariadb -S /cloudsql/my-instance -u root -p
|
...
|
ERROR 2026 (HY000): TLS/SSL error: SSL is required, but the server does not support it
|
This should succeed without requiring SSL.
{"report":{"fcp":1696.8000001907349,"ttfb":284.7000002861023,"pageVisibility":"visible","entityId":133046,"key":"jira.project.issue.view-issue","isInitial":true,"threshold":1000,"elementTimings":{},"userDeviceMemory":8,"userDeviceProcessors":64,"apdex":0.5,"journeyId":"efd440a0-e2da-4336-80da-4e7ef7bbda29","navigationType":0,"readyForUser":1764.3000001907349,"redirectCount":0,"resourceLoadedEnd":1331.8000001907349,"resourceLoadedStart":295.59999990463257,"resourceTiming":[{"duration":186.10000038146973,"initiatorType":"link","name":"https://jira.mariadb.org/s/2c21342762a6a02add1c328bed317ffd-CDN/lu2cib/820016/12ta74/0a8bac35585be7fc6c9cc5a0464cd4cf/_/download/contextbatch/css/_super/batch.css","startTime":295.59999990463257,"connectEnd":0,"connectStart":0,"domainLookupEnd":0,"domainLookupStart":0,"fetchStart":295.59999990463257,"redirectEnd":0,"redirectStart":0,"requestStart":0,"responseEnd":481.7000002861023,"responseStart":0,"secureConnectionStart":0},{"duration":186.19999980926514,"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":295.80000019073486,"connectEnd":0,"connectStart":0,"domainLookupEnd":0,"domainLookupStart":0,"fetchStart":295.80000019073486,"redirectEnd":0,"redirectStart":0,"requestStart":0,"responseEnd":482,"responseStart":0,"secureConnectionStart":0},{"duration":796.5,"initiatorType":"script","name":"https://jira.mariadb.org/s/0917945aaa57108d00c5076fea35e069-CDN/lu2cib/820016/12ta74/0a8bac35585be7fc6c9cc5a0464cd4cf/_/download/contextbatch/js/_super/batch.js?locale=en","startTime":296,"connectEnd":296,"connectStart":296,"domainLookupEnd":296,"domainLookupStart":296,"fetchStart":296,"redirectEnd":0,"redirectStart":0,"requestStart":486.90000009536743,"responseEnd":1092.5,"responseStart":512,"secureConnectionStart":296},{"duration":1035.5999999046326,"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":296.2000002861023,"connectEnd":296.2000002861023,"connectStart":296.2000002861023,"domainLookupEnd":296.2000002861023,"domainLookupStart":296.2000002861023,"fetchStart":296.2000002861023,"redirectEnd":0,"redirectStart":0,"requestStart":487,"responseEnd":1331.8000001907349,"responseStart":518.3000001907349,"secureConnectionStart":296.2000002861023},{"duration":228.5,"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":296.59999990463257,"connectEnd":296.59999990463257,"connectStart":296.59999990463257,"domainLookupEnd":296.59999990463257,"domainLookupStart":296.59999990463257,"fetchStart":296.59999990463257,"redirectEnd":0,"redirectStart":0,"requestStart":487.2000002861023,"responseEnd":525.0999999046326,"responseStart":524,"secureConnectionStart":296.59999990463257},{"duration":236.69999980926514,"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":296.90000009536743,"connectEnd":296.90000009536743,"connectStart":296.90000009536743,"domainLookupEnd":296.90000009536743,"domainLookupStart":296.90000009536743,"fetchStart":296.90000009536743,"redirectEnd":0,"redirectStart":0,"requestStart":493.09999990463257,"responseEnd":533.5999999046326,"responseStart":532.5,"secureConnectionStart":296.90000009536743},{"duration":240.5,"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":297.09999990463257,"connectEnd":297.09999990463257,"connectStart":297.09999990463257,"domainLookupEnd":297.09999990463257,"domainLookupStart":297.09999990463257,"fetchStart":297.09999990463257,"redirectEnd":0,"redirectStart":0,"requestStart":493.80000019073486,"responseEnd":537.5999999046326,"responseStart":534.3000001907349,"secureConnectionStart":297.09999990463257},{"duration":186.09999990463257,"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":297.2000002861023,"connectEnd":0,"connectStart":0,"domainLookupEnd":0,"domainLookupStart":0,"fetchStart":297.2000002861023,"redirectEnd":0,"redirectStart":0,"requestStart":0,"responseEnd":483.30000019073486,"responseStart":0,"secureConnectionStart":0},{"duration":240.59999990463257,"initiatorType":"script","name":"https://jira.mariadb.org/rest/api/1.0/shortcuts/820016/47140b6e0a9bc2e4913da06536125810/shortcuts.js?context=issuenavigation&context=issueaction","startTime":297.40000009536743,"connectEnd":297.40000009536743,"connectStart":297.40000009536743,"domainLookupEnd":297.40000009536743,"domainLookupStart":297.40000009536743,"fetchStart":297.40000009536743,"redirectEnd":0,"redirectStart":0,"requestStart":494.09999990463257,"responseEnd":538,"responseStart":535,"secureConnectionStart":297.40000009536743},{"duration":186.5,"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":297.59999990463257,"connectEnd":0,"connectStart":0,"domainLookupEnd":0,"domainLookupStart":0,"fetchStart":297.59999990463257,"redirectEnd":0,"redirectStart":0,"requestStart":0,"responseEnd":484.09999990463257,"responseStart":0,"secureConnectionStart":0},{"duration":249.19999980926514,"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":297.80000019073486,"connectEnd":297.80000019073486,"connectStart":297.80000019073486,"domainLookupEnd":297.80000019073486,"domainLookupStart":297.80000019073486,"fetchStart":297.80000019073486,"redirectEnd":0,"redirectStart":0,"requestStart":494.2000002861023,"responseEnd":547,"responseStart":535.7000002861023,"secureConnectionStart":297.80000019073486},{"duration":965.5,"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":298.5,"connectEnd":298.5,"connectStart":298.5,"domainLookupEnd":298.5,"domainLookupStart":298.5,"fetchStart":298.5,"redirectEnd":0,"redirectStart":0,"requestStart":773.3000001907349,"responseEnd":1264,"responseStart":1256.5,"secureConnectionStart":298.5},{"duration":962,"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":302.30000019073486,"connectEnd":302.30000019073486,"connectStart":302.30000019073486,"domainLookupEnd":302.30000019073486,"domainLookupStart":302.30000019073486,"fetchStart":302.30000019073486,"redirectEnd":0,"redirectStart":0,"requestStart":773.4000000953674,"responseEnd":1264.3000001907349,"responseStart":1257,"secureConnectionStart":302.30000019073486},{"duration":218.09999990463257,"initiatorType":"xmlhttprequest","name":"https://jira.mariadb.org/rest/webResources/1.0/resources","startTime":1262.9000000953674,"connectEnd":1262.9000000953674,"connectStart":1262.9000000953674,"domainLookupEnd":1262.9000000953674,"domainLookupStart":1262.9000000953674,"fetchStart":1262.9000000953674,"redirectEnd":0,"redirectStart":0,"requestStart":1421.5,"responseEnd":1481,"responseStart":1479.4000000953674,"secureConnectionStart":1262.9000000953674}],"fetchStart":0,"domainLookupStart":0,"domainLookupEnd":0,"connectStart":0,"connectEnd":0,"requestStart":99,"responseStart":284,"responseEnd":309,"domLoading":288,"domInteractive":1849,"domContentLoadedEventStart":1849,"domContentLoadedEventEnd":1892,"domComplete":2927,"loadEventStart":2927,"loadEventEnd":2927,"userAgent":"Mozilla/5.0 AppleWebKit/537.36 (KHTML, like Gecko; compatible; ClaudeBot/1.0; +claudebot@anthropic.com)","marks":[{"name":"bigPipe.sidebar-id.start","time":1829.5999999046326},{"name":"bigPipe.sidebar-id.end","time":1830.5999999046326},{"name":"bigPipe.activity-panel-pipe-id.start","time":1830.8000001907349},{"name":"bigPipe.activity-panel-pipe-id.end","time":1832},{"name":"activityTabFullyLoaded","time":1908.9000000953674}],"measures":[],"correlationId":"bf0c29827653db","effectiveType":"4g","downlink":9.9,"rtt":0,"serverDuration":112,"dbReadsTimeInMs":9,"dbConnsTimeInMs":18,"applicationHash":"9d11dbea5f4be3d4cc21f03a88dd11d8c8687422","experiments":[]}}
Generally, I agree.
The only use case it'll break is when users connect via sockets to accounts with REQUIRE clauses like REQUIRE SSL or REQUIRE ISSUER. It'd be good to have a solution for this. "Do nothing, let them fail" is one possible solution.