linux mysql主從複製

centos7 安裝 mariadbpython

1 yum 源  -- 配置阿里的 mysql

2 rmp 方式linux

3 源碼編譯方式  -- 專業DBAredis

一些知識點:

虛擬環境 不影響 redis/ mariadb/mysqlsql

rmp  -q  mariadb  檢測有沒裝  只能檢測經過yum安裝的數據庫

先workon 虛擬環境, 在這個裏面打開項目vim

 

 

配置 官方源 1 引入 yum 倉   /etc/yum.repos.d/目錄下 手動建立一個 mariadb.repo 寫入以下內容 [mariadb] name = MariaDB baseurl = http://yum.mariadb.org/10.1/centos7-amd64
gpgkey=https://yum.mariadb.org/RPM-GPG-KEY-MariaDB
gpgcheck=1

2.此時經過yum安裝的軟件,都是mariadb官方的了 以後 yum install mariadb-server mariadb 大約103M 3 啓動 systemctl start mariadb 服務端 mysql -uroot  -p 默認沒密碼
mariadb數據庫的相關命令是: systemctl start mariadb #啓動MariaDB systemctl stop mariadb #中止MariaDB systemctl restart mariadb #重啓MariaDB systemctl enable mariadb #設置開機啓動
修改mysql密碼
MariaDB [(none)]> set password = PASSWORD('redhat123');
帳號權限設置 -- mysql使用grant命令對帳戶進行受權,grant命令常見格式以下
grant 權限 on 數據庫.表名 to 帳戶@主機名            對特定數據庫中的特定表受權
grant 權限 on 數據庫.* to 帳戶@主機名              對特定數據庫中的全部表給與受權
grant 權限1,權限2,權限3 on *.* to 帳戶@主機名      對全部庫中的全部表給與多個受權
grant all privileges on *.* to 帳戶@主機名      對全部庫和全部表受權全部權限
4 確保server啓動後執行初始化 會有匿名用戶
  mysql_secure_installation
5 修改數據庫編碼 (\s 直接查看編碼信息)
  show create database zc; 查看建立庫時候的編碼問題

-- vim /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=utf8centos

6 遠程鏈接數據庫服務器

  建立普通用戶 -- create user 用戶名@'%' identified by '密碼';  任何地方都能登陸ide

  #對用戶受權,給予root用戶遠程登陸的權限

  #給予root權限,全部的權限,而且能夠遠程登陸  --下面是指令  

  grant all privileges on *.* to root@"%" identified by "redhat";  遠程機登陸時候的密碼

  #當即刷新受權表   flush privileges;

數據庫備份與恢復
mysqldump 命令用於備份數據庫操做:

1.命令   導出>
mysqldump -u root -p --all-databases > /tmp/db.dump  全部庫資源備份到目的地
指定ace_crm數據庫導出
mysqldump -uroot -p --database ace_crm > /tmp/ace_crm.dump  指定庫備份

#參數 --all-databases 導出全部的數據庫

2.導入數據庫信息  導入<
mysql -uroot -p < /tmp/db.dump    (Windows --> linux,或者不一樣機器之間)

導入數據方式2:  MariaDB [(none)]> source /tmp/db.dump   進入數據庫後,使用source方法

mysql 主從複製

MySQL數據庫的主從複製方案,是其自帶的功能,而且主從複製並非複製磁盤上的數據庫文件,而是經過binlog日誌複製到須要同步的從服務器上。

MySQL數據庫支持單向、雙向、鏈式級聯,等不一樣業務場景的複製。在複製的過程當中,一臺服務器充當主服務器(Master),接收來自用戶的內容更新,而一個或多個其餘的服務器充當從服務器(slave),接收來自Master上binlog文件的日誌內容,解析出SQL,從新更新到Slave,使得主從服務器數據達到一致。

環境準備  :  一主一從  (不一樣機器之間的操做)
(1) master將改變記錄到二進制日誌(binary log)中(這些記錄叫作二進制日誌事件,binary log events); (2) slave將master的binary log events拷貝到它的中繼日誌(relay log); (3) slave重作中繼日誌中的事件,將改變反映它本身的數據。

master 主庫配置

查看數據看狀態 -- systemctl status mariadb 中止服務 -- systemctl stop mariadb 修改配置文件 -- vim /ect/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
相關文章
相關標籤/搜索