エンタープライズ生産環境shellスクリプト事例の共有
6023 ワード
1)Mysqlデータベースバックアップスクリプト(フルバックアップ+オフサイトバックアップ)
一般的にMysqlデータベースバックアップでは、MYSQLでライブラリからフルバックアップ+インクリメンタルバックアップを実行します.ライブラリバックアップからMysqlプライマリ・ライブラリのバックアップを回避する際に、ロック・テーブルがビジネスに影響を及ぼすことがあります.
2)nginxによるログカットのスクリプト
3)Nginx負荷分散サーバー上でNginxプロセスを監視するスクリプト
エンタープライズ・ロード・バランシング・レイヤがNginx+Keepalivedアーキテクチャを使用している場合、KeepalivedはNginxサービスのリアルタイム切り替えができないため、ここでは監視スクリプトcheck_を使用します.nginx_pid.shは、5秒ごとにNginxの運転状態を監視し、問題が発見されたら自機のKeepalivedプログラムを閉じ、VIPをNginx負荷イコライザに切り替える.
4)Mysql主従監視メールアラームスクリプト
1)このスクリプトは,様々な内外ネットワーク環境に適応できるはずである.2)スクリプトもMySQLが正常に動作しているかどうかを監視します.3)SlaveマシンのIOとSQLの状態はいずれもYESでなければならず,一つ欠けてはならないが,ここでは多重条件判定−aを用いた.
このスクリプトは10分に1回実行することをお勧めします.計画タスクを作成できます.
5)システム初期化スクリプト
このスクリプトは、デフォルトのyumソースの交換、システムカーネルの最適化、起動する必要のないシステムサービスの停止など、Linuxの新規インストールに関する構成作業に使用されます.このスクリプトは、特に新しくインストールされたCentOSシリーズのサーバに適しています.Centos 7に適用!
一般的にMysqlデータベースバックアップでは、MYSQLでライブラリからフルバックアップ+インクリメンタルバックアップを実行します.ライブラリバックアップからMysqlプライマリ・ライブラリのバックアップを回避する際に、ロック・テーブルがビジネスに影響を及ぼすことがあります.
#!/bin/bash
set -e # ,
#
DATABASES=(
"magedu01"
"magedu02"
)
USER="root"
PASSWORD="dbpwd123"
MAIL="[email protected]"
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
# , f
if [ $? == 0 ];then
/usr/bin/rsync -zrtopg --delete /data/backup/* [email protected]:/data/backup/ >/dev/null 2>&1
else
echo "Database Backup Fail!" >> $LOGFILE
#
mail -s "database Daily Backup Fail!" $MAIL
fi
# 30
find $BACKUP_DIR -type f -mtime +30 -name "*.gz" -exec rm -f {} \;
2)nginxによるログカットのスクリプト
#!/bin/bash
set -e # ,
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} #
: > ${ACCESS_LOG} #
fi
if [[ -f ${ERROR_LOG} ]];then
ERROR_SIZE=$(ls -l ${ERROR_LOG} | awk '{print $5}')
if [[ ${ERROR_SIZE} -gt 20971520 ]];then # error.log 20M,
cp {,${YESTERDAY}-}${ERROR_LOG}
: > ${ERROR_LOG}
fi
fi
done
find ${LOG_PATH} -type f -name "*.log" -mtime +7 -delete #
3)Nginx負荷分散サーバー上でNginxプロセスを監視するスクリプト
エンタープライズ・ロード・バランシング・レイヤがNginx+Keepalivedアーキテクチャを使用している場合、KeepalivedはNginxサービスのリアルタイム切り替えができないため、ここでは監視スクリプトcheck_を使用します.nginx_pid.shは、5秒ごとにNginxの運転状態を監視し、問題が発見されたら自機のKeepalivedプログラムを閉じ、VIPをNginx負荷イコライザに切り替える.
#!/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主従監視メールアラームスクリプト
1)このスクリプトは,様々な内外ネットワーク環境に適応できるはずである.2)スクリプトもMySQLが正常に動作しているかどうかを監視します.3)SlaveマシンのIOとSQLの状態はいずれも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" [email protected]
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" [email protected] << /data/log/check_mysql_slave.log
fi
このスクリプトは10分に1回実行することをお勧めします.計画タスクを作成できます.
5)システム初期化スクリプト
このスクリプトは、デフォルトのyumソースの交換、システムカーネルの最適化、起動する必要のないシステムサービスの停止など、Linuxの新規インストールに関する構成作業に使用されます.このスクリプトは、特に新しくインストールされたCentOSシリーズのサーバに適しています.Centos 7に適用!
#!/bin/bash
# root
if [ `whoami` != "root" ];then
echo " only root can run it"
exit 1
fi
#
echo -e "\033[31m centos7 , , !\033[0m"
read -s -n1 -p "Press any key to continue or ctrl+C to cancel"
echo "Your inputs: $REPLY"
#1. yum
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
ntp_config(){
yum –y install chrony
systemctl start chronyd && systemctl enable chronyd
timedatectl set-timezone Asia/Shanghai && timedatectl set-ntp yes
}
#3.
close_firewalld(){
systemctl stop firewalld.service &> /dev/null
systemctl disable firewalld.service &> /dev/null
}
#4. selinux
close_selinux(){
setenforce 0
sed -i 's/enforcing/disabled/g' /etc/selinux/config
}
#5.
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.
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
}
#
main(){
yum_config;
ntp_config;
close_firewalld;
close_selinux;
yum_tools;
update_kernel;
}
main