MariaDB數據庫管理系統是MySQL的一個分支,主要由開源社區在維護,採用GPL受權許可。
開發這個分支的緣由之一是:甲骨文公司收購了MySQL後,有將MySQL閉源的潛在風險,所以社區採用分支的方式來避開這個風險。
MariaDB的目的是徹底兼容MySQL,包括API和命令行,使之能輕鬆成爲MySQL的代替品。
Red Hat Enterprise Linux/CentOS 7.0 發行版已將默認的數據庫從 MySQL 切換到 MariaDB。python
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
2、當 MariaDB 倉庫地址添加好後,你能夠經過下面的一行命令輕鬆安裝 MariaDB。
yum install MariaDB-server MariaDB-client -y
mariadb數據庫的相關命令是: systemctl start mariadb #啓動MariaDB systemctl stop mariadb #中止MariaDB systemctl restart mariadb #重啓MariaDB systemctl enable mariadb #設置開機啓動
啓動後正常使用mysqlmysql
systemctl start mariadb
在確認 MariaDB 數據庫軟件程序安裝完畢併成功啓動後請不要當即使用。爲了確保數據 庫的安全性和正常運轉,須要先對數據庫程序進行初始化操做。這個初始化操做涉及下面 5 個 步驟。 ➢ 設置 root 管理員在數據庫中的密碼值(注意,該密碼並不是 root 管理員在系統中的密 碼,這裏的密碼值默認應該爲空,可直接按回車鍵)。 ➢ 設置 root 管理員在數據庫中的專有密碼。 ➢ 隨後刪除匿名帳戶,並使用 root 管理員從遠程登陸數據庫,以確保數據庫上運行的業 務的安全性。 ➢ 刪除默認的測試數據庫,取消測試數據庫的一系列訪問權限。 ➢ 刷新受權列表,讓初始化的設定當即生效。
確保mariadb服務器啓動後,執行命令初始化sql
mysql_secure_installation
初始化mysql數據庫
若是須要遠程鏈接選擇nvim
1.中文編碼設置,編輯mysql配置文件/etc/my.cnf,下入如下內容centos
[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 root@'%' identified by 'password';
#建立用戶
mysql > create user 'username'@'%' identified by 'password';
#刷新權限
flush privileges;
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 yuchao@127.0.0.1; MariaDB [mysql]> show grants for yuchao@127.0.0.1;
移除權限併發
MariaDB [(none)]> revoke all privileges on *.* from yuchao@127.0.0.1;
#修改mysql密碼 MariaDB [(none)]> set password = PASSWORD('redhat123');
生產環境裏不會死磕root用戶,爲了數據庫的安全以及和其餘用戶協同管理數據庫,就須要建立其餘數據庫帳戶,而後分配權限,知足工做需求。
MariaDB [(none)]> create user yuchao@'127.0.0.1' identified by 'redhat123'; MariaDB [(none)]> use mysql; MariaDB [mysql]> select host,user,password from user where user='yuchao';
切換普通用戶yuchao,查看數據庫信息,發現沒法看到完整的數據庫列表
[root@master ~]# mysql -uyuchao -p -h 127.0.0.1 MariaDB [(none)]> show databases;
mysqldump命令用於備份數據庫數據
[root@master ~]# mysqldump -u root -p --all-databases > /tmp/db.dump
2.導出db一、db2兩個數據庫的全部數據
mysqldump -uroot -proot --databases db1 db2 >/tmp/user.sql
進入mariadb數據庫,刪除一個db
[root@master ~]# mysql -uroot -p MariaDB [(none)]> drop database s11;
進行數據恢復,吧剛纔重定向備份的數據庫文件導入到mysql中
[root@master ~]# mysql -uroot -p < /tmp/db.dump
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重作中繼日誌中的事件,將改變反映它本身的數據。
#查看數據庫狀態 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
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/
1.設置server-id值並關閉binlog功能參數 數據庫的server-id在主從複製體系內是惟一的,Slave的server-id要與主庫和其餘從庫不一樣,而且註釋掉Slave的binlog參數。
2.所以修改Slave的/etc/my.cnf,寫入
[mysqld]
server-id=3 read-only=true
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
########################################### dns /etc/resolv.conf [root@localhost ~]# ifconfig eno16777736: flags=4163<UP,BROADCAST,RUNNING,MULTICAST> mtu 1500 inet 192.168.0.101 netmask 255.255.255.0 broadcast 192.168.0.255 inet6 fe80::20c:29ff:fe53:9402 prefixlen 64 scopeid 0x20<link> ether 00:0c:29:53:94:02 txqueuelen 1000 (Ethernet) RX packets 68 bytes 9208 (8.9 KiB) RX errors 0 dropped 0 overruns 0 frame 0 TX packets 84 bytes 11947 (11.6 KiB) TX errors 0 dropped 0 overruns 0 carrier 0 collisions 0 lo: flags=73<UP,LOOPBACK,RUNNING> mtu 65536 inet 127.0.0.1 netmask 255.0.0.0 inet6 ::1 prefixlen 128 scopeid 0x10<host> loop txqueuelen 0 (Local Loopback) RX packets 11 bytes 1220 (1.1 KiB) RX errors 0 dropped 0 overruns 0 frame 0 TX packets 11 bytes 1220 (1.1 KiB) TX errors 0 dropped 0 overruns 0 carrier 0 collisions 0 [root@localhost ~]# vim /etc/sysconfig/net netconsole network network-scripts/ [root@localhost ~]# vim /etc/sysconfig/network-scripts/if ifcfg-eno16777736 ifdown-eth ifdown-post ifdown-Team ifup-aliases ifup-ipv6 ifup-post ifup-Team ifcfg-lo ifdown-ippp ifdown-ppp ifdown-TeamPort ifup-bnep ifup-isdn ifup-ppp ifup-TeamPort ifdown ifdown-ipv6 ifdown-routes ifdown-tunnel ifup-eth ifup-plip ifup-routes ifup-tunnel ifdown-bnep ifdown-isdn ifdown-sit ifup ifup-ippp ifup-plusb ifup-sit ifup-wireless [root@localhost ~]# vim /etc/sysconfig/network-scripts/if ifcfg-eno16777736 ifdown-eth ifdown-post ifdown-Team ifup-aliases ifup-ipv6 ifup-post ifup-Team ifcfg-lo ifdown-ippp ifdown-ppp ifdown-TeamPort ifup-bnep ifup-isdn ifup-ppp ifup-TeamPort ifdown ifdown-ipv6 ifdown-routes ifdown-tunnel ifup-eth ifup-plip ifup-routes ifup-tunnel ifdown-bnep ifdown-isdn ifdown-sit ifup ifup-ippp ifup-plusb ifup-sit ifup-wireless [root@localhost ~]# vim /etc/sysconfig/network-scripts/ifcfg-eno16777736 #打開網卡配置文件 HWADDR="00:0C:29:53:94:02" TYPE="Ethernet" BOOTPROTO="dhcp" #動態獲取ip協議 DEFROUTE="yes" PEERDNS="yes" PEERROUTES="yes" IPV4_FAILURE_FATAL="no" IPV6INIT="yes" IPV6_AUTOCONF="yes" IPV6_DEFROUTE="yes" IPV6_PEERDNS="yes" IPV6_PEERROUTES="yes" IPV6_FAILURE_FATAL="no" NAME="eno16777736" UUID="67dc0736-0a20-48c1-8576-31ae47670ff5" ONBOOT="yes" #必須將他改成ONBOOT="yes" 開機時讀取這個網卡腳本 不能上網 1.網卡配置文件中必須將他改成ONBOOT="yes" 開機時讀取這個網卡腳本 2.systemctl restart network centos7 mariadb的學習 1.在Linux上安裝軟件的方式 yum安裝 在線搜索rpm格式的軟件包,進行自動的依賴關係處理,下載,安裝 (阿里雲的yum倉庫,裏面的軟件都是阿里雲運維工程師定義的) yum install mysql -y 手動rpm包安裝,須要手動解決N個軟件依賴 rpm -ivh mysqlxx.rpm 源碼編譯安裝(這種方式是企業應用最多的) (能夠自定製軟件的版本,以及能夠最優先的使用最新版本的軟件) 2.yum源的配置(mysql的yum源) cd /etc/yum.repos.d/ 1.在線下載阿里雲的yum倉庫,以及epel倉庫 2.安裝mysql的方式 yum install mysql-server mysql -y 3.安裝mysql的方式也有2種,阿里雲官方提供的mariadb軟件包,版本可能過低。(下載網速很快,方便學習使用) 4.企業裏多半不會用阿里雲的,由於版本低,安全性過低,會配置mariadb官方的yum倉儲 1.以下操做:(手動建立mariadb倉庫文件,寫入配置信息,安裝最新版本mariadb) [root@localhost ~]# cd /etc/yum.repos.d/ [root@localhost yum.repos.d]# touch Mariadb.repo [root@localhost yum.repos.d]# vim 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 [root@localhost yum.repos.d]# mysql -V mysql Ver 15.1 Distrib 5.5.64-MariaDB, for Linux (x86_64) using readline 5.1 [root@localhost yum.repos.d]# yum install mariadb-server mariadb -y 2.啓動 systemctl start mariadb 3.初始化mysql mysql_secure_installation 【 Set root password? [Y/n] y New password: 輸入root管理員設置的數據庫密碼 Re-enter new password: 再次輸入密碼 Remove anonymous users? [Y/n] y 刪除匿名帳戶 Disallow root login remotely? [Y/n] n 容許root管理員從遠程登陸 Remove test database and access to it? [Y/n] y 刪除test數據庫並取消對它的訪問權限 Reload privilege tables now? [Y/n] y #刷新受權表,讓初始化後的設定當即生效 】 4.配置數據庫的中文支持 \s 查看數據庫編碼 編輯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 5.在服務器上,修改了配置文件,都須要重啓數據庫服務 systemctl restart mariadb 6.查看具體庫表的編碼 show create database myblog; show create table user; 5.window去連接(報錯須要受權配置) mysql -uroot -p -h 192.168.0.101 6.受權配置:配置mysql支持遠程鏈接的sql語句 授予root用戶對全部的庫表全部的權限,在全部的機器上操做,皆可登錄。 MariaDB [(none)] > grant all privileges on *.* to root@'%' identified by '密碼'; #刷新權限 MariaDB [(none)] > flush privileges; mysql主從同步技術 1.環境準備,準備2臺機器,一臺master一臺slave 192.168.0.101 (主庫) 192.168.0.111 (從庫) 【主庫】 2.配置主庫的環境 1.#停mariadb systemctl stop mariadb 2.#修改主庫的配置文件,開啓binlog功能 vim /etc/my.cnf #修改內容 #解釋:server-id服務的惟一標識(主從之間都必須不一樣);log-bin啓動二進制日誌名稱爲mysql-bin [mysqld] server-id=1 log-bin=mysql-bin 3.#啓動mariadb systemctl start mariadb 4.新建用於主從同步的用戶tom,容許登陸的從庫是'192.168.0.111' create user 'tom'@'192.168.0.111' identified by '密碼'; #create user 'tom'@'%' identified by '密碼'; 5.受權tom一個slave的身份標識,在192.168.0.111機器上覆制 grant replication slave on *.* to 'tom'@'192.168.0.111'; #grant replication slave on *.* to 'tom'@'%'; 6.鎖表 flush table with read lock; 7.數據庫信息導出 mysqldump -uroot -p --all-databases > /opt/db.dump 8.從主庫把sql文件發給從庫 scp /opt/db.dump root@192.168.0.111:/opt/ 9.【從庫配置】 10.解鎖 unlock tables; 11.驗證主從同步是否正常。 【從庫】 配置從庫的環境 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.修改Slave的/etc/my.cnf,寫入 [mysqld] server-id=3 read-only=true (說明:設置server-id值並關閉binlog功能參數 數據庫的server-id在主從複製體系內是惟一的,Slave的server-id要與主庫和其餘從庫不一樣,而且註釋掉Slave的binlog參數。) 3.啓動 systemctl start mariadb 4.導入數據(以前從主庫傳過來的) mysql -uroot -p < /opt/db.dump 5.在從庫,經過一條命令,開啓主從同步 mysql > change master to master_host='192.168.0.101', 6.配置複製的參數,Slave從庫鏈接Master主庫的配置 【master_log_file和master_log_pos 經過show master status 查看】 mysql > change master to master_host='192.168.0.101', master_user='tom', master_password='tom密碼', master_log_file='mysql-bin.000001', master_log_pos=575; 7.開啓slave同步 start slave; 8.檢查主從同步狀態 show slave status\G; 保障都yes(注意關閉防火牆) Slave_IO_Running: Yes Slave_SQL_Running: Yes 9.驗證主從同步是否正常。 注意:若是你用的就是阿里雲的yum源,安裝mariadb的軟件包名字就是以下: yum install mysql-server mysql -y 若是你用的就是官方mariadb的yum源, yum install mariadb-server mariadb -y 熟悉mariadb curd操做,mariadb主從同步,讀寫分離技術...