如何取消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

相关推荐

  • 如何\n让\n网站\n流量\n暴涨?

    方法1:使用 tr 命令(简单替换)tr(translate)是专用于字符替换的工具,适合基础场景:# 处理文件内容tr ' ' '\n' < input.txt > output.txt输出结果:applebananacherry特点:单行命令即可完成,适合快速处理……

    2025年6月15日
    4000
  • 网站打不开是DNS的锅?

    在Linux系统中配置DNS是确保网络连接正常的关键步骤,以下将详细介绍多种配置方法,涵盖主流发行版(如Ubuntu、CentOS、Debian等),并强调安全性和最佳实践,所有操作均需root权限(使用sudo或切换root用户),DNS作用:将域名(如www.example.com)解析为IP地址(如0.2……

    2025年7月24日
    2300
  • 如何进入BIOS/UEFI?不依赖系统,任何电脑通用!

    进入BIOS/UEFI设置是计算机启动初期的硬件层操作,由主板固件控制,其触发方式(特定按键如Del/F2)由硬件制造商设定,完全独立于安装在硬盘上的操作系统(如Windows、Linux或macOS),无论系统存在与否或类型如何均可进入。

    2025年7月13日
    3200
  • Linux系统中如何设置域名解析?具体操作步骤是什么?

    在Linux系统中,域名解析是将人类可读的域名(如www.example.com)转换为机器可读的IP地址(如192.0.2.1)的过程,这一功能主要通过DNS(Domain Name System)协议实现,而Linux系统提供了多种方式配置域名解析,包括本地hosts文件、DNS客户端配置以及网络管理工具等……

    2025年8月21日
    1300
  • linux中如何复制文本文件

    Linux 中,可以使用 cp 命令复制文本文件,`cp source.

    2025年8月9日
    1600

发表回复

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

联系我们

400-880-8834

在线咨询: QQ交谈

邮件:HI@E.KD.CN

关注微信