1. 程式人生 > >liinux安裝 mysql 及主從複製 mysql+centos7+主從複製

liinux安裝 mysql 及主從複製 mysql+centos7+主從複製

mariadb其實就是mysql
mysql已經被oracle收購,它即將閉源,馬上要開始收費了
因此還想免費試用開源的資料庫mysql,就在centos7上,將mysql分支為mariadb
安裝mariadb,在centos7底下:
linux軟體包的格式  mysql.rpm 1.通過yum去安裝
 1.linux的yum軟體管理目錄在 /etc/yum.repos.d
 2.在這個目錄底下,主要是*.repo這個檔案,就會被識別為yum原始檔
 
第一種方式是,通過阿里雲的yum源去下載(第三方的yum源,可能會版本較低,且軟體不全,可能找不到)
CentOS-Base.repo    epel.repo    yum install mariadb-server   #yum安裝mariadb    因為這個阿里雲特別快,咱們用他去學習,加速下載  300kb/s
 
 mariadb-server                     x86_64                     1:5.5.60-1.el7_5                       base                      11 M
 為依賴而安裝:
 mariadb                            x86_64                     1:5.5.60-1.el7_5                       base                     8.9 M
 perl-DBD-MySQL                     x86_64                     4.023-6.el7                            base                     140 k
 為依賴而更新:
 mariadb-libs                       x86_64                     1:5.5.60-1.el7_5                       base                     758 k  
第二種方式是,通過mariadb官方的yum源去下載(一定是這個軟體最正確的yum源,且包都是最新的)
 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.1/centos7-amd64
 gpgkey=https://yum.mariadb.org/RPM-GPG-KEY-MariaDB
 gpgcheck=1  第二步:在 CentOS 7 中安裝 MariaDB
 2、當 MariaDB 倉庫地址新增好後,你可以通過下面的一行命令輕鬆安裝 MariaDB。  yum install MariaDB-server MariaDB-client -y
 
 yum install MariaDB-server MariaDB-client  #區分大小寫  ,這個方式是取國外下載mariadb,速度太慢  30kb/s  依賴關係解決 =====================================================================================================================================
 Package                              架構                  版本                                        源                      大小
=====================================================================================================================================
正在安裝:
 MariaDB-client                       x86_64                10.1.37-1.el7.centos                        mariadb                 40 M
 MariaDB-server                       x86_64                10.1.37-1.el7.centos                        mariadb                104 M
 MariaDB-shared                       x86_64                10.1.37-1.el7.centos                        mariadb                1.3 M
      替換  mariadb-libs.x86_64 1:5.5.56-2.el7
為依賴而安裝:
 MariaDB-common                       x86_64                10.1.37-1.el7.centos                        mariadb                123 k
 boost-program-options                x86_64                1.53.0-27.el7                               base                   156 k
 galera                               x86_64                25.3.24-1.rhel7.el7.centos                  mariadb                8.1 M
   
 
1.下載mariadb,通過阿里雲的源
yum install mariadb-server
 
2.通過yum安裝的軟體,systemctl start/stop/restart/status  mariadb 
 
systemctl start mariadb #啟動mariadb資料庫 3.初始化mariadb
mysql_secure_installation    #直接輸入這個命令,設定root密碼,刪除匿名使用者等等操作 4.配置myariadb遠端登入,可以通過windows,pycharm等客戶端進行連線,在遠端登入的話,就必須得輸入redhat這個密碼
grant all privileges on *.* to
[email protected]
'%' identified by 'redhat'; 授予 所有的 許可權  在  所有的庫.所有的表   使用者名稱@"所有的地址"     identified by   "密碼"; 5.重新整理授權表,使得許可權立即生效
flush privileges; 6.更改mysql的密碼
set password = PASSWORD('redhat123'); 7.建立普通使用者s14
create user [email protected]
'%' identified by 's14666'; 8.查詢使用者資訊
select host,user,password  from user; 9.授權語句
grant 許可權 on 資料庫.表名 to 賬戶@主機名            對特定資料庫中的特定表授權
grant 許可權 on 資料庫.* to 賬戶@主機名              對特定資料庫中的所有表給與授權
grant 許可權1,許可權2,許可權3 on *.* to 賬戶@主機名      對所有庫中的所有表給與多個授權
grant all privileges on *.* to 賬戶@主機名      對所有庫和所有表授權所有許可權
grant create,select,insert on *.* to
[email protected]
'%' identified by "s14123" 10.資料庫的中文設定
 1.檢視資料庫編碼
 \s
 2.修改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
 
 3.修改了配置檔案,重啟服務
 systemctl restart mariadb  4.檢視資料庫建立的編碼,只有在更新了資料庫編碼之後,建立的資料庫,才會使用這個編碼
 show create database s16;
 
 5.可以測試建立table,寫入中文資料
 
