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) 需要 ...
随机推荐
- SIM900A设备在保加利亚无法正常使用GPRS问题
1. SIM900A设备在保加利亚GPRS功能无法正常使用 我们一款手持设备采用SIM900A模块,在发货之前测试正常,但到了保加利亚,客户发现无法正常上网,我们技术支持反馈的邮件反馈的现象 ...
- java开源项目之IQQ学习记录之单例模式与log4j日志记录
作者:sushengmiyan 本文地址:http://blog.csdn.net/sushengmiyan/article/details/18992741 打开IQQ项目,打开包iqq.app中的 ...
- Dynamics CRM2013 更新用户数据主要电子邮件字段报数据加密错误
今天在更新用户数据中的主要邮件字段时报数据 可以进系统设置-数据管理-数据加密中开启,但前提是必须启用https访问而不能用http,在第二个框内输入秘钥点击激活就行了,我这边已经激活过了所以显示的是 ...
- 设计模式之——工厂模式(C)
本文是在学习中的总结,欢迎转载但请注明出处:http://blog.csdn.net/pistolove/article/details/41219129 主要介绍抽象工厂模式,以及工厂方法和抽象工厂 ...
- shell快捷键
方向 <-前 后-> 删除 ctrl + d 删除光标所在位置上的字符相当于VIM里x或者dl ctrl + h 删除光标 ...
- Eclipse/Myeclipse生成serialVersionUID方法
serialVersionUID作用: 序列化时为了保持版本的兼容性,即在版本升级时反序列化仍保持对象的唯一性. 如果你修改代码重新部署后出现序列化错误,可以考虑给相应的类增加serialVersio ...
- Android官方技术文档翻译——Gradle 插件用户指南(6)
没想到翻译这篇<Gradle 插件用户指南>拖了差不多一个月,还跨年了.不过还好,在2号时终于一口气把剩下的给翻译完了(其实那天剩下的也就不到一章). 今天先发一下第六章,明天再发第七章. ...
- MPLSVPN 命令集
载请标明出处:http://blog.csdn.net/sk719887916,作者:skay 读懂下面配置命令需要有一定的TCP/IP,路由协议基础,现在直接上关键VPN命令. router ...
- OpenCV特征点提取----Fast特征
1.FAST(featuresfrom accelerated segment test)算法 http://blog.csdn.net/yang_xian521/article/details/74 ...
- 【一天一道LeetCode】#17. Letter Combinations of a Phone Number
一天一道LeetCode (一)题目 Given a digit string, return all possible letter combinations that the number cou ...