溫馨提示×

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

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

shell腳本在實(shí)際工作中的應(yīng)用

發(fā)布時(shí)間:2020-06-02 17:16:06 來源:億速云 閱讀:313 作者:Leah 欄目:系統(tǒng)運(yùn)維

這篇文章給大家分享的是shell腳本在實(shí)際工作中的應(yīng)用。小編覺得挺實(shí)用的,因此分享給大家學(xué)習(xí)。如下資料是shell腳本的多種使用方式。

1)Mysql數(shù)據(jù)庫備份腳本(完整備份+異地備份)

一般Mysql數(shù)據(jù)庫備份會(huì)采用在MYSQL從庫上執(zhí)行全量備份+增量備份方式。在從庫備份避免Mysql主庫備份的時(shí)候鎖表造成業(yè)務(wù)影響。

#!/bin/bash  
set -e                         #當(dāng)腳本有錯(cuò)誤時(shí),便停止執(zhí)行腳本
#備份的數(shù)據(jù)庫名
DATABASES=(
            "magedu01"
            "magedu02"
)
USER="root"
PASSWORD="dbpwd123"

MAIL="123456@163.com"
BACKUP_DIR=/data/backup
LOGFILE=/data/backup/data_backup.log
DATE=`date +%Y%m%d_%H%M`

cd $BACKUP_DIR
#開始備份之前,將備份信息頭寫入日記文件   
echo "--------------------" >> $LOGFILE
echo "BACKUP DATE:" $(date +"%y-%m-%d %H:%M:%S") >> $LOGFILE
echo "-------------------" >> $LOGFILE

for DATABASE in ${DATABASES};do
  /usr/local/mysql/bin/mysqldump -u$USER -p$PASSWORD --events  -R --opt  $DATABASE |gzip >${BACKUP_DIR}\/${DATABASE}_${DATE}.sql.gz
  if [ $? == 0 ];then
    echo "$DATE--$DATABASE is backup succeed" >> $LOGFILE
  else
    echo "Database Backup Fail!" >> $LOGFILE
  fi
