mysql ,主從複製

     mysql 之 mariadb     

MariaDB數據庫管理系統是MySQL的一個分支,主要由開源社區在維護,採用GPL受權許可。
開發這個分支的緣由之一是:甲骨文公司收購了MySQL後,有將MySQL閉源的潛在風險,所以社區採用分支的方式來避開這個風險。
MariaDB的目的是徹底兼容MySQL,包括API和命令行,使之能輕鬆成爲MySQL的代替品。

      安裝 mariadb       

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

  步驟1 : 添加MariaDB yum 倉庫     mysql

  配置mariadb的官方yum源,用於自動下載mariadb的rpm軟件包,自動安裝sql

  注意點:阿里雲提供的yum倉庫,和epel源倉庫,它也有mariadb,可是版本可能會很低
數據庫

  注意 : 阿里雲下的mariadb包名是小寫的,而官方的是大寫的 ************vim

# 配置官方的 mariadb 的yum 源,手動建立 Mariadb.repo 倉庫文件 ******
touch /etc/yum.repos.d/MariaDB.repo
# 添加repo倉庫配置 
touch /etc/yum.repos.d/MariaDB.repo 
# 而後寫入以下內容 : 
name = MariaDB
baseurl = http://yum.mariadb.org/10.1/centos7-amd64
gpgkey=https://yum.mariadb.org/RPM-GPG-KEY-MariaDB
gpgcheck=1

 

  步驟2 : 在CentOS7 中安裝 MariaDB     centos

#當 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');
desc  查看錶結構
create database  數據庫名
create table  表名
show create  database  庫名          查看如何建立db的
show create table 表名;            查看如何建立table結構的

   生產環境裏不會死磕root用戶,爲了數據庫的安全以及和其餘用戶協同管理數據庫,就須要建立其餘數據庫帳戶,而後分配權限,知足工做需求。

        #修改mysql的密碼
    MariaDB [(none)]>     set password = PASSWORD('redhat');
        
        #建立mysql的普通用戶,默認權限很是低,%--是容許任何ip連接
    MariaDB [(none)]>     create user ning@'%' identified by 'zhenshuai';
        
        #查詢mysql數據庫中的用戶信息
    MariaDB [(none)]>     use mysql;
    MariaDB [(none)]>     select host,user,password  from user;

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

[root@master ~]# 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 登陸,開始設置權限 : 

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

MariaDB [(none)]> use mysql;

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

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

 移除權限  : 

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

配置 mysql : 

1.設置中文編碼配置 

# 設置mysql的中文編碼支持,修改/etc/my.cnf 

     vi /etc/my.cnf 

# 在[mysqld]中添加參數,使得mariadb服務端支持中文
        [mysqld]
        character-set-server=utf8
        collation-server=utf8_general_ci
# 重啓mariadb服務,讀取my.cnf新配置
        systemctl restart mariadb 
# 登陸數據庫,查看字符編碼
        mysql -uroot -p 
         
# 輸入 \s  查看編碼 

 2 . 受權設置 : 

# 給用戶添加權限命令 
grant all privileges on *.* to 帳戶@主機名      # 對全部庫和全部表受權全部權限

grant all privileges on *.* to ning@'%';         #  ning用戶授予全部權限

flush privileges;                                         #  刷新受權表
# 授予遠程登陸的權限命令 

# 遠程鏈接設置哦設置全部庫,全部表的全部權限,賦值權限給全部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重作中繼日誌中的事件,將改變反映它本身的數據。

 

     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 chaoge@'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窗口,導出數據庫的全部數據,

[root@oldboy_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 root@192.168.178.130:/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

 

      總結     

1.準備主庫的配置文件  /etc/my.cnf 
寫入開啓主庫的參數
    [mysqld]
    server-id=1             #標註 主庫的身份id
    log-bin=s15mysql-bin        #那個binlog的文件名

2.重啓mairadb,讀取配置文件
    systemctl restart mariadb 

3.查看主庫的狀態
    mysql -uroot -p 

    show master status;  #這個命令能夠查看 日誌文件的名字,以及數據起始點 

4.建立用於主從數據同步的帳戶
create user 'yuanhao'@'%' identified by 'yuanhaobuxitou';

5.授予主從同步帳號的,複製數據的權限
grant replication slave on *.* to 'yuanhao'@'%';

6.進行數據庫的鎖表,防止數據寫入

flush table with read lock;

7.將數據導出 
mysqldump -u root -p --all-databases >  /opt/zhucong.dump

8.而後將主庫的數據,發送給從庫
scp /opt/zhucong.dump   root@從庫:/opt/

9.此時去從庫的mysql上,登陸,導入主庫的數據,保持數據一致性
mysql -uroot -p 
source /opt/zhucong.dump 





從庫的配置
1.寫入my.cnf,從庫的身份信息
vi /etc/my.cnf 
[mysqld]
server-id=10

2.檢查一下主庫和從庫的 參數信息 

show variables like 'server_id';
show variables like 'log_bin';

3.經過一條命令,開啓主從同步
change master to master_host='192.168.13.78',
master_user='yuanhao',
master_password='yuanhaobuxitou',
master_log_file='s15mysql-bin.000001',
master_log_pos=571;

4.開啓從庫的slave同步
start slave; 

5.查看主從同步的狀態
show slave status\G;  

6.查看兩條參數 ,確保主從正常
            Slave_IO_Running: Yes
            Slave_SQL_Running: Yes
相關文章
相關標籤/搜索