亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 數據庫 > MySQL > 正文

MySQL的一些功能實用的Linux shell腳本分享

2024-07-24 13:08:20
字體:
來源:轉載
供稿:網友
這篇文章主要介紹了Linux系統下MySQL的一些實用功能的shell腳本分享,包括啟動Memcached、binlog自動清理和修復主從同步這樣三個簡單的實例,需要的朋友可以參考下
 

Memcached啟動腳本

# vim /etc/init.d/memcached
#!/bin/bash#=======================================================================================# chkconfig: - 80 12# description: Distributed memory caching daemon# processname: memcached#=======================================================================================IPADDR=`/sbin/ifconfig eth1 | awk -F ':' '/inet addr/{print $2}' | sed 's/[a-zA-Z ]//g'`PORT="11211"USER="root"SIZE="2048"CONNNUM="51200"PIDFILE="/var/run/memcached.pid"BINFILE="/usr/local/memcached/bin/memcached"LOCKFILE="/var/lock/subsys/memcached"RETVAL=0      start() {  echo -n $"Starting memcached......"  $BINFILE -d -l $IPADDR -p $PORT -u $USER -m $SIZE -c $CONNNUM -P $PIDFILE  RETVAL=$?  echo  [ $RETVAL -eq 0 ] && touch $LOCKFILE          return $RETVAL}      stop() {  echo -n $"Shutting down memcached......"  /sbin/killproc $BINFILE  RETVAL=$?  echo  [ $RETVAL -eq 0 ] && rm -f $LOCKFILE          return $RETVAL}      restart() {  stop  sleep 1  start}      reload() {  echo -n $"Reloading memcached......"  /sbin/killproc $BINFILE -HUP  RETVAL=$?  echo          return $RETVAL}      case "$1" instart)  start  ;;        stop)  stop  ;;        restart)  restart  ;;        condrestart)  [ -e $LOCKFILE ] && restart  RETVAL=$?  ;;        reload)  reload  ;;        status)  status $prog  RETVAL=$?  ;;        *)  echo "Usage: $0 {start|stop|restart|condrestart|status}"  RETVAL=1esac

            

exit $RETVAL# chmod +x /etc/init.d/memcached# chkconfig --add memcached# chkconfig --level 235 memcached on# service memcached start

binlog 自動清理腳本

