如何设置MySQL数据库为只读模式以实现高效的数据读取?
- 内容介绍
- 文章标签
- 相关推荐
本文共计839个文字,预计阅读时间需要4分钟。
最直接的方式是使用`SHOW + read_only + 系统变量`,它控制的是非`super`用户能否执行写操作。注意:
SELECT @@global.read_only, @@global.super_read_only;
返回值为 1 表示启用,0 表示关闭。常见误判点是只查了 session 级变量(@@read_only),但该变量不可设,仅反映 global 值的副本。
设置只读从库的正确顺序和关键参数
在主从架构中,只读应作为从库的默认状态,而非临时开关。配置需在 my.cnf 中静态设定,并配合复制状态校验:
-
read_only = ON必须写在[mysqld]段下,重启生效;动态 SET 不推荐用于生产从库,因重启后丢失 - 务必同时设置
super_read_only = ON(MySQL 5.7+),否则具有SUPER权限的账号仍可写入,破坏数据一致性 - 确保
skip_slave_start = OFF(默认),避免意外停止复制后手动启动时绕过只读检查 - 设置完成后,用
SHOW SLAVE STATUS\G确认Slave_IO_Running和Slave_SQL_Running均为Yes,否则只读无意义
为什么有些写操作在 read_only=ON 下仍能成功
这不是 bug,而是 MySQL 的权限与只读机制分层设计导致的。
本文共计839个文字,预计阅读时间需要4分钟。
最直接的方式是使用`SHOW + read_only + 系统变量`,它控制的是非`super`用户能否执行写操作。注意:
SELECT @@global.read_only, @@global.super_read_only;
返回值为 1 表示启用,0 表示关闭。常见误判点是只查了 session 级变量(@@read_only),但该变量不可设,仅反映 global 值的副本。
设置只读从库的正确顺序和关键参数
在主从架构中,只读应作为从库的默认状态,而非临时开关。配置需在 my.cnf 中静态设定,并配合复制状态校验:
-
read_only = ON必须写在[mysqld]段下,重启生效;动态 SET 不推荐用于生产从库,因重启后丢失 - 务必同时设置
super_read_only = ON(MySQL 5.7+),否则具有SUPER权限的账号仍可写入,破坏数据一致性 - 确保
skip_slave_start = OFF(默认),避免意外停止复制后手动启动时绕过只读检查 - 设置完成后,用
SHOW SLAVE STATUS\G确认Slave_IO_Running和Slave_SQL_Running均为Yes,否则只读无意义
为什么有些写操作在 read_only=ON 下仍能成功
这不是 bug,而是 MySQL 的权限与只读机制分层设计导致的。

