Linux - centos7 下 MySQL(mariadb) 和 主從複製

Linux - centos7 下 MySQL(mariadb) 和 主從複製

MySQL(mariadb)

MariaDB數據庫管理系統是MySQL的一個分支,主要由開源社區在維護,採用GPL受權許可。mysql

開發這個分支的緣由之一是:甲骨文公司收購了MySQL後,有將MySQL閉源的潛在風險,所以社區採用分支的方式來避開這個風險。linux

MariaDB的目的是徹底兼容MySQL,包括API和命令行,使之能輕鬆成爲MySQL的代替品。sql

安裝MySQL(mariadb)

1.在線下載阿里雲的 yum 倉庫,以及epel倉庫數據庫

CentOS-Base.repo  epel.repo

2.安裝mysql的方式django

yum install mysql-server  mysql -y

3.安裝mysql的方式也有2種,阿里雲官方提供的mariadb軟件包,版本可能過低,可是下載網速很快,方便學習使用vim

4.在企業裏面,多半不會使用阿里雲的mariadb版本,由於版本過低,安全性過低,公司會配置myariadb官方的yum倉庫centos

1.手動建立mariadb的倉庫文件
    touch Mariadb.repo
2.寫入配置信息
    [mariadb]
    name = MariaDB
    baseurl = http://yum.mariadb.org/10.1/centos7-amd64
    gpgkey=https://yum.mariadb.org/RPM-GPG-KEY-MariaDB
    gpgcheck=1
3.嘗試安裝最新版本mariadb
    yum install mariadb-server mariadb

5.使用mysql,啓動安全

systemctl start mariadb

6.初始化數據庫服務器

mysql_secure_installation

配置數據庫的中文支持

1.修改mysql的配置文件,支持中文編碼

cat /etc/my.cnf  和我一致就行 
    [mysqld]
    character-set-server=utf8
    collation-server=utf8_general_ci
    log-error=/var/log/mysqld.log
    datadir=/var/lib/mysql
    socket=/var/lib/mysql/mysql.sock
    # Disabling symbolic-links is recommended to prevent assorted security risks
    symbolic-links=0
    # Settings user and group are ignored when systemd is used.
    # If you need to run mysqld under a different user or group,
    # customize your systemd unit file for mariadb according to the
    # instructions in http://fedoraproject.org/wiki/Systemd

    [client]
    default-character-set=utf8

    [mysql]
    default-character-set=utf8

2.在服務器上,修改了配置文件,都要重啓數據庫服務
systemctl restart mariadb 

3.在utf8編碼下,配置mariadb
    show create table stu;
    create table stu(id int,name char(10));
    insert into stu(id,name) values(1,"小王");
    show create database s16;

在遠程用 mysql客戶端去鏈接服務端,方式有哪些

1.navicat
2.cmd  
    mysql  -uroot -p  -h 192.168.15.53
3.pycharm 
4.pymysql  python
5.orm  django

配置mysql支持遠程鏈接的sql語句

受權mariadb遠程鏈接
#授予root用戶對全部的庫表全部的權限,在全部的機器上操做,皆可登陸
# 此時是退出mysql數據庫在外面執行的
grant all privileges on *.* to root@'%' identified by 'centos';(密碼)
grant all privileges on *.* to root@'%' identified by 'root';

刷新受權表:
flush privileges;

數據庫備份與恢復

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

mysqldump -u root -p --all-databases > /tmp/db.dump
數據導入,方式有2種
1.mysql -uroot -p  <  /tmp/db.dump 
2.進入mysql命令行,輸入source /tmp/db.dump 
systemctl stop firewalld
systemctl disable firewalld

進入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進行數據寫入,或者兩端同事寫入(特殊設置,互爲主從)

主從機制實現原理:

(1) master將改變記錄到二進制日誌(binary log)中(這些記錄叫作二進制日誌事件,binary log events); 
(2) slave將master的binary log events拷貝到它的中繼日誌(relay log); 
(3) slave重作中繼日誌中的事件,將改變反映它本身的數據。

master主庫配置

1.環境準備,準備2臺機器,一個master 一個slave

192.168.15.53  主庫 

    192.168.15.94  從庫

2.配置主庫的環境

1.修改主庫的配置文件,開啓binlog功能
    vim /etc/my.cnf
    [mysqld]
    server-id=1
    log-bin=s16-mysql-bin

2.重啓數據庫
systemctl restart mariadb

3.建立用於數據同步的帳號

create user 'banzhang'@'%' identified by 'bz666';

4.授予這個帳號,一個slave的身份標識

grant replication slave on *.* to 'banzhang'@'%';

5.鎖表

flush table with read lock;

6.數據庫信息導出

mysqldump -uroot -p   --all-databases  >  /opt/db.dump  

scp /opt/db.dump root@192.168.15.122:/opt/

mariadb從庫的操做

1.阿里雲的源,和官方源,同一安裝軟件包名以下

yum install mariadb-server mariadb -y

2.配置從庫的配置文件,開啓server-id

vim /etc/my.cnf 

寫入以下操做
[mysqld]
server-id=3
read-only=true

character-set-server=utf8
collation-server=utf8_general_ci
log-error=/var/log/mysqld.log

3.重啓數據庫

systemctl restart mariadb

4.在從庫,經過一條命令,開啓主從同步

進入數據庫
mysql > change master to master_host='192.168.15.91',
master_user='banzhang',
master_password='bz666',
master_log_file='s16-mysql-bin.000002',  這個和下面的參數要和主庫的狀態一致   即show master status; 查看這兩個參數的數值
master_log_pos=331;

5.開啓slave同步

start slave;

6.檢查主從同步狀態

show slave status\G 
當你檢查這2條參數,yes的時候,主從ok

Slave_IO_Running: Yes
Slave_SQL_Running: Yes

此時解鎖主庫!!

此時解鎖主庫!! unlock tables

此時解鎖主庫!!

驗證主從同步是否正常

檢查主從複製是否成功的關鍵在於

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