mysql+centos7+主從復制


MYSQL(mariadb)

MariaDB數據庫管理系統是MySQL的一個分支,主要由開源社區在維護,采用GPL授權許可。
開發這個分支的原因之一是:甲骨文公司收購了MySQL后,有將MySQL閉源的潛在風險,因此社區采用分支的方式來避開這個風險。
MariaDB的目的是完全兼容MySQL,包括API和命令行,使之能輕松成為MySQL的代替品。

方法1:yum安裝mariadb

Red Hat Enterprise Linux/CentOS 7.0 發行版已將默認的數據庫從 MySQL 切換到 MariaDB。

第一步:添加 MariaDB yum 倉庫

由於官網的MariaDB版本要比阿里雲的版本要高,所以我們應該優先使用官方的版本

1、首先在 RHEL/CentOS 和 Fedora 操作系統中添加 MariaDB 的 YUM 配置文件 MariaDB.repo 文件。

# 編輯創建mariadb.repo倉庫文件 vi /etc/yum.repos.d/MariaDB.repo
2、添加repo倉庫配置
[mariadb]
name=MariaDB
baseurl=http://yum.mariadb.org/10.5.2/centos7-amd64
gpgkey=https://yum.mariadb.org/RPM-GPG-KEY-MariaDB
gpgcheck=1

第二步:在 CentOS 7 中安裝 MariaDB

3、當 MariaDB 倉庫地址添加好后,你可以通過下面的一行命令輕松安裝 MariaDB。

yum install MariaDB-server MariaDB-client -y
# 由於官方的下載網速太慢,我們教學就使用阿里雲低版本的mariadb數據庫

# 刪除或者重命名剛才創建的Mariadb.repo文件
cd /etc/yum.repos.d
mv Mariadb.repo Mariadb.repo.bak

# 然后一條命令安裝Mariadb
yum install mariadb-server mariadb -y

第三步,啟動mariadb相關命令

mariadb數據庫的相關命令是:

systemctl start mariadb  #啟動MariaDB

systemctl stop mariadb  #停止MariaDB

systemctl restart mariadb  #重啟MariaDB

systemctl enable mariadb  #設置開機啟動

啟動后正常使用mysql

systemctl start mariadb

 

初始化mysql

在確認 MariaDB 數據庫軟件程序安裝完畢並成功啟動后請不要立即使用。為了確保數據 庫的安全性和正常運轉,需要先對數據庫程序進行初始化操作。這個初始化操作涉及下面 5 個 步驟。
➢ 設置 root 管理員在數據庫中的密碼值(注意,該密碼並非 root 管理員在系統中的密 碼,這里的密碼值默認應該為空,可直接按回車鍵)。
➢ 設置 root 管理員在數據庫中的專有密碼。
➢ 隨后刪除匿名賬戶,並使用 root 管理員從遠程登錄數據庫,以確保數據庫上運行的業
務的安全性。
➢ 刪除默認的測試數據庫,取消測試數據庫的一系列訪問權限。
➢ 刷新授權列表,讓初始化的設定立即生效。

確保mariadb服務器啟動后,執行命令初始化

mysql_secure_installation

初始化mysql

 mysql基本命令

# 修改mysql密碼
MariaDB [(none)]> set password = PASSWORD('redhat123');

# 創建數據庫
MariaDB [(none)]> create database qishi
# 創建表
MariaDB [qishi]> create table mylove(id int,name char(32));

生產環境里不會死磕root用戶,為了數據庫的安全以及和其他用戶協同管理數據庫,就需要創建其他數據庫賬戶,然后分配權限,滿足工作需求。

MariaDB [(none)]> create user tiger@'127.0.0.1' identified by 'redhat123';

MariaDB [(none)]> use mysql;

MariaDB [mysql]> select host,user,password from user where user='tiger';

切換普通用戶tiger,查看數據庫信息,發現無法看到完整的數據庫列表

[root@master ~]# mysql -u tiger -p -h 127.0.0.1

MariaDB [(none)]> show databases;
1.啟動mysql
systemctl start mariadb 

2.linux客戶端連接自己 
mysql -uroot -p -h 127.0.0.1

3.遠程鏈接mysql服務端
mysql -uroot -p -h 192.168.11.37

4.修改mysql密碼
MariaDB [(none)]> set password = PASSWORD('redhat123');

5.創建mysql用戶
create user xiaochun@'%' identified by 'xc666';

