MySQL备份脚本

找到10以前的文件并删除它

#find . -mtime +10 -exec rm -rf {} \;

MySQL数据库备份脚本

#!/bin/sh
cd /home/backups/sql/
mkdir /home/backups/extmail
#Remove old backups
find /home/backups/sql/* -mtime +5 -exec rm -fr {} \; > /dev/null 2>&1
#Create the filename for the backup
eval `date "+day=%d; month=%m; year=%Y; hour=%H; min=%M; sec=%S"`
INSTFIL="extmail-backup-$year$month$day-$hour$min$sec"
#Dump the MySQL Database
#touch /home/backups/extmail/$INSTFIL.txt
/usr/local/bin/mysqldump -usqlback -p"sqlbackup" --opt extmail > /home/backups/extmail/$INSTFIL.sql
#Gzip the whole folder
tar -Pcpzf /home/backups/sql/$INSTFIL.tar.gz /home/backups/extmail/*
#Remove the SQL Dump
rm -rf /home/backups/extmail

备份Mysql并上传到ftp服务器

#!/bin/bash
#MySQL设置
MysqlHost=localhost
MysqlUser=rootMysqlPwd=password
#备份文件设置
BackupPath=/backup/db
FileName=$MysqlHost-$(date +%Y%m%d-%H%M%S)
FileFullPath=$BackupPath/$FileName
#ftp设置
FtpHost=10.206.4.121
FtpUser=iptv
FtpPwd=StarIptv
FtpPath=/ftp/backup/mysql
mkdir -p $BackupPath

#备份mysql并导出到文件

mysqldump -u$MysqlUser -p$MysqlPwd -h$MysqlHost --opt --all-databases -f > $FileFullPath.sql

#压缩备份文件

tar -Pzcvf $FileFullPath.tar.gz $FileFullPath.sql

#上传到ftp

ftp -n $FtpHost <<AUTOEOF
quote USER $FtpUser
quote PASS $FtpPwd
cd $FtpPath
binary
put $FileFullPath.tar.gz $FtpPath/$FileName.tar.gz
quit
AUTOEOF

#删除SQL文件
rm -rf $FileFullPath.sql
#删除30天之前的文件
find $BackupPath -type f -mtime +30 -exec rm -f {} ;

企业生产环境Shell脚本案例分享

生产环境下的Shell脚本还是挺多的,这里介绍几个企业常见的Shell脚本。

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

MySQL主从监控邮件报警脚本

此脚本应该能适应各种各样不同的内外网环境。
让脚本也顺便监控下MySQL是否正常运行。
Slave机器的IO和SQL状态都必须为YES,缺一不可,这里用到了多重条件判断-a。

shell> check_mysql_slave.sh
#!/bin/bash
#check MySQL_Slave Status

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分钟运行一次:
shell> crontab -e
*/10 * * * * root /bin/sh /root/check_mysql_slave.sh

系统初始化脚本

此脚本用于新装Linux的相关配置工作,比如更换默认yum源,优化系统内核、停掉一些没必要启动的系统服务等。此脚本尤其适合大批新安装的CentOS系列的服务器。适用于Centos7。

shell>vim cenots_7_system_init.sh
#!/bin/bash
# Filename:    centos7-init.sh
# Author:     magedu@gmail.com
#判断是否为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

mysql数据库定时备份

操作步骤:

1、将脚本放到任意位置下,不容易被误删即可
2、定时任务,一周执行一次脚本

脚本如下:

#!bin/bash

backuppath=/data/mysql/backup

date=$(date +%Y%m%d%H%M)

SQLuser=root

SQLpwd=password

mysqldump=/usr/local/mysql/bin/mysqldump

mysql=/usr/local/mysql/bin/mysql

HIS_Date=`date -d $(date -d "-30 day" +%Y%m%d) +%s`  #取30天之前的时间戳

Sql_Date=`date -d $(date -d "-7 day" +%Y%m%d) +%s`  #取7天之前的时间戳

#进入mysql数据库,清除zabbix历史数据

$mysql -u$SQLuser -p$SQLpwd -e"

    use zabbix;

    delete from history WHERE 'clock' < $Sql_Date;

    delete from history_uint WHERE 'clock' < $Sql_Date;

    delete from history_str WHERE 'clock' < $Sql_Date;

    delete from history_text WHERE 'clock' < $Sql_Date;

    delete from history_log WHERE 'clock' < $Sql_Date;

    exit

    "

#建立备份目录

if [ ! -e $backuppath ];then

mkdir -p $backuppath

fi

#开始备份zabbix库

$mysqldump -u$SQLuser -p$SQLpwd  zabbix  >$backuppath/zabbix$date.sql

#删除1个月前的备份数据

find /data/mysql/backup -mtime +30 -type f -name \zabbix*.sql -exec rm -f {} \;

在数据库历史数据过大,可以考虑truncate掉历史数据。

$mysql -u$SQLuser -p$SQLpwd -e"

    use zabbix;

        truncate table history;

        truncate table history_log;

    truncate table history_uint;

    truncate table history_str;

    truncate table history_text;

        exit

        "

mysql定时备份脚本

1:备份脚本
包含备份,删除原文件,删除20天以前的备份文件

#!/bin/sh
    BCK_DIR="/data/backup"    
    DATE=`date +%F`
    BACK_NAME=$BCK_DIR/db_$DATE.sql

    mysqldump -h127.0.0.1 -uciika -pciikapwd blog --default-character-set=utf8 --extended-insert=false > $BACK_NAME
    tar zcvf $BACK_NAME.tar.gz $BACK_NAME 
    rm -f $EBACK_NAME
    find $BCK_DIR -name "*.tar.gz" -type f -mtime +20 -exec rm {} \; >delete.log

2:添加定时任务

0 5 * * * /opt/exec/mysqlback.sh

每天凌晨5点执行

参考链接 :
mysql定时备份脚本 : http://ciika.com/page/17/

企业生产环境Shell脚本案例分享 :https://www.jianshu.com/p/a527e79fbe16
【数据库】mysql数据库定时备份 : https://www.jianshu.com/p/217639914bca

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值