Linux之MariaDB

MariaDB數據庫的起源

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

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

 

1.配置MariaDB官方yum源

添加 MariaDB yum 倉庫

首先添加 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

 

2.在Centos7上安裝並啓動MariaDB

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  #設置開機啓動

 

3. 初始化MariaDB

在確保MariaDB正確運行後執行下面命令進行初始化

mysql_secure_installation

這條命令執行之後會出現一個交互頁面, 提示你輸入或肯定某些事情

➢ 設置 root 管理員在數據庫中的密碼值(注意,該密碼並不是 root 管理員在系統中的密碼,這裏的密碼值默認應該爲空,可直接按回車鍵)。
➢ 設置 root 管理員在數據庫中的專有密碼。
➢ 是否刪除刪除匿名帳戶,
是否可使用 root 管理員從遠程登陸數據庫,以確保數據庫上運行的業務的安全性。 
➢ 是否刪除默認的測試數據庫,取消測試數據庫的一系列訪問權限。
➢ 是否刷新受權列表,讓初始化的設定當即生效。

 

4. MariaDB數據庫的編碼設置

編碼格式是針對database來講的, 能夠更改某個database的編碼格式

alter database db1 charset gbk;

還能夠查看某個database在建立時使用的編碼格式

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)

 當數據存到某個庫中, 就已經使用了這個庫當前的編碼格式, 以後再修改庫的編碼, 對以前的數據是沒有做用的

 

** 在配置文件中指定編碼格式便可, 已經有的配置項不須要重複配置, 主要配置和character相關的配置項

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

 

5. MariaDB數據庫的經常使用操做

MariaDB數據庫的操做和mysql是同樣的

 

6. MariaDB數據庫備份和恢復備份

mysqldump 用於數據庫備份

[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

 

7.MariaDB主從複製

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

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

主從複製的邏輯有如下幾種

一主一從,單向主從同步模式,只能在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

Slave_IO_Running, Slave_SQL_Running是兩個線程, 都爲YES是表示主從同步的狀態爲OK

相關文章
相關標籤/搜索