mariadb

MYSQL(mariadb)

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

1、mariadb安裝

方法1:yum安裝mariadb

yum install mariadb-server mariadb
mariadb數據庫的相關命令是: systemctl start mariadb #啓動MariaDB systemctl stop mariadb #中止MariaDB systemctl restart mariadb #重啓MariaDB systemctl enable mariadb #設置開機啓動

ps:yum安裝指定目錄如    yum -c /etc/yum.conf --installroot=/opt/all_venv/ --releasever=/ install nginxpython

 

方法2:官網下載mysql-server包(rpm)

# wget http://dev.mysql.com/get/mysql-community-release-el7-5.noarch.rpm
# rpm -ivh mysql-community-release-el7-5.noarch.rpm # yum install mysql-community-server

方法三、源碼安裝,略

2、初始化mysql

在確認 MariaDB 數據庫軟件程序安裝完畢併成功啓動後請不要當即使用。爲了確保數據 庫的安全性和正常運轉,須要先對數據庫程序進行初始化操做。這個初始化操做涉及下面 5 個 步驟。 ➢ 設置 root 管理員在數據庫中的密碼值(注意,該密碼並不是 root 管理員在系統中的密 碼,這裏的密碼值默認應該爲空,可直接按回車鍵)。 ➢ 設置 root 管理員在數據庫中的專有密碼。 ➢ 隨後刪除匿名帳戶,並使用 root 管理員從遠程登陸數據庫,以確保數據庫上運行的業 務的安全性。 ➢ 刪除默認的測試數據庫,取消測試數據庫的一系列訪問權限。 ➢ 刷新受權列表,讓初始化的設定當即生效。

確保mariadb服務器啓動後,執行命令初始化

systemctl start mariadb mysql_secure_installation

 

3、mysql基本命令

mysql -uroot -p -h # 建立用戶時未指定ip能夠省略-h
#修改mysql密碼 MariaDB [(none)]
> set password = PASSWORD('redhat123');
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';

4、數據庫權限設置

grant 權限 on 數據庫.表名 to 帳戶@主機名 對特定數據庫中的特定表受權 grant 權限 on 數據庫.* to 帳戶@主機名   對特定數據庫中的全部表給與受權 grant 權限1,權限2,權限3 on *.* to 帳戶@主機名    對全部庫中的全部表給與多個受權 grant all privileges on *.* to 帳戶@主機名      對全部庫和全部表受權全部權限

退出數據庫,使用root登陸,開始權限設置mysql

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

移除權限nginx

MariaDB [(none)]> revoke all privileges on *.* from yuchao@127.0.0.1;

配置mysqlsql

1.中文編碼設置數據庫

編輯mysql配置文件/etc/my.cnf [mysqld] character-set-server=utf8 datadir=/var/lib/mysql socket=/var/lib/mysql/mysql.sock collation-server=utf8_general_ci security risks symbolic-links=0 log-error=/var/log/mysqld.log pid-file=/var/run/mysqld/mysqld.pid [client] default-character-set=utf8 [mysql] default-character-set=utf8 utf8

2.受權配置vim

遠程鏈接設置哦設置全部庫,全部表的全部權限,賦值權限給全部ip地址的root用戶 mysql > grant all privileges on *.* to root@'%' identified by 'password'; #建立用戶 mysql > create user 'username'@'%' identified by 'password'; #刷新權限 flush privileges;

5、數據庫備份與恢復

mysqldump命令用於備份數據庫數據

[root@master ~]# mysqldump -u root -p --all-databases > /tmp/db.dump

進入mariadb數據庫,刪除一個db安全

[root@master ~]# mysql -uroot -p

MariaDB [(none)]> drop database s11;

進行數據恢復,吧剛纔重定向備份的數據庫文件導入到mysql中

[root@master ~]# mysql -uroot -p < /tmp/db.dump

 6、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 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;
相關文章
相關標籤/搜索