1. 备份某个数据库
################################################################### 备份某个数据库################################################################### root 用户,创建备份目录mkdir -p /usr/local/cncounter/mysql_dumpcd /usr/local/cncounter/mysql_dump# 导出数据库,热备mysqldump -u root -pmypasssecret cncounter > cncounter_dump.sql.20140414_1333
2. 还原某个数据库
################################################################### 还原某个数据库################################################################### 修改密码# 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 定时备份3.1 编辑备份脚本
################################################################### crontab 定时备份################################################################### # root 用户,创建执行脚本mkdir -p /root/mysql_dump/datacd /root/mysql_dumptouch mysql_back.shchmod 755 mysql_back.sh# 编辑备份脚本vim mysql_back.sh################下面是备份脚本的内容#!/bin/sh# file: /root/mysql_dump/mysql_back.sh# database infodb_name=cncounterdb_user=rootdb_pass=mypasssecret# others vars# whereis mysqldump# is ` but not 'bin_dir=/usr/binbck_dir=/root/mysql_dump/datadate=`date +%y%m%d_%h%m%s`# todomkdir -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
3.2 添加到crontab# 添加到crontabcrontab -e# 添加一行,root用户不需要指定执行的用户名,esc,wq1 1 * * * /root/mysql_dump/mysql_back.sh# 不一定需要重启crontab服务# service crond restart
3.3 crontab 简单说明# cat /etc/crontab shell=/bin/bashpath=/sbin:/bin:/usr/sbin:/usr/binmailto=roothome=/# 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,否则有调度日志,但是没有实际执行。