Home >Backend Development >PHP Tutorial >Example of how shell automatically backs up mysql database every day
Recommended related mysql video tutorials: "mysql tutorial"
/usr/bin/mysqldump --opt -ubatsing -pbatsingpw -hlocalhost timepusher > /mnt/mysqlBackup/db_`date +%F`.sql
1. Execute /usr/bin/mysqldump;
2. --opt is the collective name of quick, add-drop-table, add-locks, extended-insert and lock-tables parameters, which are generally used. , search for the specific meaning by yourself;
3. -u database user name -p database user password -h database address database name> exported file path;
4. `date +%F` is the current generated in the shell The date is in the format of 2015-11-05, so the file name generated when exported successfully is db_2015-11-05.sql;
5. Download the generated sql file, open it with a text editor for inspection, and import the test database locally. Check to see if there are any problems;
#!/bin/sh# Database infoDB_USER="batsing"DB_PASS="batsingpw"DB_HOST="localhost"DB_NAME="timepusher"# Others varsBIN_DIR="/usr/bin" #the mysql bin pathBCK_DIR="/mnt/mysqlBackup" #the backup file directoryDATE=`date +%F` # TODO# /usr/bin/mysqldump --opt -ubatsing -pbatsingpw -hlocalhost timepusher > /mnt/mysqlBackup/db_`date +%F`.sql$BIN_DIR/mysqldump --opt -u$DB_USER -p$DB_PASS -h$DB_HOST $DB_NAME > $BCK_DIR/db_$DATE.sql#还原数据库#用mysql-front导入前一天的 *.sql 文件即可恢复数据
2../ sqlAutoBak.sh, if the uploaded file is written in Windows, an error may be reported
/bin/sh^M: bad interpreter: No such file or directoryThis is caused by different system encoding formats: .sh files edited in Windows systems may have invisible characters, so in Linux systems The above exception information will be reported when executed. You can use Notepad++ on Windows to convert to Unix format (select in the menu: Edit>File Format Conversion>Convert to UNIX)
3. After modification, upload and continue executing ./sqlAutoBak.sh, no error is reported. Check the exported sql file again.
2 , modify sqlAutoBak.sh to the following
#!/bin/sh# Database infoDB_USER="batsing"DB_PASS="batsingpw"DB_HOST="localhost"DB_NAME="timepusher"# Others varsBIN_DIR="/usr/bin" #the mysql bin pathBCK_DIR="/mnt/mysqlBackup" #the backup file directoryDATE=`date +%F` # TODO# /usr/bin/mysqldump --opt -ubatsing -pbatsingpw -hlocalhost timepusher > /mnt/mysqlBackup/db_`date +%F`.sql# $BIN_DIR/mysqldump --opt -u$DB_USER -p$DB_PASS -h$DB_HOST $DB_NAME > $BCK_DIR/db_$DATE.sql$BIN_DIR/mysqldump --opt -u$DB_USER -p$DB_PASS -h$DB_HOST $DB_NAME | gzip > $BCK_DIR/db_$DATE.sql.gz# 还原数据库# 把 *.sql.gz 使用gunzip 或 本地的解压软件 解压为 *.sql 文件# 用mysql-front导入前一天的 *.sql 文件即可恢复数据3. After modification, upload and continue execution./sqlAutoBak.sh, no error is reported. If you use a text editor to view the exported *.sql.gz file, it should be a bunch of garbled characters.
4. Download it locally and open it with decompression software. After decompression, you can see the real *.sql file inside.
6. Set up linux scheduled tasks to execute the script; 1. Edit the scheduled task list
crontab -e2. Insert The following line is because usually the website has the lowest traffic at 5 o'clock.
00 05 * * * /bin/sh /usr/local/apache/htdocs/timepusher/sqlBak/sqlAutoBak.sh#每天早上 5:00am 执行3. Check whether the task is created successfully
crontab -l7. Check whether the automatically generated sql file meets the requirements the next dayIf the generated file is decompressed, check whether it is question, then the script for automatic scheduled database backup is completed. Because too many generated files will take up a certain amount of space, it is recommended to clean up the files regularly (for example, once a month). $, Supplement 1. If the user of the database is not assigned the permission to lock tables, the backup will report an error when using LOCK TABLES. That's because the mysqldump command locks the table by default when exporting, so there are two solutions. One is to give the user the permission to open the lock table; the other is to add the --skip-lock-tables parameter to the command. That is:
$BIN_DIR/mysqldump --opt -u$DB_USER -p$DB_PASS -h$DB_HOST $DB_NAME --skip-lock-tables| gzip > $BCK_DIR/db_$DATE.sql.gzRelated recommendations:
3 steps to teach you how to automatically back up mysql database with one click_MySQL
Linux Automatic Backup MySQL database script code_MySQL
Use shell to automatically back up mysql database regularly_MySQL
The above is the detailed content of Example of how shell automatically backs up mysql database every day. For more information, please follow other related articles on the PHP Chinese website!