linux定时清理数据库过期记录
cron服务是Linux的内置服务,但它不会开机自动启动。可以用以下命令启动和停止服务:
/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 即可
查看当前用户的crontab,输入 crontab -l;
编辑crontab,输入 crontab -e;
删除crontab,输入 crontab -r
添加任务
crontab -e //执行之后会打开一个文件。在文件中追加如下内容即可。
*/ * * * command
*/ * * * command
查询任务是否加了:
crontab -l -u root #查看root用户
*/ * * * command
*/ * * * command
基本格式 :
* * * * * command
分 时 日 月 周 命令
第1列表示分钟1~59 每分钟用*或者 */1表示
第2列表示小时1~23(0表示0点)
第3列表示日期1~31
第4列表示月份1~12
第5列标识号星期0~6(0表示星期天)
第6列要运行的命令
crontab文件的一些例子(博主会在此处不定时增加例子):
- 每10分钟执行一个shell脚本。
*/10 * * * * /home/tmp/clear.sh
*/10表示每10分钟执行。
但是,有一个问题,就是,如果你想通过定时任务来调用执行***.php,那么,就可以这么写。
*/10 * * * * /usr/local/php/bin/php /home/shells/clearOutOfDate.php
上面这句话是可以定时运行的。我测试过。如果不行,请使用chmod 744 ***.php修改你的文件可执行权限(rwx的x一定要有,如果是root用户的话)。不行的话,可以提升权限至777再试试
我想说的问题是:如果你把
/usr/local/php/bin/php /home/shells/clearOutOfDate.php
这句话放在shell脚本里面,比如这样,