6.查詢mysql庫中的用戶信息
use mysql;
select host,user,password from  user;

7.授權語句
給小春這個用戶,授予創建數據庫的權限

mysql使用grant命令對賬戶進行授權,grant命令常見格式如下

grant 權限 on 數據庫.表名 to 賬戶@主機名            對特定數據庫中的特定表授權
grant 權限 on 數據庫.* to 賬戶@主機名              對特定數據庫中的所有表給與授權
grant 權限1,權限2,權限3 on *.* to 賬戶@主機名      對所有庫中的所有表給與多個授權
grant all privileges on *.* to 賬戶@主機名      對所有庫和所有表授權所有權限

#授予小春創建的權限,對於所有的庫表生效
grant create  on *.* to xiaochun@"%"  identified by 'xc666';
#授予小春用戶,只有創建mymysql數據庫的權限
grant create  on mymysql.* to xiaochun@"%"  identified by 'xc666';

#授予用戶最大的權限,所有的權限
grant all privileges on *.* to username@'%' identified by 'password';


8.移除權限
MariaDB [(none)]> revoke all privileges on *.* from xiaochun@"%" identified by 'xc666';


9.數據庫的備份與恢復
#備份
mysqldump -u root -p --all-databases > /tmp/db.sql
#數據導入,方式有2種
source /tmp/db.sql;

第二種
mysql -uroot -p <  /tmp/db.sql 


第三種
navicat

第四種,如果你數據量特別大的話,使用第三方工具
xtrabackup
mysql基本命令

數據庫權限設置

mysql使用grant命令對賬戶進行授權,grant命令常見格式如下

grant 權限 on 數據庫.表名 to 賬戶@主機名            對特定數據庫中的特定表授權
grant 權限 on 數據庫.* to 賬戶@主機名              對特定數據庫中的所有表給與授權
grant 權限1,權限2,權限3 on *.* to 賬戶@主機名      對所有庫中的所有表給與多個授權
grant all privileges on *.* to 賬戶@主機名      對所有庫和所有表授權所有權限

退出數據庫,使用root登錄,開始權限設置

[root@master ~]# mysql -uroot -p

MariaDB [(none)]> use mysql;

MariaDB [(none)]> grant all privileges on *.* to tiger@127.0.0.1;

MariaDB [mysql]> show grants for tiger@127.0.0.1;

移除權限

MariaDB [(none)]> revoke all privileges on *.* from tiger@127.0.0.1;

配置mysql

1.中文編碼設置,編輯mysql配置文件/etc/my.cnf,下入以下內容

[mysqld]
character-set-server=utf8
collation-server=utf8_general_ci
log-error=/var/log/mysqld.log
[client]
default-character-set=utf8
[mysql]
default-character-set=utf8

 

2.授權配置

遠程連接設置哦設置所有庫,所有表的所有權限,賦值權限給所有ip地址的root用戶
mysql > grant all privileges on *.* to root@'%' identified by 'password';
#創建用戶
mysql > create user 'username'@'%' identified by 'password';
#刷新權限
flush privileges;

數據庫備份與恢復

mysqldump命令用於備份數據庫數據

[root@master ~]# mysqldump -u root -p --all-databases > /tmp/db.dump

進入mariadb數據庫,刪除一個db

[root@master ~]# mysql -uroot -p

MariaDB [(none)]> drop database s11;

進行數據恢復,吧剛才重定向備份的數據庫文件導入到mysql中

[root@master ~]# mysql -uroot -p < /tmp/db.dump

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重做中繼日志中的事件,將改變反映它自己的數據。
1. 主數據庫寫入數據之后, 會有data changes(數據變化)記錄
2. 有變化記錄之后,將增刪改的一些sql語句記錄到本地的Binary log(二進制日志)中
3. 從庫會一直開啟着一個線程
4. 通過線程去讀取這個二進制日志的內容
5. 從庫會將數據寫入到自己的Relay log(中繼日志)中
6. 從庫會將中繼日志中的操作轉化為SQL thread(SQL語句)
7. 通過轉化的SQL語句寫入到自己的數據庫, 兩邊的數據就一致了
主從復制原理7步曲

master主庫(10.0.0.7)配置

#查看數據庫狀態
systemctl status mariadb
#停mariadb
systemctl stop mariadb