11.mysql的資料備份
 1.通過命令匯出全部資料
 mysqldump -u root -p --all-databases > /data/db.dump
 2.mysql的資料檔案都放在/var/lib/mysql/* 中,所有的db資訊,以及賬號密碼資訊
 rm -rf /var/lib/mysql/*    #清空mariadb所有資料
 
 3.匯入資料庫的db檔案,在mysql命令列中輸入這個命令
  source /opt/db.dump
 
 4.第二種方式匯入資料,通過mysql命令
 mysql -uroot -p <  /opt/db.dump  ***********************************************************************************************************************************************************************************************************************************************************************
  mysql主從複製的步驟: 環境準備:
準備兩臺伺服器,安裝兩個mariadb 主庫是:192.168.12.96    mater
從庫是:192.168.12.87    slave    主庫的操作如下:
1.開啟binlog功能,修改/etc/my.cnf
vim /etc/my.cnf #寫入 [mysqld]
server-id=1   #指明主庫的身份id為1
log-bin=mysqls14-bin   #指明binlog的日誌名 2.修改了配置檔案,重啟mariadb,使得binlog生效
systemctl restart mariadb  3.登入mysql,檢查主庫的狀態
show master status; 4.建立一個使用者,用於進行主從同步
create user 'kangchen'@'%' identified by 'kangchen666'; 5.授予賬號許可權,授予一個從庫的身份許可權
grant replication slave on *.* to 'kangchen'@'%'; 6.鎖定mysql的表,防止資料寫入
flush table with read lock; 7.主從同步,將從庫與主庫的資料,保持一致後,它倆都在同一個起跑線,然後解除鎖表,一同寫入資料,保證資料一致性
 1.匯出當前的資料,用於slave機器匯入資料,保證在一個起始點
 mysqldump -u root -p --all-databases > /data/db.dump
 2.將此db.dump檔案遠端傳輸給 slave機器,用於匯入
 scp /data/db.dump  [email protected]:/tmp/  3.登入slave從庫,匯入主庫的資料資訊
 mysql >  source /tmp/db.dump
 4.檢視主庫和從庫的資訊,是否一致
8.檢視主庫的狀態資訊,binlog資訊
show master status; 9.解鎖表,開始主從同步
unlock tables;   從庫的設定: 1.在/etc/my.cnf當中開啟server-id ([mysqld]
   server-id=2   #指明主庫的身份id為2)
vim /etc/my.cnf 2.重啟myariadb 3.檢視slave機器的身份資訊
show variables like 'server_id';
show variables like 'log_bin'; 4.通過命令,開啟主從同步技術
change master to master_host='192.168.117.128',
master_user='kangchen',
master_password='kangchen666',
master_log_file='mysqls14-bin.000001',
master_log_pos=1068; 5.開啟slave
start slave; 6.檢查slave狀態,show slave status\G;   檢查兩條引數,如果都是yes,即主從ok
             Slave_IO_Running: Yes
            Slave_SQL_Running: Yes    
7.此時可以在主庫中寫入資料,檢視從庫中是否生成了記錄 主庫:插入資料 從庫:檢查資料    
Mariadb 的sql: 增
create database  s14;
create table s14tb(id int,name char);
insert into s14tb (id ,name) values(1,"s14")   刪
drop database s14;
drop table s14tb;  #刪除整張表
delete from s14tb;   改
update   查
select id,name,addr from table;        

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 倉庫

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.1/centos7-amd64
gpgkey=https://yum.mariadb.org/RPM-GPG-KEY-MariaDB
gpgcheck=1
複製程式碼

第二步:在 CentOS 7 中安裝 MariaDB

2、當 MariaDB 倉庫地址新增好後,你可以通過下面的一行命令輕鬆安裝 MariaDB。

yum install MariaDB-server MariaDB-client -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');

生產環境裡不會死磕root使用者,為了資料庫的安全以及和其他使用者協同管理資料庫,就需要建立其他資料庫賬戶,然後分配許可權,滿足工作需求。

MariaDB [(none)]> create user [email protected]'127.0.0.1' identified by 'redhat123';

MariaDB [(none)]> use mysql;

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

切換普通使用者yuchao,檢視資料庫資訊,發現無法看到完整的資料庫列表

[[email protected] ~]# mysql -uyuchao -p -h 127.0.0.1

MariaDB [(none)]> show databases;

資料庫許可權設定

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

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

退出資料庫,使用root登入,開始許可權設定

複製程式碼
[[email protected] ~]# mysql -uroot -p

MariaDB [(none)]> use mysql;

MariaDB [(none)]> grant all privileges on *.* to [email protected];

MariaDB [mysql]> show grants for [email protected];
複製程式碼

移除許可權

MariaDB [(none)]> revoke all privileges on *.* from [email protected];

配置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 [email protected]'%' identified by 'password';
#建立使用者
mysql > create user 'username'@'%' identified by 'password';
#重新整理許可權
flush privileges;
複製程式碼

資料庫備份與恢復

mysqldump命令用於備份資料庫資料

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

進入mariadb資料庫,刪除一個db

[[email protected] ~]# mysql -uroot -p

MariaDB [(none)]> drop database s11;

進行資料恢復,吧剛才重定向備份的資料庫檔案匯入到mysql中

[[email protected] ~]# 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重做中繼日誌中的事件,將改變反映它自己的資料。

master主庫配置

複製程式碼  
#檢視資料庫狀態
systemctl status mariadb
#停mariadb
systemctl 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;
複製程式碼

 檢查主從複製是否成功的關鍵在於

複製程式碼
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: chaoge
                  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
複製程式碼

 

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
複製程式碼

 

 

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 倉庫

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.1/centos7-amd64
gpgkey=https://yum.mariadb.org/RPM-GPG-KEY-MariaDB
gpgcheck=1
複製程式碼

第二步:在 CentOS 7 中安裝 MariaDB

2、當 MariaDB 倉庫地址新增好後,你可以通過下面的一行命令輕鬆安裝 MariaDB。

yum install MariaDB-server MariaDB-client -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');

生產環境裡不會死磕root使用者,為了資料庫的安全以及和其他使用者協同管理資料庫,就需要建立其他資料庫賬戶,然後分配許可權,滿足工作需求。

MariaDB [(none)]> create user [email protected]'127.0.0.1' identified by 'redhat123';

MariaDB [(none)]> use mysql;

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

切換普通使用者yuchao,檢視資料庫資訊,發現無法看到完整的資料庫列表

[[email protected] ~]# mysql -uyuchao -p -h 127.0.0.1

MariaDB [(none)]> show databases;

資料庫許可權設定

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

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

退出資料庫,使用root登入,開始許可權設定

複製程式碼
[[email protected] ~]# mysql -uroot -p

MariaDB [(none)]> use mysql;

MariaDB [(none)]> grant all privileges on *.* to [email protected];

MariaDB [mysql]> show grants for [email protected];
複製程式碼

移除許可權

MariaDB [(none)]> revoke all privileges on *.* from [email protected];

配置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 [email protected]'%' identified by 'password';
#建立使用者
mysql > create user 'username'@'%' identified by 'password';
#重新整理許可權
flush privileges;
複製程式碼

資料庫備份與恢復

mysqldump命令用於備份資料庫資料

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

進入mariadb資料庫,刪除一個db

[[email protected] ~]# mysql -uroot -p

MariaDB [(none)]> drop database s11;

進行資料恢復,吧剛才重定向備份的資料庫檔案匯入到mysql中

[[email protected] ~]# 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重做中繼日誌中的事件,將改變反映它自己的資料。

master主庫配置

複製程式碼  
#檢視資料庫狀態
systemctl status mariadb
#停mariadb
systemctl 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;
複製程式碼

 檢查主從複製是否成功的關鍵在於

複製程式碼
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: chaoge
                  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
複製程式碼

 

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
複製程式碼