溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

MySQL 數(shù)據(jù)庫(kù)遷移工作筆記----連接抓取、展示與異常連接

發(fā)布時(shí)間:2020-07-22 08:46:07 來源:網(wǎng)絡(luò) 閱讀:651 作者:Amnesiasun 欄目:數(shù)據(jù)庫(kù)

背景:由于公司機(jī)房網(wǎng)絡(luò)調(diào)整,需要調(diào)整一批mysql 數(shù)據(jù)庫(kù)的服務(wù)器IP,在新環(huán)境中已經(jīng)搭建好新架構(gòu)(keepalive+lvs),并需要開發(fā)工程師配合修改程序配置,共有2個(gè)業(yè)務(wù),9臺(tái)服務(wù)器,50多個(gè)實(shí)例。

1、抓取連接腳本

---從繁重的重復(fù)工作中解脫出來

為了使切換的過程更高效并解放自己的雙手,編寫了簡(jiǎn)單的shell腳本,定時(shí)抓取連接并存儲(chǔ)至核心數(shù)據(jù)庫(kù),簡(jiǎn)單的例子:

#!/bin/bash
                                                                                                   
StatFile="/var/log/status/processlist.txt"
#獲取IP信息        
IP=`/sbin/ifconfig | egrep -A 1 "eth[0-4] " | egrep "inet " | egrep -v "192.168|:10."| awk -F'[ :]+' '{print $4}' | sed -n "1p"`
if [[ $IP = '' ]]       
then           
IP=`/sbin/ifconfig | egrep -A 1 "eth[0-4] " | egrep "inet " | egrep  "192.168|:10."| awk -F'[ :]+' '{print $4}' | sed -n "1p"`       
fi
# port.txt 存儲(chǔ)端口號(hào)
cat /var/log/port.txt | while read port                                                                                   
do              
    /bin/mysql -h數(shù)據(jù)庫(kù)IP -uroot -p'密碼' -P$port information_schema -Bse "select '$IP','$port',user,substring_index(host,':',1) as host from  PROCESSLIST where user not in ('root','system user') group by user,substring_index(host,':',1);" > $StatFile
# 此處將show processlist信息存入文件,也可直接循環(huán)執(zhí)行
# 將文件中信息存入核心數(shù)據(jù)庫(kù),忽略表結(jié)構(gòu)           
    cat $StatFile | while read ip  port username host           
    do                   
        /bin/mysql  -h數(shù)據(jù)庫(kù)IP -u用戶名  -p 密碼’ -P端口  庫(kù)名 -Bse "insert into mysql_db_proce(db_ip,port,username,app_host) values ('$IP','$port','$username','$host');"           
    done       
done


2、信息展示

-----讓我的結(jié)果更好看

①抓取連接腳本加入到計(jì)劃任務(wù)中,每分鐘執(zhí)行一次

②這時(shí)可以從核心庫(kù)中查看到連接信息,根據(jù)表中的update_time字段判斷當(dāng)前最新時(shí)間的連接情況

③可以使用sql語句進(jìn)行查詢,但仍比較繁瑣,眾多的服務(wù)器依然需要重復(fù)執(zhí)行sql,讓人厭煩

④因此使用了最近學(xué)習(xí)的python用 django 搭建了簡(jiǎn)單的web頁面進(jìn)行展示,具體的結(jié)構(gòu)都很簡(jiǎn)單,就是從數(shù)據(jù)庫(kù)中查詢數(shù)據(jù),傳到模板中進(jìn)行渲染就好了

MySQL 數(shù)據(jù)庫(kù)遷移工作筆記----連接抓取、展示與異常連接

默認(rèn)展示最近一分鐘數(shù)據(jù),添加了搜索框,可以根據(jù)IP,端口號(hào)進(jìn)行篩選。

⑤這樣在與開發(fā)進(jìn)行溝通的時(shí)候,更加清晰,再也不是黑白頁面了(●ˇ?ˇ●),雖然很簡(jiǎn)單

3、碰到的連接異常

整個(gè)工作進(jìn)行的很順利,但在切換到最后的時(shí)候,頁面中看到有一個(gè)業(yè)務(wù)的寫庫(kù)一直有一臺(tái)web的連接進(jìn)來,于是詢問開發(fā)是否有配置未同步,

他搜索了很久告訴我用到的地方都已經(jīng)修改完了,沒找到。

抓到的連接顯示是他的服務(wù)器,因此需要幫助他定位到問題點(diǎn)

①開啟mysql general-log抓取連接具體信息(因?yàn)榇藭r(shí)主庫(kù)已不可寫,binlog中查不到信息),根據(jù)頁面信息,抓取了五分鐘數(shù)據(jù),

查找到具體執(zhí)行的sql,提供給開發(fā)確認(rèn)

②開發(fā)以知曉具體程序,但檢查配置已經(jīng)修改了,懷疑是其他單獨(dú)布置的腳本未使用vip,因此抓取網(wǎng)絡(luò)信息,查看使用的是什么ip連接的數(shù)據(jù)庫(kù)

在數(shù)據(jù)庫(kù)服務(wù)器上執(zhí)行命令:

netstat –lna | grep ‘應(yīng)用服務(wù)器IP’

即可看到該程序使用的數(shù)據(jù)庫(kù)IP是什么,發(fā)現(xiàn)確實(shí)為VIP,此時(shí)我們已經(jīng)解決不了該問題了,需要交給開發(fā)仔細(xì)查找

③最后,經(jīng)過他告訴我說是有一個(gè)進(jìn)程,從昨天開始就一直在執(zhí)行,新配置沒生效

④紀(jì)錄下這個(gè)問題,以后可能還會(huì)遇到,修改配置后,最好把程序進(jìn)程都檢查一遍

4、思考

DBA進(jìn)行數(shù)據(jù)庫(kù)變更后,每次都需要開發(fā)配合進(jìn)行修改,這應(yīng)該存在架構(gòu)上的問題,每次都需要開發(fā)等到半夜很久,也是令人討厭的一件事

怎樣在架構(gòu)上進(jìn)行更改,讓數(shù)據(jù)庫(kù)配置對(duì)應(yīng)用程序透明,做到基本無感,應(yīng)該是接下來應(yīng)該考慮的事情。 夜深人靜,晚安

                                                                                                      MySQL 數(shù)據(jù)庫(kù)遷移工作筆記----連接抓取、展示與異常連接

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI