mysql+centos7+主從複製

来源:https://www.cnblogs.com/wangyueping/archive/2019/09/26/11577367.html
-Advertisement-
Play Games

MYSQL(mariadb) 方法1:yum安裝mariadb Red Hat Enterprise Linux/CentOS 7.0 發行版已將預設的資料庫從 MySQL 切換到 MariaDB 第一步:添加 MariaDB yum 倉庫 第二步:在 CentOS 7 中安裝 MariaDB 第三 ...


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密碼
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 | | |
+------------------+----------+--------------+------------------+
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

您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 開學STM32 跑馬燈的實驗主要就是瞭解GPIO口的配置及使用,我這裡是使用庫函數進行編程,主要需要設置以下兩方面: 1、使能需要使用的IO口的時鐘,一共有A、B、C、D、E、F、G七組IO口 2、初始化IO口(設置IO口的埠號(有GPIO_Pin_0 ~ GPIO_Pin_15,共16個IO埠 ...
  • 飛思卡爾(現恩智浦)自2017年推出i.MXRT系列MCU以來,至今已發佈數款新品(RT1050、RT1020、RT1060...),每一款晶元都配套了EVK板,下圖是截止目前所有EVK的板載資源的對比,今天痞子衡就選擇其中資源最豐富的MIMXRT1060-EVK來具體聊一聊。 ...
  • 一、 鏡像下載 國內源下載鏡像:(推薦) http://mirrors.aliyun.com/centos/8.0.1905/isos/x86_64/CentOS-8-x86_64-1905-dvd1.iso 國外源下載鏡像:(不建議) http://mirror.qoxy.com/centos/8 ...
  • 在Windows中,系統進程,資源管理都是通過可視化操作實現的,如下為Windows經典的可視化系統資源管理,其中,作為開發人員或伺服器運維人員, 查看系統系統,系統進程,系統性能和系統伺服器是三個重要的參考因素。 然而,在linux系統中,如何實現這些操作呢?本篇文章將從操作的角度,簡要分析liu ...
  • 總結於 "《鳥哥的 Linux 私房菜 基礎學習篇》" ,圖片也來自於此。 <! 可在「閱讀原文」中查看其他核心筆記:如 Git 等 核心思想 目錄樹結構(directory tree) Linux 系統是基於目錄樹結構的,這是它的核心思想 。目錄,即文件夾。Linux 系統相當於一個文件夾,Lin ...
  • 最近遇到一個問題,由於兩台伺服器時間的問題,經常導致用戶登錄由於時間差問題而報錯,再三百度,最後整理了一下修改linux定時同步的操作(本方法適用於有自己時間伺服器,沒有的只限於借鑒) 首先確認,我們的服務是否已經安裝了ntp服務 如果沒有安裝,需要先安裝ntp服務 安裝完ntp之後,編輯ntp.c ...
  • console.log("運行自定義腳本"); 安裝工具 我的機器環境是: ,開始之前,得在機器上面安裝一些工具: [x] gcc [x] binutils (readelf,objdump) 因為我在自己的機器上面安裝了 brew 這個包管理工具,以及 這個 Shell ,所以我就通過 就安裝好了 ...
  • 最小化centos 安裝基礎命令: 常用的基礎命令如下 yum install vim iotop bc gcc gcc-c++ glibc glibc-devel pcre \ pcre-devel openssl openssl-devel zip unzip zlib-devel net-to ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...