1、MySQL数据库备份脚本,下面的脚本是Mysql全量备份+异地备份
一般Mysql数据库备份会采用在MYSQL从库上执行全量备份+增量备份方式。在从库备份避免Mysql主库备份的时候锁表造成业务影响。
- shell> vim db_backup.sh
- #!/bin/bash
- # description: MySQL buckup shell script
- # author: magedu.com
- # 192.168.10.10 为专门的备份服务器,需要做一下服务器之间免密码登录
- #备份的数据库名
- DATABASES=(
- "magedu01"
- "magedu02"
- )
- USER="root"
- PASSWORD="dbpwd123"
- MAIL="magedu@gmail.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
- done
- #判断数据库备份是否全部成功,全部成功就同步到异地备份f服务器
- 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
- #备份失败后向管理者发送邮件提醒
- mail -s "database Daily Backup Fail!" $MAIL
- fi
- #删除30天以上的备份文件
- find $BACKUP_DIR -type f -mtime +30 –name "*.gz" –exec rm -f {} \;
2、Nginx负载均衡服务器上监控Nginx进程的脚本
企业负载均衡层如果用到Nginx+Keepalived架构,而Keepalived无法进行Nginx服务的实时切换,所以这里用了一个监控脚本check_nginx_pid.sh,每隔5秒就监控一次Nginx的运行状态,如果发现有问题就关闭本机的Keepalived程序,让VIP切换到从Nginx负载均衡器上。
- shell> vim check_nginx_pid.sh
- #!/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
- nginxpid='ps -C nginx –no-header | wc -l'
- if [$nginxpid -eq 0 ];then
- /etc/init.d/keepalived stop
- fi
- fi
- sleep 5
- done
3、MySQL主从监控邮件报警脚本
- 此脚本应该能适应各种各样不同的内外网环境。
- 让脚本也顺便监控下MySQL是否正常运行。
- Slave机器的IO和SQL状态都必须为YES,缺一不可,这里用到了多重条件判断-a。