备份恢复MySQL数据库

备份

mysqldump -u root -p  数据库名  表名 >  位置

mysqldump -u root -p sys_user user > /home/whch/user.bak

 

恢复
 

mysqldump -u root -p sys_user user < /home/whch/user.bak

 

导入sql数据

mysql -u用户名    -p密码    <  要导入的数据库数据(runoob.sql)
# mysql -u root -p 123456 < runoob.sql

crontab -e 执行任务

* * * * * command path  // 前五个字段可以取整数值,指定何时开始工作,第六个域是字符串,即命令字段,其中包括了crontab调度执行的命令。 各个字段之间用spaces和tabs分割。
字段名称 说明 取值范围
分钟 每小时的第几分钟执行 0-59
小时   每日的第几个小时执行 0-23
日期 每月的第几天执行 1-31
月历 每年的第几月执行 1-12
星期 每周的第几天执行 0-6
命令名称 欲执行的命令及参数  

crontab命令中的一些常用特殊符号:

符号  说明
* 表示任何时刻
, 表示分割
表示一个段,如第二段里: 1-5,就表示1到5点
/n 表示每个n的单位执行一次,如第二段里,*/1, 就表示每隔1个小时执行一次命令。也可以写成1-23/1.

 

每天定时执行任务,配置样例如下:

8,12,16 * * * /data/app/scripts/monitor/df.sh
2 * * * /data/app/scripts/hotbackup/hot_database_backup.sh
8,12,16 * * * /data/app/scripts/monitor/check_ind_unusable.sh
8,12,16 * * * /data/app/scripts/monitor/check_maxfilesize.sh
8,12,16 * * * /data/app/scripts/monitor/check_objectsize.sh
21 * * *  每天的21:43 执行
05 * * *    每天的05:15 执行
17 * * * 每天的17:00 执行
17 * * 1 每周一的 17:00 执行

0,10 17 * * 0,2,3 每周日,周二,周三的 17:00和 17:10 执行

0-10 17 1 * * 毎月1日从 17:00到7:10 毎隔1分钟 执行
0 1,15 * 1 毎月1日和 15日和 一日的 0:00 执行
4 1 * *     毎月1日的 4:42分 执行
21 * * 1-6   周一到周六 21:00 执行

0,10,20,30,40,50 * * * * 每隔10分 执行

*/10 * * * *        每隔10分 执行

* 1 * * *         从1:0到1:59 每隔1分钟 执行
1 * * *         1:00 执行
*/1 * * *        毎时0分 每隔1小时 执行
* * * *         毎时0分 每隔1小时 执行
8-20/3 * * *      8:02,11:02,14:02,17:02,20:02 执行
5 1,15 * *       1日 和 15日的 5:30 执行

一种执行contrab -e 下执行,在后面再追加一个命令即可,不推荐。

另一种在脚本中部署任务执行,推荐,在task.sh下输入命令,每天凌晨两点执行备份某数据库文件.日期格式:

# 2018-12-24 11:22:44
echo `date "+%Y-%m-%d %H:%M:%S"`

echo $(date +%Y-%m-%d %H:%M:%S) #与上等同

      #压缩与不压缩 二选一   
       #!/bin/bash
   	 mysqldump -uusername -ppassword DatabaseName > /home/backup/DatabaseName_$(date +%Y%m%d_%H%M%S).sql
	#!/bin/bash
	mysqldump -uusername -ppassword DatabaseName | gzip > /home/backup/DatabaseName_$(date +%Y%m%d_%H%M%S).sql.gz

username和password替换为自己的MySQL账号和密码,中间没有空格,然后部署任务:

chmod 744 task.sh 
crontab -e 
>2 * * * /task.sh

五、crontab的其他一些命令

如果我们需要列出自己创建的任务调度都有哪些命令,可以使用 crontab -l 命令来查看

[root@xiaoluo /]# crontab -l

2 * * * /task.sh

如果我们需要终止自己刚创建的任务调度,则使用 crontab -r 命令即可

[root@xiaoluo /]# crontab -r

此时我们可以发现,crontab里面的任务都已经没有了

六、cron服务的启动

我们可以通过 chkconfig --list | grep cron 命令来查看cron服务的启动情况:

[root@xiaoluo home]# chkconfig --list | grep cron
crond              0:关闭    1:关闭    2:启用    3:启用    4:启用    5:启用    6:关闭

我们可以看到,系统启动级别如果是1-4,cron服务都会开机自动启动的,我们可以通过如下命令来设置该服务的启动项:

复制代码

复制代码

/sbin/service crond start

/sbin/service crond stop

/sbin/service crond restart

/sbin/service crond reload

以上1-4行分别为启动、停止、重启服务和重新加载配置。

要把cron设为在开机的时候自动启动,在 /etc/rc.d/rc.local 脚本中加入 /sbin/service crond start 即可。

复制代码

复制代码

你可能感兴趣的:(数据库)