# vim /data/scripts/delete_mysql_binlog.sh
#!/bin/bash#=======================================================================================#  用于刪除 MySQL Master 端已經同步完的 binlog【需在 Master 端運行】,以減少磁盤空間#  每天凌晨 5:30 分運行一次##  注:需在 Slave 端添加允許 Master 端訪問的帳號【帳號:check_binlog,密碼:binlog_2356】#     運行于 MySQL Master 端【目前只用于一主一從的同步模式,對于多從的情況暫時未考慮】#=======================================================================================PATH=/sbin:/bin:/usr/sbin:/usr/bin:/usr/local/sbin:/usr/local/bin   ## Slave端連接信息SLAVE_ADDR="XXX.XXX.XXX.XXX"SLAVE_USER="check_binlog"SLAVE_PWD="binlog_2356"   LOGFILE="/data/logs/db_sync_info.log"PINGFILE="/tmp/mysqlping.log"   ## MySQL狀態信息查看命令SQLCMD="show slave status"   #=======================================================================================## 檢查MySQL是否已經運行if [[ `ps aux | grep mysql[d] | wc -l` -eq 0 ]]; then  echo The MySQL is not running at: `date +%F" "%H-%M-%S` >> ${LOGFILE}  exit 1fi   ## 測試Slave端的連通性nohup mysqladmin -h${SLAVE_ADDR} -u${SLAVE_USER} -p${SLAVE_PWD} ping > ${PINGFILE}retval=`grep "^error" ${PINGFILE}`rm -f ${PINGFILE}if [[ "${retval}X" != "X" ]]; then  echo The MySQL Slave can not be connected at: `date +%F" "%H-%M-%S` >> ${LOGFILE}  exit 1fi   ## 檢查是否合法的SlaveMASTER_ADDR=`mysql -h${SLAVE_ADDR} -u${SLAVE_USER} -p${SLAVE_PWD} -e "${SQLCMD}/G;" | awk '$1=="Master_Host:" {print $2}'`LOCAL_ADDR=`/sbin/ifconfig eth1 | awk -F ':' '/inet addr/{print $2}' | sed 's/[a-zA-Z ]//g'`if [[ "${MASTER_ADDR}" != "${LOCAL_ADDR}" ]]; then  echo The MySQL Slave is not lawful at: `date +%F" "%H-%M-%S` >> ${LOGFILE}  exit 1fi   ## 獲得Slave端信息,以此來確定是否處于正常同步的情況IO_STATUS=`mysql -h${SLAVE_ADDR} -u${SLAVE_USER} -p${SLAVE_PWD} -e "${SQLCMD}/G;" | awk '$1=="Slave_IO_Running:" {print $2}'`SQL_STATUS=`mysql -h${SLAVE_ADDR} -u${SLAVE_USER} -p${SLAVE_PWD} -e "${SQLCMD}/G;" | awk '$1=="Slave_SQL_Running:" {print $2}'`if [[ "${IO_STATUS}" != "Yes" || "${SQL_STATUS}" != "Yes" ]]; then  echo The MySQL Replication is not synchronous at: `date +%F" "%H-%M-%S` >> ${LOGFILE}  exit 1fi   ## 再做一次判斷,以保證數據同步絕對正?!緞摻y試數據】mysql -uroot -e "create database if not exists mytestdb;"sleep 3   retval=`mysql -h${SLAVE_ADDR} -u${SLAVE_USER} -p${SLAVE_PWD} -e "show databases;" | grep mytestdb`mysql -uroot -e "drop database if exists mytestdb;"if [[ "${retval}X" = "X" ]]; then  echo The MySQL Replication is not synchronous at: `date +%F" "%H-%M-%S` >> ${LOGFILE}  exit 1fi   ## 在已經同步的情況,還需要判斷當前同步的binlog,以此來確定哪些已經是過期的binlogSLAVE_BINLOG1=`mysql -h${SLAVE_ADDR} -u${SLAVE_USER} -p${SLAVE_PWD} -e "${SQLCMD}/G;" | awk '$1=="Master_Log_File:" {print $2}'`SLAVE_BINLOG2=`mysql -h${SLAVE_ADDR} -u${SLAVE_USER} -p${SLAVE_PWD} -e "${SQLCMD}/G;" | awk '$1=="Relay_Master_Log_File:" {print $2}'`## 獲得Master端,當前的binlog文件以及binlog路徑MASTER_BINLOG=`mysql -uroot -e "show master status;" | grep -v '^+' | tail -1 | awk '{print $1}'`   ## 主從端已經同步到相同的binlogif [[ "${SLAVE_BINLOG1}" = "${SLAVE_BINLOG2}" && "${SLAVE_BINLOG1}" = "${MASTER_BINLOG}" ]]; then  CURR_BINLOG="${MASTER_BINLOG}"     ## 主從端已經同步,但從端的binlog還沒有追趕到主端最新的binlogelif [[ "${SLAVE_BINLOG1}" = "${SLAVE_BINLOG2}" && "${SLAVE_BINLOG1}" != "${MASTER_BINLOG}" ]]; then  CURR_BINLOG="${SLAVE_BINLOG1}"     ## 主從端已經同步,主從端的binlog一致,但relaylog還不一致elif [[ "${SLAVE_BINLOG1}" != "${SLAVE_BINLOG2}" && "${SLAVE_BINLOG1}" = "${MASTER_BINLOG}" ]]; then  CURR_BINLOG="${SLAVE_BINLOG2}"     else  echo Has noknown error at:`date +%F" "%H-%M-%S` >> ${LOGFILE}  exit 1fi   mysql -uroot -e "purge binary logs to '${CURR_BINLOG}';"if [[ $? -eq 0 ]]; then  echo Clear MySQL binlog is ok at: `date +%F" "%H-%M-%S` >> ${LOGFILE}fi
# crontab -e 30 05 * * * /data/scripts/delete_mysql_binlog.sh >/dev/null 2>&1

修復MySQL主從同步

