Mysql database scheduled backup script sharing

Mysql database scheduled backup script sharing

BackUpMysql.sh script

#!/bin/bash
PATH=/bin:/sbin:/usr/bin:/usr/sbin:/usr/local/bin:/usr/local/sbin
export PATH

#Database ip
DBHOST=''
#Database username DBUSER=''
#Database password DBPASSWD=''
#Databases that need to be backed up, multiple databases are separated by spaces DBNAME=''

#Backup time backtime=`date +%Y-%m-%d_%H%M%S`
#Backup path (current directory)
BACKPATH=$(dirname $(readlink -f $0))
echo $BACKPATH
#Log backup path LOGPATH="${BACKPATH}/log"
#Data backup path DBPATH="${BACKPATH}/db"

#Create a backup directory [ ! -d "${LOGPATH}" ] && mkdir -p "${LOGPATH}"
[ ! -d "${DBPATH}" ] && mkdir -p "${DBPATH}"

#Log record header echo "Backup time is ${backtime}, backup database table ${DBNAME} starts" >> ${LOGPATH}/mysqlback.log

#Formal backup database for table in $DBNAME; do
source=`mysqldump -u ${DBUSER} -h${DBHOST} -p${DBPASSWD} ${table}> ${LOGPATH}/${backtime}.sql` 2>> ${LOGPATH}/mysqlback.log;

#Backup succeeds the following operations $? Get the result of the previous command, 0 represents success if [ "$?" == 0 ]; then
cd ${LOGPATH}
#To save hard disk space, compress the database tar -czf ${DBPATH}/${table}${backtime}.tar.gz ./${backtime}.sql > /dev/null
#Delete the original file and keep only the compressed file rm -f ${LOGPATH}/${backtime}.sql
#Delete the backup seven days ago, that is, only save the backup within 7 days find $DBPATH -name "*.tar.gz" -type f -mtime +7 -exec rm -rf {} \; > /dev/null 2>&1
echo "Database table ${DBNAME} is backed up successfully!!" >> ${LOGPATH}/mysqlback.log
else
#If the backup fails, perform the following operations echo "Database table ${DBNAME} backup failed!!" >> ${LOGPATH}/mysqlback.log
fi
done

Use crontab to execute the BackUpMysql.sh script regularly, and configure it to execute at 12:00 every night

Run crontab -e

enter

59 23 * * * /data/mysqlbak/BackUpMysql.sh

Author: Low-key Little Panda Link: http://ilovey.live/archives/Mysqlbackupshell

The above is the detailed content of the Mysql database scheduled backup script. For more information about the Mysql scheduled backup script, please pay attention to other related articles on 123WORDPRESS.COM!

You may also be interested in:
  • Shell script to backup MySQL database data regularly and retain it for a specified time
  • MySQL scheduled database backup operation example
  • Linux implements scheduled backup of MySQL database and deletes backup files older than 30 days
  • How to implement scheduled backup of MySQL database
  • A simple method to implement scheduled backup of MySQL database in Linux
  • The best way to automatically backup the mysql database (windows server)
  • Several ways to schedule backup of MySQL database (comprehensive)

<<:  Vue implements tree table

>>:  Analysis of two implementation methods for adding static routing in Linux

Recommend

Sample code for displaying a scroll bar after the HTML page is zoomed out

Here is a record of how to make a scroll bar appe...

Analyze the difference between computed and watch in Vue

Table of contents 1. Introduction to computed 1.1...

Learn MySQL database in one hour (Zhang Guo)

Table of contents 1. Database Overview 1.1 Develo...

Detailed installation and configuration tutorial of MySQL 5.7 under Win10

1. Unzip MySQL 5.7 2. Create a new configuration ...

What are the differences between sql and mysql

What is SQL? SQL is a language used to operate da...

Website User Experience Design (UE)

I just saw a post titled "Flow Theory and Des...

Linux uses iptables to limit multiple IPs from accessing your server

Preface In the Linux kernel, netfilter is a subsy...

Alpine Docker image font problem solving operations

1. Run fonts, open the font folder, and find the ...

Detailed process of installing logstash in Docker

Edit docker-compose.yml and add the following con...

Vue uses vue-quill-editor rich text editor and uploads pictures to the server

Table of contents 1. Preparation 2. Define the gl...

Implementation of breakpoint resume in vue-video-player

In a recent project, I needed to implement the fu...