MySQL定时备份之使用Linux下的crontab定时备份实例
1. mysql备份某个数据库的命令
##################################################################
# 备份某个数据库
##################################################################
# root 用户,创建备份目录
mkdir -p /usr/local/cncounter/mysql_dump
cd /usr/local/cncounter/mysql_dump
# 导出数据库,热备
mysqldump -u root -pmypasssecret cncounter > cncounter_dump.sql.20140414_1333
2. mysql还原某个数据库的命令
##################################################################
# 还原某个数据库
##################################################################
# 修改密码
# mysqladmin -u root password "mypasssecret"
# mysqladmin -u root password oldpass "mypasssecret"
# 登录
mysql -u root -pmypasssecret
-- 热备只是备份数据库内部的表,以及数据
use cncounter;
source /usr/local/cncounter/mysql_dump/cncounter_dump.sql.20140414_1333;
exit;
3. 使用crontab 定时备份mysql
3.1 备份脚本
##################################################################
# crontab 定时备份
##################################################################
#
# root 用户,创建执行脚本
mkdir -p /root/mysql_dump/data
cd /root/mysql_dump
touch mysql_back.sh
chmod 755 mysql_back.sh
# 编辑备份脚本
vim mysql_back.sh
################下面是备份脚本的内容
#!/bin/sh
# file: /root/mysql_dump/mysql_back.sh
# database info
db_name="cncounter"
db_user="root"
db_pass="mypasssecret"
# others vars
# whereis mysqldump
# is ` but not '
bin_dir="/usr/bin"
bck_dir="/root/mysql_dump/data"
date=`date +%y%m%d_%h%m%s`
# todo
mkdir -p $bck_dir
$bin_dir/mysqldump --opt -u$db_user -p$db_pass $db_name \
> $bck_dir/$db_name.dump_$date.sql
当然,执行的脚本也可以不用那么灵活: 其中行末尾的 反斜线(\) 的意思是shell 指令换行,如果写在单行内部,就不再需要.
/usr/bin/mysqldump --opt -uroot -pmypasssecret cncounter \
> /root/mysql_dump/data/cncounter.dump_`date +%y%m%d_%h%m%s`.sql
dump出来的sql文件有可能很大,我们也可以开启 gzip 压缩,一般来说可以实现10倍压缩比例:也就是讲输出到文件的内容通过管道操作符让 gzip 程序处理一遍.
/usr/bin/mysqldump --opt -uroot -pmypasssecret cncounter | gzip \
> /root/mysql_dump/data/cncounter.dump_`date +%y%m%d_%h%m%s`.sql.gz
3.2 添加到crontab
# 添加到crontab
crontab -e
# 添加一行,root用户不需要指定执行的用户名,esc,wq
1 1 * * * /root/mysql_dump/mysql_back.sh
# 不一定需要重启crontab服务
# service crond restart
3.3 crontab 简单说明
# cat /etc/crontab
shell=/bin/bash
path=/sbin:/bin:/usr/sbin:/usr/bin
mailto=root
home=/
# for details see man 4 crontabs
# example of job definition:
# .---------------- minute (0 - 59)
# | .------------- hour (0 - 23)
# | | .---------- day of month (1 - 31)
# | | | .------- month (1 - 12) or jan,feb,mar,apr ...
# | | | | .---- day of week (0 - 6) (sunday=0 or 7) or sun,mon,tue,wed,thu,fri,sat
# | | | | |
# * * * * * user-name command to be executed
可以发现,crontab 的执行周期有5个部分组成,其中第一个是分钟数,第二个是小时数,第三个是一个月中的第几天。。。 如果是 * 就表示每天都会调度。
user-name 部分,如果需要以其他用户调度,则可以指定,否则不能指定,比如 root 用户就不能指定 root,否则有调度日志,但是没有实际执行。
上一篇: 详解Java 中程序内存的分析
推荐阅读
-
MySQL定时备份之使用Linux下的crontab定时备份实例
-
Linux下实现MySQL数据备份和恢复的命令使用全攻略
-
Linux下实现MySQL数据备份和恢复的命令使用全攻略
-
关于Linux下MySQL数据库的自动定时备份教程
-
Linux服务器实现每天定时备份MySQL数据库的shell脚本
-
linux实现定时备份mysql数据库的简单方法
-
Linux下Mysql定时任务备份数据的实现方法
-
buffer-系统定时备份时一直不成功,mysql错误日志写的看不懂,各位大神给指点一下吧
-
利用Crontab为Linux定时备份Mysql数据库_MySQL
-
Linux下MySQL定时按日期备份数据