如何取消Linux数据库只读模式?

操作前关键准备

  1. 备份数据库
    执行任何写操作前,使用以下命令备份(以MySQL为例):

    mysqldump -u [用户名] -p --all-databases > full_backup.sql
  2. 检查只读状态
    登录数据库确认当前状态:

    SHOW VARIABLES LIKE 'read_only';  -- MySQL
    SELECT pg_is_in_recovery();       -- PostgreSQL(返回 f 表示非只读)

**二、取消只读模式的具体步骤

MySQL/MariaDB

方法1:动态修改(无需重启)

SET GLOBAL read_only = OFF;          -- 取消全局只读
SET GLOBAL super_read_only = OFF;    -- 若启用超级只读需额外关闭

方法2:修改配置文件(需重启)
编辑 /etc/my.cnf/etc/mysql/my.cnf

[mysqld]
read_only = OFF          # 删除或设为OFF
super_read_only = OFF    # 同上

重启服务生效:

systemctl restart mysqld

PostgreSQL

步骤:

  1. 结束恢复模式(如主从架构中的从库):
    pg_ctl promote -D /var/lib/pgsql/data/  # 提升从库为主库
  2. 单机环境修改配置:
    编辑 postgresql.conf

    default_transaction_read_only = off  # 确保为off

    重启服务:

    systemctl restart postgresql

Redis

redis-cli
127.0.0.1:6379> CONFIG SET replica-read-only no  # 关闭副本只读
127.0.0.1:6379> CONFIG REWRITE                  # 持久化配置

MongoDB

use admin
db.adminCommand({ setParameter: 1, readOnly: false })  // 取消只读

验证是否成功

  • MySQL
    SHOW VARIABLES LIKE 'read_only';  -- 结果应为 OFF
  • PostgreSQL
    INSERT INTO test_table (col) VALUES ('write_test');  -- 测试写入
  • 通用检查
    观察应用日志或使用监控工具(如Prometheus)确认写操作恢复。

常见问题解决

  1. 权限不足导致失败

    ERROR 1227 (42000): Access denied; need SUPER privilege

    解决方案:使用具有 SUPER 权限的账户操作。

  2. PostgreSQL从库无法取消只读
    需先停止主从同步:

    pg_ctl stop -D /var/lib/pgsql/data/
    rm -f /var/lib/pgsql/data/standby.signal  # 删除触发恢复的信号文件
    pg_ctl start -D /var/lib/pgsql/data/
  3. 配置文件修改后未生效

    • 检查配置路径是否正确:mysql --help | grep "my.cnf"
    • 确认服务重启:systemctl status mysqld

安全建议

  1. 只读场景推荐
    • 从库查询分离时保持只读
    • 数据备份期间启用只读防误操作
  2. 操作后监控
    使用 tophtopvmstat 观察服务器负载,避免突发写入导致资源过载。

重要提示:生产环境操作前必须备份数据并制定回滚方案,如遇复杂架构(如集群、主从复制),建议结合数据库文档操作。


引用说明

  • MySQL 8.0 Reference Manual: read_only System Variable
  • PostgreSQL Documentation: Recovery Configuration
  • Redis Commands: CONFIG SET
  • MongoDB Manual: readOnly Mode

原创文章,发布者:酷番叔,转转请注明出处:https://cloud.kd.cn/ask/6375.html

(0)
酷番叔酷番叔
上一篇 2025年7月5日 22:57
下一篇 2025年7月5日 23:59

相关推荐

  • Linux粘贴快捷键为何不同?

    图形界面(GUI)粘贴适用于 GNOME、KDE、XFCE 等桌面环境:通用快捷键:Ctrl + V适用于大多数图形应用(文本编辑器、浏览器、办公软件等),鼠标中键粘贴:选中文本后,直接点击鼠标滚轮(中键) 可快速粘贴(源自 X Window 系统的剪贴板设计),终端(Terminal)粘贴不同终端模拟器的行为……

    2025年7月29日
    12900
  • linux如何启动root权限

    Linux 中,可通过切换到 root 用户(如 su 或 sudo -i)

    2025年8月16日
    9800
  • 在Linux操作系统中,如何准确查看当前所有进程的详细信息及运行状态?

    在Linux系统中,进程是程序执行的基本单元,查看当前进程是系统管理、性能监控和故障排查的核心操作,Linux提供了多种命令来查看进程信息,包括静态快照、动态实时监控、进程关系分析等,每种工具适用于不同场景,本文将详细介绍常用进程查看命令的用法、参数及输出解析,帮助用户高效掌握进程管理技能,ps命令:静态进程快……

    2025年9月9日
    11700
  • 在Linux系统中如何具体查看U盘格式并读取文件内容?

    在Linux系统中查看U盘的文件系统格式并访问其中的文件,是日常操作中常见的需求,由于Linux对多种文件系统(如FAT32、NTFS、exFAT、ext4等)的支持情况不同,且不同发行版的操作方式略有差异,掌握正确的方法能避免很多麻烦,下面将详细介绍从识别U盘到查看格式、访问文件的完整流程,以及常见问题的解决……

    2025年10月8日
    10600
  • 如何查看Linux进程状态?ps、top命令详解?

    在Linux系统中,进程是程序执行的基本单位,查看进程状态是系统管理和故障排查的核心操作,Linux进程状态通过特定标识符描述,可通过多种命令工具实时或静态获取,帮助用户监控进程运行情况、资源占用及父子关系,本文将详细介绍查看Linux进程状态的各类方法、工具及参数使用,并结合实例说明输出含义,Linux进程状……

    2025年9月26日
    8600

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

联系我们

400-880-8834

在线咨询: QQ交谈

邮件:HI@E.KD.CN

关注微信