MySQL高可用架構:mysql+keepalived實現

来源:https://www.cnblogs.com/L10086/archive/2019/08/16/11366281.html
-Advertisement-
Play Games

系統環境及架構 在master和slave上分別進行資料庫的安裝 創建資料庫文件存放路徑 配置mysql配置文件 #在mysqlMaster上配置mysql配置文件 在mysqlSlave上配置mysql配置文件 #若是不寫上這個欄位,在本機用 命令 進入mysql會報錯,提示預設路徑/var/li ...


系統環境及架構

#主機名		   系統版本	       mysql版本	 ip地址
mysqlMaster	   <a href="https://www.linuxprobe.com/" title="centos" target="_blank">centos</a>7.4	       mysql5.7	       192.168.1.42
mysqlSlave	   centos7.4	       mysql5.7	       192.168.1.43

#vip:192.168.1.41

在master和slave上分別進行資料庫的安裝

yum install epel*  -y && yum clean all && yum makecache 
rpm -Uvh http://repo.mysql.com/mysql57-community-release-el7.rpm
yum clean all && yum makecache
yum install gcc gcc-c++ openssl-devel mysql mysql-server mysql-devel -y

創建資料庫文件存放路徑

mkdir /data/mysql -p
chown -R mysql:mysql /data/mysql

配置mysql配置文件

#在mysqlMaster上配置mysql配置文件

vi /etc/my.cnf

[mysqld]
server-id = 1		#全局唯一,每台都不能一樣
log-bin = mysql-bin	#log-bin表示開啟二進位日誌記錄,mysql-bin表示日誌文件的命名格式,會生成mysql-bin.0001 等等
relay-log = mysql-relay-bin	#指定中繼日誌格式(拉取主mysql日誌後,在從庫上生成的日誌)
replicate-wild-ignore-table=mysql.%	#指定那些庫或則表不進行同步,mysql是庫名,.%表示下麵所有的表,mysql.user  表示不同不mysql庫下的user表
replicate-wild-ignore-table=test.%
replicate-wild-ignore-table=information_schema.%
#replicate-wild-do-table=boke.%		#表示同步那個庫
#註意:不要在主庫上使用binlog-do-db 或 binlog-ignore-db選項
#也不要在從庫上使用 replicate-do-db 或 replicate-ignore-db 選項,因為這有可能產生跨庫更新失敗的問題.推薦從庫上使用 replicate_wild_do_table 和 replicate_wild_ignore_table 這兩個選項來解決複製過濾問題
datadir=/data/mysql
socket=/data/mysql/mysql.sock
user=mysql
symbolic-links=0
log-error=/var/log/mysqld.log
pid-file=/var/run/mysqld/mysqld.pid
character-set-server=utf8

[mysql]
socket=/data/mysql/mysql.sock
default-character-set=utf8

[client]
socket=/data/mysql/mysql.sock
default-character-set=utf8
user=root
password=NCYD-tianyu@0791
#若是不寫上這個欄位,在本機用<a href="https://www.linuxcool.com/" title="命令" target="_blank">命令</a>進入mysql會報錯,提示預設路徑/var/lib/mysql/mysql.sock找不到

在mysqlSlave上配置mysql配置文件

vi /etc/my.cnf

[mysqld]
server-id = 2
log-bin = mysql-bin
relay-log = mysql-relay-bin
replicate-wild-ignore-table=mysql.%
replicate-wild-ignore-table=test.%
replicate-wild-ignore-table=information_schema.%
datadir=/data/mysql
socket=/data/mysql/mysql.sock
user=mysql
symbolic-links=0
log-error=/var/log/mysqld.log
pid-file=/var/run/mysqld/mysqld.pid
character-set-server=utf8

[mysql]
socket=/data/mysql/mysql.sock
default-character-set=utf8

[client]
socket=/data/mysql/mysql.sock
default-character-set=utf8
user=root
password=NCYD-tianyu@0791

#若是不寫上這個欄位,在本機用 命令 進入mysql會報錯,提示預設路徑/var/lib/mysql/mysql.sock找不到,先初始化資料庫(需要進行初始化在/data/mysql目錄里生成必要的信息)

#mysql5.7.7以後的初始化方法
mysqld --initialize --user=mysql --datadir=/data/mysql

#mysql5.7.7以前的初始化方法
mysql_install_db --user=mysql --datadir=/data/mysql

分別啟動主從資料庫

#在centos7裡面,必須先關閉se<a href="https://www.linuxprobe.com/" title="linux" target="_blank">linux</a>,否在無法啟動mysqld
systemctl start mysqld

分別為主從mysql做安全加固

#查到上一步,首次啟動mysql,系統自動生成的密碼( cat /var/log/mysqld.log |grep pass )
mysql_secure_installation	#使用該命令更改隨機root密碼(修改為 NCYD-tianyu@0791 )
手動同步數據(假如現在的環境,主上已經有數據了,從是新的)
1:在主上資料庫中創建用於複製的用戶,並授權
mysql> GRANT REPLICATION SLAVE ON *.* to 'tongbu'@'192.168.1.43' identified by '123456789';

2:在主mysql上先鎖表(使其所有表變成只讀狀態)
mysql> flush tables with read lock;		#不要退出終端,否在這個鎖就失效了

3:再開啟另一個命令行終端,使用myqldump等工具將數據導出(或則直接打包存儲mysql數據的目錄,併發送到從機上)

4:將導出數據複製到從機上,並創建新庫並導入數據
互相置從,互相置主(以達到雙主模式)

在mysqlMaster上將mysqlSlave設置為自己的主角色伺服器

mysql> show master status;	#查看mysqlSlave的狀態(記錄File名字,和Position)

change master to
master_host = '192.168.1.43',
master_user = 'tongbu',
master_password = '123456789',
master_log_file = 'mysql-bin.000002',
master_log_pos = 1006;

mysql> start slave;      #啟動slave端的複製進程(某些版本是:slave start; )
mysql> show slave status\G  #查看slaves端的I/O進程,與SQL進程

在從上將mysqlMaster設置為自己的主角色伺服器

mysql> show master status;	#查看mysqlMaster的狀態(記錄File名字,和Position)

change master to
master_host = '192.168.1.42',
master_user = 'tongbu',
master_password = '123456789',
master_log_file = 'mysql-bin.000002',
master_log_pos = 1006;

mysql> start slave;      #啟動slave端的複製進程
mysql> show slave status\G  #查看slaves端的I/O進程,與SQL進程

驗證是否同步

1:第一驗證在myssqlMaster上創建庫,mysqlSlave上是否存在

2:第二驗證在mysqlSlave上創建庫,mysqlMaster上是否存在

安裝keepalived實現VIP切換,達到高可用

yum install keepalived -y

#在mysqlMaster和mysqlSlave上都創建檢查mysql的檢查<a href="https://www.linuxcool.com/" title="腳本" target="_blank">腳本</a>,並賦予執行許可權
touch /etc/keepalived/mysql_check.sh
chmod +x /etc/keepalived/mysql_check.sh
vi /etc/keepalived/mysql_check.sh

#!/bin/bash
#slave_is=( $(mysql -uroot -pNCYD-tianyu@0791 -e "show slave status\G" | grep "Slave_.*_Running" | awk '{print $2}') ) 在新版本的myql中,直接將密碼寫在命令行,會進行安全提示,解決辦法是將其寫在mysql的配置文件里的 [client] 欄位里,寫法見上面mysql的配置文件
slave_is=( $(mysql -e "show slave status\G" | grep "Slave_.*_Running" | awk '{print $2}') )
if [ "${slave_is[0]}" = "Yes" -a "$slave_is[1]" = "Yes"]
	then
	exit 0
else
	exit 1
fi

#註意,keepalived檢查 腳本 vrrp_script,只認兩個返回值,0表示正常,非0表示不正常(這在寫腳本是要註意),不正常就要做相關的切換

配置keepalived,以實現高可用

vi /etc/keepalived/keepalived.conf

global_defs {
   notification_email {
     [email protected]
     [email protected]
     [email protected]
   }
   notification_email_from [email protected]
   smtp_server 192.168.200.1
   smtp_connect_timeout 30
   router_id LVS_DEVEL
   vrrp_skip_check_adv_addr
   #vrrp_strict		#註意:當你發現無法ping通虛擬VIP時,建議將此行註釋掉
   vrrp_garp_interval 0
   vrrp_gna_interval 0
}
vrrp_script mysql_check {
	script "/etc/keepalived/mysql_check.sh"
	#這個腳本,若是發現不執行,可以檢查他的許可權,777是不可以的,日誌提示不安全,可以直接chmod +x /etc/keepalived/mysql_check.sh 就行
	#script "shutdown -r now"	#或者,直接用命令進行調試
	interval 2
	weight 2
}
vrrp_instance VI_1 {
    state MASTER	#mysqlMaster上是MASTER;mysqlSlave上是BACKUP
    interface ens192
    virtual_router_id 52
    priority 100	#mysqlMaster上是100;mysqlSlave上是90
    advert_int 1
    nopreempt		#配置VIP(註意:故障切換搶占模式,儘量關閉,預設是開啟的,這個參數只需要在高優先順序上設置即可)
    authentication {
        auth_type PASS
        auth_pass 1111
    }
track_script {	#調用上面定義檢查mfsmaster的腳本
        mysql_check
    }
    virtual_ipaddress {
        192.168.1.41/24 dev ens192
    }
}

啟動keepalived

systemctl start keepalived

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

-Advertisement-
Play Games
更多相關文章
  • bat中怎樣用Random產生1到10之間的一個隨機數? 當然是用%random%,示例: 獲得一定範圍內的隨機數,用%random%可以產生0到32767之間的隨機數,但是,如何才能得到一定範圍內的隨機數呢?通用的演算法公式如下: 通用的公式%random%%%(max-min+1)+min來產生[ ...
  • Linux網路——配置防火牆的相關命令 摘要:本文主要學習瞭如何在Linux系統中配置防火牆。 iptables命令 iptables準確來講並不是防火牆,真正的防火牆是運行於系統內核中的netfilter,而iptables僅僅是操作netfilter的一個工具,其所負責的主要功能便是與用戶交互, ...
  • 0x00 事件 對於在 Linux 的下載工具而言,比較常用的就是 wget 或者 curl,吾也一直用 wget 的方式進行網路上的資源下載。偶然發現了 axel 這個支持多線程的下載工具,試用了幾次之後,發現網路文件的下載速度提交了很多,決定將常用的下載工具替換為 axel。 0x01 安裝 1 ...
  • 1. 簡介 RTMP協議是Real Time Message Protocol(實時信息傳輸協議)的縮寫,它是由Adobe公司提出的一種應用層的協議,用來解決多媒體數據傳輸流的多路復用(Multiplexing)和分包(packetizing)的問題。 RTMP消息塊流和RTMP一起適用於多樣性音視 ...
  • 參考博客: https://www.cnblogs.com/fengdejiyixx/p/10821820.html https://www.runoob.com/linux/linux comm ln.html https://www.cnblogs.com/crazylqy/p/5821105. ...
  • 一.進程基礎知識 1.1 Linux進程的概念 Process :是運行中的程式的一個副本,是被載入記憶體的一個指令集合。進程 (`Process ID PID UID GID SELinux`語境決定對文件系統的 存取和訪問許可權 ,這些屬性通常從執行進程的用戶來 繼承 ,並且進程存在 生命周期 ,每 ...
  • 操作系統 : windows7_x64 創建vhd 磁碟管理 --> 操作 --> 創建vhd 掛載vhd 腳本: Python版本: https://github.com/mike-zhang/pyExamples/blob/master/tools/vhdFileOpt/load_vhd.py ...
  • 1、通過位置變數創建linux系統賬戶及密碼$1 是執行腳本的第一個參數,$2 是執行腳本的第二個參數 2、每周5使用tar命令備份/var/log 下的所有日誌文件,防止文件覆蓋 3、實時監控本機記憶體和硬碟剩餘空間,剩餘記憶體小於500M,根分區剩餘空間小於1000M的時候發送報警郵件 4、腳本生成 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...