Bug 53370

Summary: Обновление конфигурационных файлов MySQL
Product: Sisyphus Reporter: iluha <iluha.companets>
Component: MySQL-serverAssignee: Николай Костригин <nickel>
Status: CLOSED FIXED QA Contact: qa-sisyphus
Severity: normal    
Priority: P5 CC: mike, nickel, rider, shaba
Version: unstable   
Hardware: x86_64   
OS: Linux   

Description iluha 2025-03-09 16:57:20 MSK
Версии MySQL обновляются, а многие параметры в конфигурационных файлах "застряли" ещё со времён 5.*

Есть параметры, которые сейчас лучше использовать по-умолчанию, чем использовать устаревшие значения, приводящие к различным warning'ам.
Comment 1 iluha 2025-03-09 17:02:59 MSK
основной момент - указание кодировки `utf8`, которая в 8-й версии является алиасом `utfmb3`, а по-умолчанию используется `utf8mb4`

предлагаемые изменения:

/lib/systemd/system/mysqld.service
- убрать строку `CHSET=utf8`

/etc/my.cnf.d/client.cnf
- убрать строку `loose-default-character-set`

/etc/my.cnf.d/mysql-clients.cnf
- убрать строку `default-character-set`

/etc/my.cnf.d/server.cnf
- убрать строки с:
`collation-server`
`init-connect`
`character-set-server`
Comment 2 iluha 2025-03-09 17:06:22 MSK
далее, ещё небольшие изменения в `/etc/my.cnf.d/server.cnf`:

- убрать строку с устаревшим параметром `symbolic-links`, значение которого итак равно задаваемому

+ добавить
```
sql-mode="STRICT_TRANS_TABLES,ERROR_FOR_DIVISION_BY_ZERO,NO_ENGINE_SUBSTITUTION,NO_ZERO_DATE,NO_ZERO_IN_DATE"
```
Comment 3 iluha 2025-03-09 17:25:28 MSK
я бы вообще урезал `server.cnf` - убрал репликационные, малоиспользуемые параметры ...

посмотрите, какой генерится конфиг по-умолчанию при установке в Debian из репозитория MySQL


или, альтернатива - сделать "большой" конфиг на основе конфигурации, создаваемой установщиком под Windows
Comment 4 iluha 2025-05-17 09:48:37 MSK
?
Comment 5 iluha 2025-05-28 11:39:01 MSK
?
Comment 6 Николай Костригин 2025-05-29 09:05:55 MSK
Посмотрю.
Comment 7 Николай Костригин 2025-06-04 15:27:44 MSK
См. https://packages.altlinux.org/ru/tasks/search/?q=%23386268

Добавил настройку sql-mode только в качестве подсказки, т.к. изменение умолчания может сломать развернутые системы при обновлении, если приложение не готово к strict mode.
Comment 8 iluha 2025-06-04 15:41:25 MSK
`sql-mode` - это не столь важно, можно не трогать...

самое главное - убрать переопределение кодировок на `utf8` (== `utf8mb3`)
Comment 9 Repository Robot 2025-06-27 19:49:09 MSK
MySQL-8.0.42-alt2 -> sisyphus:

 Fri May 30 2025 Nikolai Kostrigin <nickel@altlinux> 8.0.42-alt2
 - quit forcing obsolete defaults for charset and symbolic links (closes: #53370)
   + server.cnf: add a hint for activating sql strict mode