done
#判斷數(shù)據(jù)庫備份是否全部成功,全部成功就同步到異地備份f服務(wù)器
if [ $? == 0 ];then
  /usr/bin/rsync -zrtopg   --delete  /data/backup/* root@192.168.10.10:/data/backup/  >/dev/null 2>&1
else
  echo "Database Backup Fail!" >> $LOGFILE
  #備份失敗后向管理者發(fā)送郵件提醒
  mail -s "database Daily Backup Fail!" $MAIL
fi

#刪除30天以上的備份文件  
find $BACKUP_DIR  -type f -mtime +30 -name "*.gz" -exec rm -f {} \;

2)nginx進(jìn)行日志切割的腳本

#!/bin/bash
set -e                         #當(dāng)腳本有錯(cuò)誤時(shí),便停止執(zhí)行腳本
LOG_PATH="/var/log/nginx"      #定義日志存放路徑
ACCESS_LOG="access.log"
ERROR_LOG="error.log"
YESTERDAY=$(date -d '1 day ago' +%F)        #定義昨天的日期
for i in $(find ${LOG_PATH} -name ${ACCESS_LOG});do
    cd $(dirname ${i})
    if  [[ -f ${ACCESS_LOG} ]];then
        cp {,${YESTERDAY}-}${ACCESS_LOG}         #將原本的日志文件復(fù)制一份
        : > ${ACCESS_LOG}                        #將原本的日志內(nèi)容清空
    fi
    if  [[ -f ${ERROR_LOG} ]];then
        ERROR_SIZE=$(ls -l   ${ERROR_LOG} | awk '{print $5}')
        if  [[ ${ERROR_SIZE} -gt 20971520 ]];then               #如果error.log日志大于20M,進(jìn)行切割
            cp {,${YESTERDAY}-}${ERROR_LOG}
            : > ${ERROR_LOG}
        fi
    fi
done
find ${LOG_PATH} -type f -name "*.log" -mtime +7 -delete            #將一周前的日志進(jìn)行刪除

3)Nginx負(fù)載均衡服務(wù)器上監(jiān)控Nginx進(jìn)程的腳本

企業(yè)負(fù)載均衡層如果用到Nginx+Keepalived架構(gòu),而Keepalived無法進(jìn)行Nginx服務(wù)的實(shí)時(shí)切換,所以這里用了一個(gè)監(jiān)控腳本check_nginx_pid.sh,每隔5秒就監(jiān)控一次Nginx的運(yùn)行狀態(tài),如果發(fā)現(xiàn)有問題就關(guān)閉本機(jī)的Keepalived程序,讓VIP切換到從Nginx負(fù)載均衡器上。

#!/bin/bash
while :
do
nginxpid=`ps -C nginx --no-header | wc -l`
if [ $nginxpid -eq 0 ];then
  ulimit -SHn 65535
  /usr/local/nginx/sbin/nginx
    sleep 5
else
 /etc/init.d/keepalived stop
fi
sleep 5
done

4)Mysql主從監(jiān)控郵件報(bào)警腳本

1)此腳本應(yīng)該能適應(yīng)各種各樣不同的內(nèi)外網(wǎng)環(huán)境。
2)讓腳本也順便監(jiān)控下MySQL是否正常運(yùn)行。
3)Slave機(jī)器的IO和SQL狀態(tài)都必須為YES,缺一不可,這里用到了多重條件判斷-a。

#!/bin/bash
MYSQLPORT='netstat -na|grep "LISTEN"|grep "3306"|awk -F[:" "]+ '{print $4}''
MYSQLIP='ifconfig eth0|grep "inet addr" | awk -F[:" "]+ '{print $4}''
STATUS=$(/usr/local/mysql/bin/mysql -u dbuser -dbpwd123 -S /tmp/mysql.sock -e "show slave status\G" | grep -i "running")
IO_env='echo $STATUS | grep IO | awk ' {print $2}''
SQL_env='echo $STATUS | grep SQL | awk '{print $2}''

if [ "$MYSQLPORT" == "3306" ]
then
 echo "mysql is running"
else
 mail -s "warn!server: $MYSQLIP mysql is down" magedu@gmail.com
fi

if [ "$IO_env" = "Yes" -a "$SQL_env" = "Yes" ]
then
 echo "Slave is running!"
else
 echo "####### $date #########">> /data/log/check_mysql_slave.log
 echo "Slave is not running!" >> /data/log/check_mysql_slave.log
 mail -s "warn! $MySQLIP_replicate_error" magedu@gmail.com << /data/log/check_mysql_slave.log
fi

建議此腳本10分鐘執(zhí)行一次,可編寫計(jì)劃任務(wù)!

5)系統(tǒng)初始化腳本

此腳本用于新裝Linux的相關(guān)配置工作,比如更換默認(rèn)yum源,優(yōu)化系統(tǒng)內(nèi)核、停掉一些沒必要啟動(dòng)的系統(tǒng)服務(wù)等。此腳本尤其適合大批新安裝的CentOS系列的服務(wù)器。適用于Centos7!

#!/bin/bash
#判斷是否為root用戶
if [ `whoami` != "root" ];then
echo " only root can run it"
exit 1
fi
#執(zhí)行前提示
echo -e "\033[31m 這是centos7系統(tǒng)初始化腳本,將更新系統(tǒng)內(nèi)核至最新版本,請(qǐng)慎重運(yùn)行!\033[0m" 
read -s -n1 -p "Press any key to continue or ctrl+C to cancel"
echo "Your inputs: $REPLY"
#1.定義配置yum源的函數(shù)
yum_config(){
mv /etc/yum.repos.d/CentOS-Base.repo /etc/yum.repos.d/CentOS-Base.repo.backup
wget -O /etc/yum.repos.d/CentOS-Base.repo http://mirrors.aliyun.com/repo/Centos-7.repo
yum clean all && yum makecache
}
#2.定義配置NTP的函數(shù)
ntp_config(){
yum –y install chrony
systemctl start chronyd && systemctl enable chronyd
timedatectl set-timezone Asia/Shanghai && timedatectl set-ntp yes
}
#3.定義關(guān)閉防火墻的函數(shù)
close_firewalld(){
systemctl stop firewalld.service &> /dev/null
systemctl disable firewalld.service &> /dev/null
}
#4.定義關(guān)閉selinux的函數(shù)
close_selinux(){
setenforce 0
sed -i 's/enforcing/disabled/g' /etc/selinux/config
}
#5.定義安裝常用工具的函數(shù)
yum_tools(){
yum install –y vim wget curl curl-devel bash-completion lsof iotop iostat unzip bzip2 bzip2-devel
yum install –y gcc gcc-c++ make cmake autoconf openssl-devel openssl-perl net-tools
source /usr/share/bash-completion/bash_completion
}
#6.定義升級(jí)最新內(nèi)核的函數(shù)
update_kernel (){
rpm --import https://www.elrepo.org/RPM-GPG-KEY-elrepo.org
rpm -Uvh http://www.elrepo.org/elrepo-release-7.0-3.el7.elrepo.noarch.rpm
yum --enablerepo=elrepo-kernel install -y kernel-ml
grub2-set-default 0
grub2-mkconfig -o /boot/grub2/grub.cfg
}
#執(zhí)行腳本
main(){
    yum_config;
    ntp_config;
    close_firewalld;
    close_selinux;
    yum_tools;
    update_kernel;
}
main

關(guān)于shell腳本在實(shí)際工作中的應(yīng)用就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,可以學(xué)到更多知識(shí)。如果喜歡這篇文章,不如把它分享出去讓更多的人看到。


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

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

AI