MYSQL(mariadb)
MariaDB資料庫管理系統是MySQL的一個分支,主要由開源社區在維護,采用GPL授權許可,
開發這個分支的原因之一是:甲骨文公司收購了MySQL后,有將MySQL閉源的潛在風險,因此社區采用分支的方式來避開這個風險,
MariaDB的目的是完全兼容MySQL,包括API和命令列,使之能輕松成為MySQL的代替品,
方法1:yum安裝mariadb

Red Hat Enterprise Linux/CentOS 7.0 發行版已將默認的資料庫從 MySQL 切換到 MariaDB,
第一步:添加 MariaDB yum 倉庫
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
第二步:在 CentOS 7 中安裝 MariaDB
2、當 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');
生產環境里不會死磕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;
資料庫權限設定
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 [email protected]; MariaDB [mysql]> show grants for [email protected];
移除權限
MariaDB [(none)]> revoke all privileges on *.* from [email protected];
配置mysql
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.授權配置
遠程連接設定哦設定所有庫,所有表的所有權限,賦值權限給所有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
2.匯出db1、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主從復制
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 [email protected]:/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
轉載請註明出處,本文鏈接:https://www.uj5u.com/caozuo/158644.html
標籤:Linux
上一篇:Linux下virtualenv與virtualenvwrapper詳解
下一篇:report for PA2