#修改配置文件
vim /etc/my.cnf
#修改內容
#解釋:server-id服務的唯一標識(主從之間都必須不同);log-bin啟動二進制日志名稱為mysql-bin

 [mysqld]
  server-id=1
  log-bin=qishi-logbin

#重啟mariadb
systemctl start mariadb

master主庫(10.0.0.7)添加從庫賬號

1.新建用於主從同步的用戶tiger,允許登錄的從庫是'10.0.0.8'
create user 'xiaochun'@'%' identified by 'xc666';

2.題外話:如果提示密碼太簡單不復合策略加在前面加這句
mysql> set global validate_password_policy=0;

3.給從庫賬號授權,說明給tiger從庫復制的權限,在10.0.0.8機器上復制
grant replication slave on *.* to 'xiaochun'@'%';
# 檢查主庫創建的復制賬號
select user,host from mysql.user;
# 檢查授權賬號的權限
show grants for xiaochun@'10.0.0.8';

4.實現對主數據庫鎖表只讀,防止數據寫入,數據復制失敗
flush table with read lock; 5.檢查主庫的狀態, 並記錄下日志文件的名字,和位置
MariaDB [(none)]> show master status;
+---------------------+----------+--------------+------------------+
| File | Position | Binlog_Do_DB | Binlog_Ignore_DB |
+---------------------+----------+--------------+------------------+
| qishi-logbin.000001 | 1303 | | |
+---------------------+----------+--------------+------------------+
File是二進制日志文件名,Position 是日志開始的位置。后面從庫會用到 后面從庫會用到 后面從庫會用到!!!!!!

6.鎖表后,一定要單獨再打開一個SSH窗口,導出數據庫的所有數據,
[root@oldboy_python ~ 19:32:45]# mysqldump -uroot -p --all-databases > /data/all.sql 

7.確保數據導出后,沒有數據插入,完畢再查看主庫狀態
show master status; 8.導出數據完畢,並配置好從庫開啟主從同步后,再解鎖主庫,恢復可寫;
unlock tables; 9.將備份導出的數據scp至Slave數據庫
scp /data/all.sql root@10.0.0.8:/data/

 

slave從庫(10.0.0.8)配置

1.設置server-id值並關閉binlog功能參數
數據庫的server-id在主從復制體系內是唯一的,Slave的server-id要與主庫和其他從庫不同,並且注釋掉Slave的binlog參數。

2.因此修改Slave的/etc/my.cnf,寫入
[mysqld] server-id=3
read-only=true
# 加上read-only參數表示從庫只讀不寫入

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='10.0.0.7',
master_user='xiaochun',
master_password='xc666',
master_log_file='qishi-logbin.000001',
master_log_pos=1303;

7.啟動從庫的同步開關,測試主從復制的情況
start slave; 8.查看復制狀態
show slave status\G;

 

檢查主從復制是否成功的關鍵在於

確保如下兩條參數,是yes,即主從復制正確

MariaDB [(none)]> show slave status\G
*************************** 1. row ***************************
               Slave_IO_State: Waiting for master to send event
                  Master_Host: 192.168.119.10
                  Master_User: tiger
                  Master_Port: 3306
                Connect_Retry: 60
              Master_Log_File: mysql-bin.000001
          Read_Master_Log_Pos: 1039
               Relay_Log_File: slave-relay-bin.000002
                Relay_Log_Pos: 537
        Relay_Master_Log_File: mysql-bin.000001
             Slave_IO_Running: Yes
            Slave_SQL_Running: Yes

最后再給主庫解鎖

unlock tables;

最后在主庫上刷新授權表

flush privileges;

此時主從同步就已經完成配置了,雙方都登錄xiaochun賬號,在主庫創建一個庫,再看從庫已經成功復制過來了,再到從庫上面嘗試創建庫或寫入數據,無法寫入,因為從庫設置了只讀

tip:

注意此處還未配置從庫的只讀模式,只需在slave服務器上配置/etc/my.cnf,加上以下配置,並且在slave上創建普通用戶,使用普通用戶主從同步即可達到只讀的效果

如果用root用戶,無法達到readonly,這是一個坑

[mysqld]
character-set-server=utf8
collation-server=utf8_general_ci
log-error=/var/log/mysqld.log
server-id=3
read-only=true
[client]
default-character-set=utf8
[mysql]
default-character-set=utf8

最后,提示請看圖: 

 


免責聲明!

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



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