Linux–CentOS定时运行Python脚本

2023-03-31 09:50:00 浏览数 (2)

最近公司的项目开始进入运营阶段,数据库的记录也开始多了起来。看了postgresql的自动清理好像不太符合需求,暂定对接口请求记录表保留3个月内的记录,既然postgresql不支持那就发挥python的优势,自己写个脚本实现

执行所需

  • Linux下安装crontab
  • 符合自己需求的python脚本

由于自己和公司所使用的是云服务器,均已安装crontab,所以这里略过,有需要的小伙伴可以看看博主极客Geek的博客:http://blog.csdn.net/netdxy/article/details/50562864


操作步骤

这里有两种方法进行定时任务添加,分别是crontab -e和编辑/etc/crontab。两种方法的语法也略有不同,/etc/crontab的语法比crontab -e多了一个用户字段。

  • crontab -e 用户级,不能设置用户字段
  • /etc/crontab 系统级,只能root用户权限使用,需要设置用户字段

crontab -e

这种方式是用户级的,所有用户的可以使用,实际保存在/var/spool/cron/username中。但有的linux系统加在crontab -e会无效,这种方法不会对语法进行校验。具体操作步骤为:

代码语言:javascript复制
crontab -e
  • 添加定时任务,如每周一3点执行python脚本
代码语言:javascript复制
 0 3 * * 1 python /data/www/test.py

wq保存退出,完毕 语法为

代码语言:javascript复制
# 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
# |  |  |  |  |
# *  *  *  *  * command to be executed

/etc/crontab

直接编辑/etc/crontab

代码语言:javascript复制
# 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

直接编辑/etc/crontab 比 crontab -e 多了一个用户名字段,该方法是系统级的,必须root权限使用 步骤:

代码语言:javascript复制
vi  /etc/crontab
  • 在后面添加定时任务,如每周一3点执行python脚本
代码语言:javascript复制
 0 3 * * 1 root python /data/www/test.py

wq保存退出,完毕

在此附上python自动清理3个月前postgresql数据表脚本test.py

代码语言:javascript复制
#!/usr/bin/python

import psycopg2

conn = psycopg2.connect(database="api_request_log",
                        user="postgresql",
                        password="123456",
                        host="127.0.0.1",
                        port="3432")
print("Opened DELETE successfully")

cur = conn.cursor()

cur.execute("DELETE from api_request_log where record_time < (now() - interval '2 month');")
conn.commit()
print("api_request_log DELETE successfully")

conn.close()

补充Crontab语法

该部分转载自http://blog.csdn.net/netdxy/article/details/50562864

这个文本解释的已经比较直观了,其中 星号(*):代表所有可能的值,例如month字段如果是星号,则表示在满足其它字段的制约条件后每月都执行该命令操作。 逗号(,):可以用逗号隔开的值指定一个列表范围,例如,“1,2,5,7,8,9” 中杠(-):可以用整数之间的中杠表示一个整数范围,例如“2-6”表示“2,3,4,5,6” 正斜线(/):可以用正斜线指定时间的间隔频率,例如“0-23/2”表示每两小时执行一次。同时正斜线可以和星号一起使用,例如*/10,如果用在minute字段,表示每十分钟执行一次。

这里举几个例子,基本涵盖了常见的一些情况:

代码语言:javascript复制
5      *       *           *     *     ls         指定每小时的第5分钟执行一次ls命令
30     5       *           *     *     ls         指定每天的 5:30 执行ls命令
30     7       8           *     *     ls         指定每月8号的7:30分执行ls命令
30     5       8           6     *     ls         指定每年的6月8日5:30执行ls命令
30     5       8           6     *     ls         指定每年的6月8日5:30执行ls命令
30     6       *           *     0     ls         指定每星期日的6:30执行ls命令
30     3     10,20         *     *     ls         每月10号及20号的3:30执行ls命令
25     8-11    *           *     *     ls         每天8-11点的第25分钟执行ls命令
*/15   *       *           *     *     ls         每15分钟执行一次ls命令
30     6     */10          *     *     ls         每个月中,每隔10天6:30执行一次ls命令
22     4       *           *     *     root     run-parts     /etc/cron.daily
#每天4:22以root身份执行/etc/cron.daily目录中的所有可执行文件,run-parts参数表示,执行后面目录中的所有可执行文件。

0 人点赞