#!/bin/shPATH=/sbin:/bin:/usr/sbin:/usr/bin:/usr/local/sbin:/usr/local/bin  LOGFILE=/data/repair_mysql_sync_`date +%F`.logSQLCMD1="show slave status"  ## 查看MySQL是否已啟動if [[ `ps aux | grep mysqld | grep -v grep`"X" = "X" ]]; then  echo The MySQL is not running at: `date +%F" "%H-%M-%S` >> ${LOGFILE}  exit 1fi  ## 獲得MySQL從端Relay binlog的路徑retval=`grep "^relay-log" /etc/my.cnf | grep -v relay-log- | grep '/'`if [[ "${retval}" = "X" ]]; then  RELAY_BINLOG_PATH=`ps aux | grep -w mysqld | grep -v grep | awk '{print $13}' | awk -F '=' '{print $2}'`else  RELAY_BINLOG_PATH=`dirname $(echo ${retval} | awk -F '=' '{print $2}')`fi  ## 查找master.info文件,用于定位Binlog信息MASTER_FILE=`ps aux | grep -w mysqld | grep -v grep | awk '{print $13}' | awk -F '=' '{print $2}'`/master.infoif [[ ! -e ${MASTER_FILE} ]]; then  echo This Server is not MySQL Slave at: `date +%F" "%H-%M-%S` >> ${LOGFILE}  exit 1fi  ## 獲得當前的同步狀態IO_STATUS=`mysql -uroot -e "${SQLCMD1}/G;" | awk '$1=="Slave_IO_Running:" {print $2}'`SQL_STATUS=`mysql -uroot -e "${SQLCMD1}/G;" | awk '$1=="Slave_SQL_Running:" {print $2}'`if [[ "${IO_STATUS}" = "Yes" && "${SQL_STATUS}" = "Yes" ]]; then  echo Now, The MySQL Replication is synchronous at: `date +%F" "%H-%M-%S` >> ${LOGFILE}  exit 0fi  ## 從master.info文件中,獲得MySQL主端的同步信息REPLI_INFO=`sed '/^$/d' ${MASTER_FILE} | tail +2 | head -5`REPLI_BINLOG_FILE=`echo ${REPLI_INFO} | awk '{print $1}'`REPLI_IPADDR=`echo ${REPLI_INFO} | awk '{print $3}'`REPLI_USER=`echo ${REPLI_INFO} | awk '{print $4}'`REPLI_PWD=`echo ${REPLI_INFO} | awk '{print $5}'`  ## 刪除無用的Relay binlogrm -rf ${RELAY_BINLOG_PATH}/*-relay-bin.*  ## 直接從0位置開始同步SQLCMD2="change master to master_host='${REPLI_IPADDR}', master_user='${REPLI_USER}', master_password='${REPLI_PWD}',"SQLCMD2="${SQLCMD2} master_log_file='${REPLI_BINLOG_FILE}', master_log_pos=0"mysql -uroot -e "stop slave;"mysql -uroot -e "${SQLCMD2};"mysql -uroot -e "start slave;"  ## 如果同步的過程中,出現重復記錄導致同步失敗,就跳過while truedo  sleep 2  IO_STATUS=`mysql -uroot -e "${SQLCMD1}/G;" | awk '$1=="Slave_IO_Running:" {print $2}'`  SQL_STATUS=`mysql -uroot -e "${SQLCMD1}/G;" | awk '$1=="Slave_SQL_Running:" {print $2}'`  BEHIND_STATUS=`mysql -uroot -e "${SQLCMD1}/G;" | awk '$1=="Seconds_Behind_Master:" {print $2}'`  SLAVE_BINLOG1=`mysql -uroot -e "${SQLCMD1}/G;" | awk '$1=="Master_Log_File:" {print $2}'`  SLAVE_BINLOG2=`mysql -uroot -e "${SQLCMD1}/G;" | awk '$1=="Relay_Master_Log_File:" {print $2}'`      ## 出現錯誤,就將錯誤信息記錄到日志文件,并跳過錯誤繼續同步  if [[ "${IO_STATUS}" != "Yes" || "${SQL_STATUS}" != "Yes" ]]; then    ERRORINFO=`mysql -uroot -e "${SQLCMD1}/G;" | awk -F ': ' '$1=="Last_Error" {print $2}'`    echo "The MySQL synchronous error information: ${ERRORINFO}" >> ${LOGFILE}    mysql -uroot -e "stop slave;"    mysql -uroot -e "set GLOBAL SQL_SLAVE_SKIP_COUNTER=1;"    mysql -uroot -e "start slave;"        ## 已完成同步,就正常退出  elif [[ "${IO_STATUS}" = "Yes" && "${SQL_STATUS}" = "Yes" && "${SLAVE_BINLOG1}" = "${SLAVE_BINLOG2}" && ${BEHIND_STATUS} -eq 0 ]]; then    echo The MySQL synchronous is ok at: `date +%F" "%H-%M-%S` >> ${LOGFILE}    break  fidone