我自己也调了很久,但是这句话就是不会被执行。echo "你好啊"这句话是可以输出。找不到问题在哪里。所以建议大家在crontab定时执行php文件的时候,直接在
crontab -e 里面写
*/1 * * * * /usr/local/php/bin/php /home/shells/clearOutOfDate.php
就好了。另外注意 php /home/shells/clearOutOfDate.php是不能执行的。对于php的可执行文件要写全绝对路径。一般都会在/usr/local/php/bin/php目录下,可以找一找。
(2018-1-11日更)定时每个月处理一下日志文件。可以先看我的bash 命令:
#!/bin/bash cp success.log success/$(date +%Y-%m-%d).log
cp error.log error/$(date +%Y-%m-%d).log
cp login.log login/$(date +%Y-%m-%d).log echo "---------------------------" > success.log
echo "---------------------------" > error.log
echo "---------------------------" > login.log应用会产生日志对吧?但是我们一年下来总把日志追加在一个文件的话,文件越来越大。每次定时读写也是非常耗费内存的。所以,我们需要针对日志文件的积累情况,定一个合理的时间,把日志的内容取出来,按照日期归类。例如图中:
$(date +%Y-%m-%d)
就是按照年月日来把log文件归类。下面设置定时执行,因为我的日志产生的不是很多。每个月最多也就1M多一点。所以,我设置一下,每10天,归档一次log文件。这样可以减小后期追加log的IO消耗。命令如下:
* , * * /data/wwwroot/project1/wx/logs/copy.sh
表示每个月的1号和15号的凌晨3点会执行一次。
- (2018-1-11日更)crontab无法做到秒级执行,最小的粒度是分钟。不过可以变相实现秒级定时任务。
* * * * * "命令"
上面的全星号,可以实现每分钟运行。
* * * * * "命令"
* * * * * sleep 20; "命令"
* * * * * sleep 40; "命令"上面的三行 可以做到每20秒执行。也可以写一个循环脚本,在脚本内进行sleep骚操作。
定时任务不会执行的问题总结:
1 crond服务未启动
crontab不是Linux内核的功能,而是依赖一个crond服务,这个服务可以启动当然也可以停止。如果停止了就无法执行任何定时任务了,解决的方法是打开它:
crond
或
service crond start
如果提示crond命令不存在,可能被误删除了,CentOS下可以通过这个命令重新安装:
yum -y install crontabs
2 权限问题
比如:脚本没有x执行权限,解决方法:
增加执行权限,或者用bash abc.sh的方法执行
3 路径问题
有的命令在shell中执行正常,但是在crontab执行却总是失败。有可能是因为crontab使用的sh未正确识别路径,比如:以root身份登录shell后执行一个/root/test.sh,只要执行
./test.sh
就可以了。但是在crontab中,就会找不到这个脚本,比如写完整:
/root/test.sh
4 时差问题
因为服务器与客户端时差问题,所以crontab的时间以服务器时间为准。
5 变量问题
有时候命令中含有变量,但crontab执行时却没有,也会造成执行失败。
linux定时清理数据库过期记录的更多相关文章
- linux 定时清理session
php session 运营想让用户登陆网站就能永久保持登陆会话,感觉这是扯淡,因为视频播放1小时,所以我设置了两小时过期. 但是用户过多,导致session文件大量存储.产生上百万千万.服务器空间很 ...
- 基于SpringBoot实现定时任务的设置(常用:定时清理数据库)
1.构建SpringBoot工程项目 1)创建一个Springboot工程,在它的程序入口加上@EnableScheduling,开启调度任务. @SpringBootApplication @Ena ...
- 定时删除日志文件---linux定时清理日志
linux是一个很能自动产生文件的系统,日志.邮件.备份等.虽然现在硬盘廉价,我们可以有很多硬盘空间供这些文件浪费,让系统定时清理一些不需要的文件很有一种爽快的事情.不用你去每天惦记着是否需要清理日志 ...
- crontab的相关设置&linux定时备份数据库
对于才了解crontab的人来说,应该按照以下的步骤来设置crontab 1.首先要检查是否装了crontab http://blog.sina.com.cn/s/blog_4881040d01011 ...
- Win和Linux定时备份数据库
项目的数据库需要每天备份,但是手动备份太麻烦而且容易忘,所以通过定时任务执行脚本备份数据库,服务器有Windows和Linux,所以两种都记录一下. 一.Windows 首先写好脚本,这里不多说,因为 ...
- Linux定时清理日志脚本
在应用疯狂打日志的情况下,服务器很容易被塞满磁盘. 先要写一个shell脚本,脚本如下. #!/bin/bash #----------------使用规范---------------- #1.该文 ...
- linux系统清理僵尸进程记录
在UNIX 系统中,一个进程结束了,但是他的父进程没有等待(调用wait / waitpid)他, 那么他将变成一个僵尸进程. 在fork()/execve()过程中,假设子进程结束时父进程仍存在, ...
- Linux定时清理30天前的Tomcat日志脚本
一.在tomcat的log路径下新建.sh脚本文件clean.sh,内容如下:#!/bin/bashlogs_path="/mnt/tomcat/apache-tomcat-8.5.23/l ...
- linux 定时备份数据库
说明 检查Crontab是否安装 若没有 需要先安装Crontab定时工具 安装定时工具参考(https://www.cnblogs.com/shaohuixia/p/5577738.html) 需要 ...
随机推荐
- postman使用—chrome版
如果大家不知道怎么安装,请下载个FQ软件(蓝灯,shadowsocks)都是可以的,安装完成之后,你可以在chrome看到posman的插件程序. 使用说明: 安装完成之后,使用chrome://ap ...
- C#中的泛型化方法的实现
在一个基本数据类型的方法中求解最大值或者最小值是一件很方便,同时也是很简单的事.但是如果你想复用这个方法,我们就需要使用到泛型编程的概念了.这就好比是C++中的模板函数,或者java中的泛型操作.相比 ...
- Chapter 2 User Authentication, Authorization, and Security(9):防止登录名和用户查看元数据
原文出处:http://blog.csdn.net/dba_huangzj/article/details/39003679,专题目录:http://blog.csdn.net/dba_huangzj ...
- oracle ebs应用产品安全性-数据访问权限集
定义 数据访问权限集是一个重要的.必须设定的系统配置文件选项.对具有相同科目表.日历和期间类型的分类帐及其所有平衡段值或管理段值的定义读写权限,系统管理员将其分配至不同的责任以控制不同的责任对分类帐数 ...
- 关于会话、进程、请求的几个常用SQL
1.检查自己的SID SELECT sid FROM v$session WHERE sid = (SELECT sid FROM v$mystat WHERE rownum = 1); 2. 几个I ...
- 解决log4cxx退出时的异常
解决log4cxx退出时的异常(金庆的专栏)如果使用log4cxx的FileWatchdog线程来监视日志配置文件进行动态配置,就可能碰到程序退出时产生的异常.程序退出时清理工作耗时很长时,该异常很容 ...
- UVa - 1616 - Caravan Robbers
二分找到最大长度,最后输出的时候转化成分数,比较有技巧性. AC代码: #include <iostream> #include <cstdio> #include <c ...
- MiseringThread.java 解析页面线程
MiseringThread.java 解析页面线程 http://injavawetrust.iteye.com package com.iteye.injavawetrust.miner; imp ...
- Git版本控制 — 日常使用(二)
本地使用 以下是我的一些日常操作. (1) 创建版本库 # cd /proj # git init Initialized empty Git repository in /proj/.git/ (2 ...
- 手把手带你做一个超炫酷loading成功动画view Android自定义view
写在前面: 本篇可能是手把手自定义view系列最后一篇了,实际上我也是一周前才开始真正接触自定义view,通过这一周的练习,基本上已经熟练自定义view,能够应对一般的view需要,那么就以本篇来结尾 ...