MySQL设置从库只读模式
常見現(xiàn)象
運(yùn)維工作中會經(jīng)常維護(hù)MySQL主從服務(wù)器,當(dāng)然Slave我們只是用于讀操作。
一般權(quán)限開通也只授權(quán)只讀賬號,但是有時(shí)候維護(hù)工作可能不是一個(gè)人在做,你不能保證其他同事都按照這個(gè)標(biāo)準(zhǔn)操作。
有同事可能會授權(quán)Slave庫MySQL賬號為all或者select,update,insert,delete。還有一種情況是主從做了對所有數(shù)據(jù)的同步(包括用戶信息),在Master庫上面授權(quán)的賬號也同步到了Slave庫上面,當(dāng)然Master賬號中肯定會有select,update,insert,delete權(quán)限。
存在的問題
那么問題來了,當(dāng)運(yùn)維人員或者開發(fā)人員程序錯誤的連接了Mysql把Slave當(dāng)成了Master等情況,那么就悲催了所有的數(shù)據(jù)修改就到Slave了,也會直接影響到主從的同步。
為了避免上述問題,我們需要給MySQL的Slave設(shè)置為只讀模式。
解決方法
演示如下:
mysql> set global read_only=1; Query OK, 0 rows affected (0.00 sec)#set global read_only=0 為取消普通賬號的只讀模式
授權(quán)普通MySQL測試賬號
mysql> grant select,insert,update,delete on s18.* to 'test'@'127.0.0.1' identifi ed by '123456'; Query OK, 0 rows affected, 1 warning (0.00 sec)用測試賬號登陸進(jìn)行刪除等操作,會提示--read-only錯誤
mysql> delete from student where sid=14; ERROR 1290 (HY000): The MySQL server is running with the --read-only option so i t cannot execute this statementmysql> insert class values(5,三年級十班); ERROR 1290 (HY000): The MySQL server is running with the --read-only option so i t cannot execute this statement注意:set global read_only=1 對擁有super權(quán)限的賬號是不生效的,所以在授權(quán)賬號的時(shí)候盡量避免添加super權(quán)限
那么我們在做數(shù)據(jù)遷移的時(shí)候不想發(fā)生任何數(shù)據(jù)的修改,包括super權(quán)限修改也要限制。
可以用鎖表:
mysql> flush tables with read lock; Query OK, 0 rows affected (0.18 sec)使用root賬號測試:
mysql> delete from student where sid=13; ERROR 1223 (HY000): Can't execute the query because you have a conflicting read lock解鎖測試:
mysql> unlock tables; Query OK, 0 rows affected (0.00 sec) mysql> delete from student where sid=13; Query OK, 0 rows affected (0.00 sec)轉(zhuǎn)載于:https://www.cnblogs.com/sandea/p/9467176.html
總結(jié)
以上是生活随笔為你收集整理的MySQL设置从库只读模式的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: cordova-config.xml配置
- 下一篇: Centos7作为VNCserver,本