注:相關教程知識閱讀請移步到MYSQL教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
96国产粉嫩美女| 最近2019中文免费高清视频观看www99| 亚洲第一中文字幕| 成人免费高清完整版在线观看| 亚洲级视频在线观看免费1级| 亚洲精品91美女久久久久久久| 久久久久久久久国产| 国语对白做受69| 亚洲精品欧美日韩专区| 久久久999成人| 亚洲国产成人精品女人久久久| 国产在线观看精品一区二区三区| 亚洲精品xxxx| 九九热99久久久国产盗摄| 中文字幕在线成人| 精品国内自产拍在线观看| 一区二区欧美在线| 久久成人这里只有精品| 亚洲伊人第一页| 亚洲欧美国产另类| 日韩视频免费在线| 亚洲精品国产精品久久清纯直播| 国产精品欧美一区二区三区奶水| 亚洲成人激情小说| 亚洲网站视频福利| 日韩精品视频免费专区在线播放| 久久久这里只有精品视频| 亚洲xxxx视频| 成人看片人aa| 青青草成人在线| 91高清免费在线观看| 亚洲sss综合天堂久久| 91国内揄拍国内精品对白| 日韩av免费一区| 日韩视频第一页| 亚洲成色www8888| 91国在线精品国内播放| 欧美在线免费视频| 日韩欧美综合在线视频| 蜜臀久久99精品久久久无需会员| 欧美在线视频在线播放完整版免费观看| 亚洲精品久久久久| 亚洲男人天堂久| 亚洲深夜福利网站| 久久久久久久国产精品| 91亚洲国产精品| 国产成人鲁鲁免费视频a| 国产亚洲人成网站在线观看| 亚洲国产日韩欧美在线99| 国产精品美女免费视频| 国产精品青草久久久久福利99| 久久精品中文字幕免费mv| 92福利视频午夜1000合集在线观看| 久久精品一本久久99精品| 成人午夜一级二级三级| 亚洲午夜久久久久久久| 亚洲精品免费网站| 欧美大片免费观看在线观看网站推荐| 国产在线观看精品| 97在线视频国产| 亚洲国产日韩精品在线| 久久综合免费视频| 国产精品人人做人人爽| 日韩高清av一区二区三区| 国产精品一区二区性色av| 久久av红桃一区二区小说| 永久免费看mv网站入口亚洲| 在线国产精品视频| 57pao成人国产永久免费| 亚洲激情在线视频| 欧美小视频在线观看| 国产精品久久激情| 国产精品视频yy9099| 亚洲欧洲日本专区| 国产精品美女久久久久久免费| 日韩在线视频二区| 一区二区在线视频播放| 日韩小视频在线观看| 高清视频欧美一级| 欧美精品在线免费观看| 欧美日韩在线观看视频小说| 久久这里只有精品视频首页| 欧洲日韩成人av| 日韩高清免费观看| 成人国产精品久久久久久亚洲| 欧美一区二粉嫩精品国产一线天| 国产免费亚洲高清| 国产亚洲日本欧美韩国| 国产成人精品视| 久久久精品美女| 在线午夜精品自拍| 久久影院模特热| 亚洲国产精品视频在线观看| 亚洲bt欧美bt日本bt| 欧美大尺度电影在线观看| 国产日本欧美在线观看| 久久久久久久香蕉网| 日本aⅴ大伊香蕉精品视频| 亚洲福利视频专区| 亚洲欧洲一区二区三区在线观看| 91久久久久久国产精品| 日韩三级影视基地| 992tv在线成人免费观看| 上原亚衣av一区二区三区| 日本中文字幕成人| 日韩国产欧美区| 久久影院在线观看| 综合久久五月天| 中文字幕av一区二区三区谷原希美| 国产日韩欧美中文在线播放| 欧美性高潮床叫视频| 国产精品自拍偷拍视频| 97在线免费视频| 亚洲伦理中文字幕| 久久久国产精品亚洲一区| 欧美肥臀大乳一区二区免费视频| 国产欧美日韩精品丝袜高跟鞋| 国产精品成人一区二区三区吃奶| 欧美大尺度激情区在线播放| 两个人的视频www国产精品| 一区二区三区四区视频| 亚洲国产精品字幕| 91亚洲va在线va天堂va国| 97在线免费观看视频| 中文字幕日韩欧美| 久久久中文字幕| 久久天堂电影网| 午夜精品一区二区三区在线| 欧洲亚洲免费在线| 日韩一区二区三区国产| 日韩视频在线一区| 精品一区电影国产| 国产91精品久久久久久| 亚洲已满18点击进入在线看片| 欧美一区二区三区艳史| 狠狠爱在线视频一区| 狠狠久久亚洲欧美专区| 精品动漫一区二区| 亚洲电影免费在线观看| 色久欧美在线视频观看| 亚洲成人av片| 久久久久一本一区二区青青蜜月| 国产91精品最新在线播放| 亚洲精品视频在线观看视频| 日韩在线视频中文字幕| 亚洲精品v欧美精品v日韩精品| 国产精品wwwwww| 国产亚洲美女精品久久久| 国产精品久久激情| 亚洲伦理中文字幕| 91午夜在线播放| 国产成人精品综合久久久| 一区二区av在线| 91久久在线观看| 91精品国产91久久久久久不卡| 国产精品国产三级国产aⅴ9色| 2018中文字幕一区二区三区| 精品国产电影一区| 久久久久久久久久婷婷| 精品久久久久久久久国产字幕| 欧美国产在线视频| 97视频在线看| 国产精品爽爽ⅴa在线观看| 7m第一福利500精品视频|