標籤:資料庫管理 自己 ber 過程 重做 ase ima 令行 資料備份
MariaDB資料庫管理系統是MySQL的一個分支,主要由開源社區在維護,採用GPL授權許可。
開發這個分支的原因之一是:甲骨文公司收購了MySQL後,有將MySQL閉源的潛在風險,因此社區採用分支的方式來避開這個風險。
MariaDB的目的是完全相容MySQL,包括API和命令列,使之能輕鬆成為MySQL的代替品。
方法1:yum安裝mariadb
yum install mariadb-server mariadb
相關命令
mariadb資料庫的相關命令是:systemctl start mariadb #啟動MariaDBsystemctl stop mariadb #停止MariaDBsystemctl restart mariadb #重啟MariaDBsystemctl enable mariadb #設定開機啟動
啟動後正常使用mysql
systemctl start mariadb#進入mysqlmysql -uroot -p
方法2:官網下載mysql-server包(rpm)
# wget http://dev.mysql.com/get/mysql-community-release-el7-5.noarch.rpm# rpm -ivh mysql-community-release-el7-5.noarch.rpm# yum install mysql-community-server
配置mysql
1.中文編碼設定
編輯mysql設定檔/etc/my.cnf[mysqld]character-set-server=utf8datadir=/var/lib/mysqlsocket=/var/lib/mysql/mysql.sockcollation-server=utf8_general_cisecurity riskssymbolic-links=0log-error=/var/log/mysqld.logpid-file=/var/run/mysqld/mysqld.pid[client]default-character-set=utf8[mysql]default-character-set=utf8
2.授權配置
遠端連線設定哦設定所有庫,所有表的所有許可權,賦值許可權給所有ip地址的root使用者
mysql > grant all privileges on *.* to [email protected]‘%‘ identified by ‘password‘;
#建立使用者
mysql > create user ‘username‘@‘%‘ identified by ‘password‘;
#重新整理許可權
flush privileges;
MYSQL主從複製
MySQL資料庫的主從複製方案,是其內建的功能,並且主從複製並不是複製磁碟上的資料庫檔案,而是通過binlog日誌複製到需要同步的從伺服器上。
MySQL資料庫支援單向、雙向、鏈式級聯,等不同業務情境的複製。在複製的過程中,一台伺服器充當主伺服器(Master),接收來自使用者的內容更新,而一個或多個其他的伺服器充當從伺服器(slave),接收來自Master上binlog檔案的日誌內容,解析出SQL,重新更新到Slave,使得主從伺服器資料達到一致。
主從複製的邏輯有以下幾種
一主一從,單向主從同步模式,只能在Master端寫入資料
一主多從
雙主主複製邏輯架構,此架構可以在Master1或Master2進行資料寫入,或者兩端同事寫入(特殊設定)
在生產環境中,MySQL主從複製都是非同步複製方式,即不是嚴格的即時複製,但是給使用者的體驗都是即時的。
MySQL主從複製叢集功能使得MySQL資料庫支援大規模高並發讀寫成為可能,且有效保護了伺服器宕機的資料備份。
應用情境
利用複製功能當Master伺服器出現問題時,我們可以人工的切換到從伺服器繼續提供服務,此時伺服器的資料和宕機時的資料幾乎完全一致。
複製功能也可用作資料備份,但是如果人為的執行drop,delete等語句刪除,那麼從庫的備份功能也就失效了.
主從機制實現原理
(1) master將改變記錄到二進位日誌(binary log)中(這些記錄叫做二進位日誌事件,binary log events); (2) slave將master的binary log events拷貝到它的中繼日誌(relay log); (3) slave重做中繼日誌中的事件,將改變反映它自己的資料。
master主庫配置
#查看資料庫狀態systemctl status mariadb#停mariadbsystemctl stop mariadb
#修改設定檔
vim /etc/my.cnf
#修改內容
#解釋:server-id服務的唯一標識(主從之間都必須不同);log-bin啟動二進位日誌名稱為mysql-bin
[mysqld]
server-id=1
log-bin=mysql-bin
#重啟mariadb
systemctl start mariadb
master主庫添加從庫帳號
1.建立用於主從同步的使用者chaoge,允許登入的從庫是‘192.168.178.130‘create user ‘chaoge‘@‘192.168.178.130‘ identified by ‘redhat‘;2.#題外話:如果提示密碼太簡單不複合策略加在前面加這句mysql> set global validate_password_policy=0;3.給從庫帳號授權,說明給chaoge從庫複製的許可權,在192.168.178.130機器上複製
grant replication slave on *.* to ‘chaoge‘@‘192.168.178.130‘;
#檢查主庫建立的複製帳號
select user,host from mysql.user;
#檢查授權帳號的許可權
show grants for [email protected]‘192.168.178.130‘;
實現對主要資料庫鎖表唯讀,防止資料寫入,資料複製失敗
flush table with read lock;
4.檢查主庫的狀態
MariaDB [(none)]> show master status
-> ;
+------------------+----------+--------------+------------------+
| File | Position | Binlog_Do_DB | Binlog_Ignore_DB |
+------------------+----------+--------------+------------------+
| mysql-bin.000001 | 575 | | |
+------------------+----------+--------------+------------------+
1 row in set (0.00 sec)
File是二進位記錄檔名,Position 是日誌開始的位置。後面從庫會用到 後面從庫會用到 後面從庫會用到!!!!!!
5.鎖表後,一定要單獨再開啟一個SSH視窗,匯出資料庫的所有資料,
[[email protected]_python ~ 19:32:45]#mysqldump -uroot -p --all-databases > /data/all.sql
6.確保資料匯出後,沒有資料插入,完畢再查看主庫狀態
show master status;
7.匯出資料完畢後,解鎖主庫,恢複可寫;
unlock tables;
8.將備份匯出的資料scp至Slave資料庫
scp /data/all.sql [email protected]:/data/
slave從庫配置
1.設定server-id值並關閉binlog功能參數資料庫的server-id在主從複製體系內是唯一的,Slave的server-id要與主庫和其他從庫不同,並且注釋掉Slave的binlog參數。
2.因此修改Slave的/etc/my.cnf,寫入
[mysqld]
server-id=3
3.重啟資料庫
systemctl restart mariadb
4.檢查Slava從資料庫的各項參數
show variables like ‘log_bin‘;
show variables like ‘server_id‘;
5.恢複主庫Master的資料匯入到Slave庫
匯入資料(注意sql檔案的路徑)
mysql>source /data/all.sql;
方法二:
#mysql -uroot -p < abc.sql
6.配置複製的參數,Slave從庫串連Master主庫的配置
mysql > change master to master_host=‘192.168.178.129‘,
master_user=‘chaoge‘,
master_password=‘redhat‘,
master_log_file=‘mysql-bin.000001‘,
master_log_pos=575;
7.啟動從庫的同步開關,測試主從複製的情況
start slave;
8.查看複製狀態
show slave status\G;
檢查主從複製是否成功的關鍵在於
mysql+centos7+主從複製