• 专注于网站建设,网络推广,关键词优化,SEO优化,专业的网站建设开发团队!
首页 > IT技术 > PHP > 内容

linux通过crond任务定时备份mysql数据库

2015-06-14 22:30:53   来源:叶景网络
    今天在Linux下做了数据库的自动定时备份,在Linux下的定时执行主要是使用crontab文件中加入定制计划来执行,关键是要记住/var/spool/cron这个目录,下面看一下具体的用法:
    首先查看一下/etc/crontab文件:
    $ cat /etc/crontab
    SHELL=/bin/bash
    PATH=/sbin:/bin:/usr/sbin:/usr/bin
    MAILTO=root
    HOME=/
    # run-parts
    #每晚上两点钟进行备份
    01 2 * * * root /home/backup/dbbackup    
    前四行是有关设置cron任务运行的环境变量。
    SHELL变量的值指定系统使用的SHELL环境(该样例为bash shell),
    PATH变量定义了执行命令的路径。
    Cron的输出以电子邮件的形式发给MAILTO变量定义的用户名。如果MAILTO变量定义为空字符串(MAILTO=""),电子邮件不会被发送。执行命令或脚本时HOME变量可用来设置基目录。
    文件/etc/crontab中每行任务的描述格式如下: 
    minute hour day month dayofweek command
    01 2 * * * root /home/backup/dbbackup 
    minute - 从0到59的整数 
    hour - 从0到23的整数 
    day - 从1到31的整数 (必须是指定月份的有效日期)
    month - 从1到12的整数 (或如Jan或Feb简写的月份)
    dayofweek - 从0到7的整数,0或7用来描述周日 (或用Sun或Mon简写来表示)
    command - 需要执行的命令(可用as ls /proc >> /tmp/proc或 执行自定义脚本的命令) 
    root表示以root用户身份来运行
    run-parts表示后面跟着的是一个文件夹,要执行的是该文件夹下的所有脚本
    对于以上各语句,星号(*)表示所有可用的值。例如*在指代month时表示每月执行(需要符合其他限制条件)该命令。 
    整数间的连字号(-)表示整数列,例如1-4意思是整数1,2,3,4
    指定数值由逗号分开。如:3,4,6,8表示这四个指定整数。
    符号“/”指定步进设置。“/<interger>”表示步进值。如0-59/2定义每两分钟执行一次。步进值也可用星号表示。如*/3用来运行每三个月份运行指定任务。
    以“#”开头的为注释行,不会被执行。
    如果一个cron任务需要定期而不是按小时,天,周,月来执行,则需要添加/etc/cron.d目录。这个目录下的所有文件和文件/etc/crontab语法相同,查看样例:
    # record the memory usage of the system every monday 
    # at 3:30AM in the file /tmp/meminfo 
    30 3 * * mon cat /proc/meminfo >> /tmp/meminfo 
    # run custom scrīpt the first day of every month at 4:10AM 
    10 4 1 * * /root/scrīpts/backup.sh
    除了root用户之外的用户可以执行crontab配置计划任务。所有用户定义的crontab存储在目录/var/spool/cron下,任务会以创建者的身份被执行。要以特定用户创建一个crontab,先以该用户登录,执行命令crontab -e,系统会启动在VISUAL或者EDITOR中指定的的编辑软件编辑crontab。文件内容与/etc/crontab格式相同。示例如下:
    01 2 * * * root /home/backup/dbbackup 
    表示每天2点执行/home/backup/dbbackup如果是每五分钟执行一次可改为:
    */5 * * * * /home/backup/dbbackup 
    当更改的crontab需要保存时,文件会保存在成如下文件/var/spool/cron/username。文件名会根据用户名而不同。
    cron服务会每分钟检查一次/etc/crontab、/etc/cron.d/、/var/spool/cron文件下的变更。如果发现变化,就会下载到存储器中。因此,即使crontab文件改变了,程序也不需要重新启动。推荐自定义的任务使用crontab -e命令添加,退出后用/etc/init.d/crond restart命令重启crond进程,/etc/crontab文件中的run-parts是指后面跟着的是文件夹
    实例:
    lnmp中自动备份数据库:
    1.打开vi /etc/crontab加入
    01 2 * * * root /home/backup/dbbackup     #每晚上两点钟进行备份
    01 2 * * 2,4,6 root /home/backup/dbbackup     #每周二四六晚上两点钟进行备份
    2.创建:/home/backup
    mkdir /home/backup
    3.新建dbbackup文件,并在dbbackup文件中写入:
    vi /home/backup/dbbackup
    randtime=`date +%Y-%m-%d-%H:%M:%S`
    mysqldump -uroot -ppassword dbname> /home/backup/dbname-$randtime.sql
    4.把dbbackup?文件改为可执行文件
    chmod +x /home/backup/dbbackup
    5.重启任务管理:
    /etc/rc.d/init.d/crond restart
叶景网络,网络推广,网站建设
特别推荐RECOMMEND
搜索引擎网站关键词seo优化的意义
视频推广怎么做
网站seo优化怎么做关键词排上首页?
SEO介绍什么叫搜索引擎网站关键词优化
seo优化怎样做提升关键词排名
热点图文Hot
PHP通过soap调用.net接口asmx文件 PHP通过soap调用.ne
PHP开发环境配置 PHP开发环境配置
wamp集成环境的虚拟域名配置方法 wamp集成环境的虚拟
wamp独立安装配置 wamp独立安装配置
关注排行RANKING
1

PHP通过soap调用.net接口asmx文件

PHP通过soap调用.net接口asmx文件 叶景网络(www cngxit com),致力于互联网品牌建设与网络营销,专业领域包括网...

2

PHP开发环境配置

PHP开发环境配置 下载PHP安装程序,并解压缩。(下载页面为http: www php net downloads php,下...

3

wamp集成环境的虚拟域名配置方法

wamp集成环境的虚拟域名配置方法 最近,发现身边很多人用wamp集成环境,这个虽然比较快捷,一步到位,但是只能访...

4

wamp独立安装配置

wamp独立安装配置 apache 中的 httpd conf LoadModule php5_module "D: lamp php5 php5apache2_2 dll " 加载模块并开启

5

php 获取今天明天昨天时间戳

php 获取今天明天昨天时间戳 叶景网络(www cngxit com),致力于互联网品牌建设与网络营销,专业领域包括网...

6

PHP获取服务器信息 MySql版本和浏览器信息

PHP获取服务器信息 MySql版本和浏览器信息 1、$_SESSION[ PHP_SELF ] -- 获取当前正在执行脚本的文件名 2...

7

smarty 截取字符串函数 truncate的用法

smarty 截取字符串函数 truncate的用法 smarty truncate 截取字符串,从字符串开始处截取某长度的字符,默认的长度为8...

8

php编程常用函数方法等

php编程常用函数方法等 叶景网络(www cngxit com),致力于互联网品牌建设与网络营销,专业领域包括网站...

9

如何让ThinkPHP的模板引擎达到最佳效率

如何让ThinkPHP的模板引擎达到最佳效率 默认情况下ThinkPHP框架系统默认使用的模板引擎是内置模板引擎。内置模板引擎支持模板文...