MySQL主從開啟只讀模式


常見現象

  運維工作中會經常維護MySQL主從服務器,當然Slave我們只是用於讀操作。

一般權限開通也只授權只讀賬號,但是有時候維護工作可能不是一個人在做,你不能保證其他同事都按照這個標准操作。

有同事可能會授權Slave庫MySQL賬號為all或者select,update,insert,delete。還有一種情況是主從做了對所有數據的同步(包括用戶信息),在Master庫上面授權的賬號也同步到了Slave庫上面,當然Master賬號中肯定會有select,update,insert,delete權限。

存在的問題

  那么問題來了,當運維人員或者開發人員程序錯誤的連接了Mysql把Slave當成了Master等情況,那么就悲催了所有的數據修改就到Slave了,也會直接影響到主從的同步。

為了避免上述問題,我們需要給MySQL的Slave設置為只讀模式。

 1、開啟只讀模式

mysql> show global variables like "%read_only%";
mysql> flush tables with read lock;
mysql> set global read_only=1;
mysql> show global variables like "%read_only%";

    關閉只讀

mysql> unlock tables;
mysql> set global read_only=0;

2.對於需要保證master-slave主從同步的salve庫

mysql> set global read_only=1;
改為讀寫模式
mysql> set global read_only=0;

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM