批量清除128組節(jié)點(diǎn)db上面過(guò)期的binlog釋放磁盤空間實(shí)現(xiàn)思路
更新時(shí)間:2013年06月09日 16:36:17 作者:
在 一臺(tái)db跳轉(zhuǎn)機(jī)上面, 寫一個(gè)腳本,訪問(wèn)slave,遠(yuǎn)程獲取正在復(fù)制的master上面的binlog位置, 然后再遠(yuǎn)程去purge master上面的binlog
如果10臺(tái)以內(nèi)的db的話,自己手動(dòng)ssh進(jìn)去,clean就足以,但是上百臺(tái)呢,就要寫腳本了。大概思路:在 一臺(tái)db跳轉(zhuǎn)機(jī)上面, 寫一個(gè)腳本,訪問(wèn)slave,遠(yuǎn)程獲取正在復(fù)制的master上面的binlog位置, 然后再遠(yuǎn)程去purge master上面的binlog.
1, 建立slave dbserver列表 slavelist; 一個(gè)slave一行。
2,遠(yuǎn)程獲取slave db上面的binlog位置以及slave的master主機(jī)名(也許是ip地址)
3,拿到binlog位置以及master主機(jī)名,然后ssh遠(yuǎn)程清理掉master上面的binlog
4,shell for循環(huán)操作step 2以及step 3。
附帶腳本1:clean_binlog.sh
#!/bin/bash
# p1 the slave mysql db server
db03=$1
echo $dbserver;
ster_Log_File=`ssh $db03 " mysql -uxx -pxx --ssl-ca=/opt/mysql/ssl/ca-cert.pem --s
sl-cert=/opt/mysql/ssl/server-cert.pem --ssl-key=/opt/mysql/ssl/server-key.pem -e \"show slave status\G;\" |grep -i master_Log_File
"`;
# echo ##### 獲取binlog信息
log_file=`echo $ster_Log_File | awk '{print $2}'`;
db01tmp=`ssh $db03 " mysql -uxx -pxx --ssl-ca=/opt/mysql/ssl/ca-cert.pem --s
sl-cert=/opt/mysql/ssl/server-cert.pem --ssl-key=/opt/mysql/ssl/server-key.pem -e \"show slave status\G;\" |grep -i Master_Host
"`;
# 獲取master主機(jī)名或者ip地址
db01=`echo $db01tmp | awk '{print $2}'`
# 開(kāi)始清理binlog日志信息
ssh $db01 " mysql -uxxx -pxx --ssl-ca=/opt/mysql/ssl/ca-cert.pem --ssl-cert=/op
t/mysql/ssl/server-cert.pem --ssl-key=/opt/mysql/ssl/server-key.pem -e \"purge master logs to '$log_file';\" "
# check master上面的binlog信息
ssh $db01 " df -h /mysql/binlog ";
<STRONG><SPAN style="COLOR: #ff0000"></SPAN></STRONG>
附帶批量for循環(huán)腳本2:
for s in `cat slavelist`; do sh clean_binlog.sh $s; done
這個(gè)是比較粗略的方案,肯定有不足之處,我的128組是mm組合,所以這樣操作是可以的,架構(gòu)不同估計(jì)會(huì)有變動(dòng),這里還涉及到purge之前的binlog的備份等等(有專門的備份機(jī)以及備份腳本)。
1, 建立slave dbserver列表 slavelist; 一個(gè)slave一行。
2,遠(yuǎn)程獲取slave db上面的binlog位置以及slave的master主機(jī)名(也許是ip地址)
3,拿到binlog位置以及master主機(jī)名,然后ssh遠(yuǎn)程清理掉master上面的binlog
4,shell for循環(huán)操作step 2以及step 3。
附帶腳本1:clean_binlog.sh
復(fù)制代碼 代碼如下:
#!/bin/bash
# p1 the slave mysql db server
db03=$1
echo $dbserver;
ster_Log_File=`ssh $db03 " mysql -uxx -pxx --ssl-ca=/opt/mysql/ssl/ca-cert.pem --s
sl-cert=/opt/mysql/ssl/server-cert.pem --ssl-key=/opt/mysql/ssl/server-key.pem -e \"show slave status\G;\" |grep -i master_Log_File
"`;
# echo ##### 獲取binlog信息
log_file=`echo $ster_Log_File | awk '{print $2}'`;
db01tmp=`ssh $db03 " mysql -uxx -pxx --ssl-ca=/opt/mysql/ssl/ca-cert.pem --s
sl-cert=/opt/mysql/ssl/server-cert.pem --ssl-key=/opt/mysql/ssl/server-key.pem -e \"show slave status\G;\" |grep -i Master_Host
"`;
復(fù)制代碼 代碼如下:
# 獲取master主機(jī)名或者ip地址
db01=`echo $db01tmp | awk '{print $2}'`
# 開(kāi)始清理binlog日志信息
復(fù)制代碼 代碼如下:
ssh $db01 " mysql -uxxx -pxx --ssl-ca=/opt/mysql/ssl/ca-cert.pem --ssl-cert=/op
t/mysql/ssl/server-cert.pem --ssl-key=/opt/mysql/ssl/server-key.pem -e \"purge master logs to '$log_file';\" "
# check master上面的binlog信息
復(fù)制代碼 代碼如下:
ssh $db01 " df -h /mysql/binlog ";
復(fù)制代碼 代碼如下:
<STRONG><SPAN style="COLOR: #ff0000"></SPAN></STRONG>
附帶批量for循環(huán)腳本2:
for s in `cat slavelist`; do sh clean_binlog.sh $s; done
這個(gè)是比較粗略的方案,肯定有不足之處,我的128組是mm組合,所以這樣操作是可以的,架構(gòu)不同估計(jì)會(huì)有變動(dòng),這里還涉及到purge之前的binlog的備份等等(有專門的備份機(jī)以及備份腳本)。
相關(guān)文章
MySQL遇到“?Access?denied?for?user?”問(wèn)題的解決辦法
這篇文章主要介紹了MySQL遇到“?Access?denied?for?user?”問(wèn)題的解決辦法,文中通過(guò)代碼示例講解的非常詳細(xì),對(duì)大家的解決問(wèn)題有一定的幫助,需要的朋友可以參考下2024-12-12
安裝mysql出錯(cuò)”A Windows service with the name MySQL already exis
這篇文章主要介紹了安裝mysql出錯(cuò)”A Windows service with the name MySQL already exists.“如何解決的相關(guān)資料,在日常項(xiàng)目中此問(wèn)題比較多見(jiàn),特此把解決辦法分享給大家,供大家參考2016-05-05
Mysql5.7.14安裝配置方法操作圖文教程(密碼問(wèn)題解決辦法)
本篇文章主要涉及mysql5.7.14用以往的安裝方法安裝存在的密碼登錄不上,密碼失效等問(wèn)題的解決辦法,需要的朋友參考下吧2017-01-01
Linux環(huán)境下設(shè)置MySQL表名忽略大小寫的方法小結(jié)
在MySQL中,表名的大小寫敏感性取決于操作系統(tǒng)和MySQL的配置,在Unix/Linux系統(tǒng)上,表名通常是區(qū)分大小寫的,由于之前MySQL未設(shè)置忽略表名大小寫導(dǎo)致數(shù)據(jù)查詢失敗等問(wèn)題,所以本文給大家介紹了Linux環(huán)境下設(shè)置MySQL表名忽略大小寫的方法,需要的朋友可以參考下2024-06-06
Python?Matplotlib繪圖基礎(chǔ)詳細(xì)教程
matplotlib是python中用于繪制各種圖像的模塊,功能十分強(qiáng)大,通常與pandas模塊搭配使用,可以生成各種樣視的圖片,用于數(shù)據(jù)的分析和展示,下面這篇文章主要給大家介紹了關(guān)于Python?Matplotlib繪圖基礎(chǔ)的相關(guān)資料,需要的朋友可以參考下2022-07-07
MySQL優(yōu)化之表結(jié)構(gòu)優(yōu)化的5大建議(數(shù)據(jù)類型選擇講的很好)
很多人都將 數(shù)據(jù)庫(kù)設(shè)計(jì)范式 作為數(shù)據(jù)庫(kù)表結(jié)構(gòu)設(shè)計(jì)“圣經(jīng)”,認(rèn)為只要按照這個(gè)范式需求設(shè)計(jì),就能讓設(shè)計(jì)出來(lái)的表結(jié)構(gòu)足夠優(yōu)化,既能保證性能優(yōu)異同時(shí)還能滿足擴(kuò)展性要求2014-03-03

