首先添加 MariaDB 的 yum源 配置文件 MariaDB.repo 文件。 1. 編輯建立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
1.安裝
當 MariaDB 倉庫地址添加好後,你能夠經過下面的一行命令輕鬆安裝 MariaDB。 yum install MariaDB-server MariaDB-client -y
2.啓動
在centos中操做mariadb數據庫的相關命令是: systemctl start mariadb #啓動MariaDB systemctl stop mariadb #中止MariaDB systemctl restart mariadb #重啓MariaDB systemctl enable mariadb #設置開機啓動
mysql_secure_installation
➢ 設置 root 管理員在數據庫中的密碼值(注意,該密碼並不是 root 管理員在系統中的密碼,這裏的密碼值默認應該爲空,可直接按回車鍵)。
➢ 設置 root 管理員在數據庫中的專有密碼。
➢ 是否刪除刪除匿名帳戶,
➢ 是否可使用 root 管理員從遠程登陸數據庫,以確保數據庫上運行的業務的安全性。
➢ 是否刪除默認的測試數據庫,取消測試數據庫的一系列訪問權限。
➢ 是否刷新受權列表,讓初始化的設定當即生效。
alter database db1 charset gbk;
MariaDB [(none)]> show create database db02; +----------+---------------------------------------------------------------+ | Database | Create Database | +----------+---------------------------------------------------------------+ | db02 | CREATE DATABASE `db02` /*!40100 DEFAULT CHARACTER SET utf8 */ | +----------+---------------------------------------------------------------+ 1 row in set (0.00 sec)
vim /etc/my.cnf
[mysqld] character-set-server=utf8 collation-server=utf8_general_ci log-error=/var/log/mysqld.log server-id=1 log-bin=mysqls14-bin
[client] default-character-set=utf8
[mysql] default-character-set=utf8
MariaDB [(none)]> \s # 查看編碼的命令, 至關於status -------------- mysql Ver 15.1 Distrib 10.1.37-MariaDB, for Linux (x86_64) using readline 5.1 Connection id: 13 Current database: Current user: root@localhost SSL: Not in use Current pager: stdout Using outfile: '' Using delimiter: ; Server: MariaDB Server version: 10.1.37-MariaDB MariaDB Server Protocol version: 10 Connection: Localhost via UNIX socket Server characterset: utf8 Db characterset: utf8 Client characterset: utf8 Conn. characterset: utf8 UNIX socket: /var/lib/mysql/mysql.sock Uptime: 1 hour 1 min 47 sec Threads: 3 Questions: 465 Slow queries: 0 Opens: 66 Flush tables: 1 Open tables: 60 Queries per second avg: 0.125 --------------
[root@master ~]# mysqldump -u root -p --all-databases > /tmp/db.dump
方式一 source \tmp\db.dump # 這個source是在mysql的命令行下執行的, 不是linux的source 方式二 [root@master ~]# mysql -uroot -p < /tmp/db.dump
一主一從,單向主從同步模式,只能在Master端寫入數據
一主多從
還有一種同步方式: 雙主主複製邏輯架構,此架構能夠在Master1或Master2進行數據寫入,或者兩端同事寫入(特殊設置)python
在生產環境中,MySQL主從複製都是異步的複製方式,即不是嚴格的實時複製,可是給用戶的體驗都是實時的。
MySQL主從複製集羣功能使得MySQL數據庫支持大規模高併發讀寫成爲可能,且有效的保護了服務器宕機的數據備份。
主從複製的應用場景mysql
利用複製功能當Master服務器出現問題時,咱們能夠人工的切換到從服務器繼續提供服務,此時服務器的數據和宕機時的數據幾乎徹底一致。
複製功能也可用做數據備份,可是若是人爲的執行drop,delete等語句刪除,那麼從庫的備份功能也就失效了.
主從機制的實現原理linux
(1) master將改變 記錄到二進制日誌(binary log)中(這些記錄叫作二進制日誌事件,binary log events); (2) slave將master的binary log events拷貝到它的中繼日誌(relay log); (3) slave重作中繼日誌中的事件,將記錄翻譯成它本身的數據。
查看數據庫狀態 systemctl status mariadb 中止mariadb systemctl stop mariadb 修改配置文件 vim /etc/my.cnf 修改內容 [mysqld] server-id=1 log-bin=mysql-bin 解釋:
server-id服務的惟一標識(主從之間都必須不一樣)
log-bin啓動二進制日誌名稱爲mysql-bin 重啓mariadb systemctl start mariadb
1.新建用於主從同步的用戶chaoge,容許登陸的從庫是'192.168.178.130' create user 'sath'@'%' identified by 'redhat'; 2.#題外話:若是提示密碼太簡單不復合策略加在前面加這句 mysql> set global validate_password_policy=0; 3.給從庫帳號受權,說明給sath這個用戶從庫複製的權限,在任意機器上覆制 grant replication slave on *.* to 'sath'@'%'; #檢查主庫建立的複製帳號 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 | | | +------------------+----------+--------------+------------------+ 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/
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='sath, 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