11: python中的輕量級定時任務調度庫:schedule

1.1 schedule 基本使用

  一、schedule 介紹html

      1. 提到定時任務調度的時候,相信不少人會想到芹菜celery,要麼就寫個腳本塞到crontab中。python

      2. 不過,一個小的定時腳本,要用celery的話太「重」了。因此,我找到了一個輕量級的定時任務調度的庫:schedule。多線程

      3. 安裝: pip install scheduleapp

  二、schedule最基本使用異步

      官網地址:https://schedule.readthedocs.io/en/stable/ ide

      參考博客:https://www.cnblogs.com/anpengapple/p/8051923.html spa

#! -*- coding:utf8 -*-
import schedule
import time

def job():
    print("I'm working...")

schedule.every(1).seconds.do(job)
schedule.every(10).minutes.do(job)
schedule.every().hour.do(job)
schedule.every().day.at("10:30").do(job)
schedule.every().monday.do(job)
schedule.every().wednesday.at("13:15").do(job)

while True:
    schedule.run_pending()
    time.sleep(1)
schedule最簡單使用

      1. 這是在pypi上面給出的示例,經過這個栗子,咱們也能夠知道,schedule其實就只是個定時器。線程

      2. 在while True死循環中,schedule.run_pending()是保持schedule一直運行,去查詢上面那一堆的任務,在任務中,就能夠設置不一樣的時間去運行,跟crontab是相似的。code

      3. 可是,若是是多個任務運行的話,實際上它們是按照順序從上往下挨個執行的。若是上面的任務比較複雜,會影響到下面任務的運行時間htm

  三、利用python 用多線程/多進程 結合 schedule 實現異步定時任務

#! /usr/bin/env python
# -*- coding: utf-8 -*-
import datetime
import schedule
import threading
import time


def job1():
    print("I'm working for job1")
    time.sleep(2)
    print("job1:", datetime.datetime.now())


def job2():
    print("I'm working for job2")
    time.sleep(2)
    print("job2:", datetime.datetime.now())


def job1_task():
    threading.Thread(target=job1).start()


def job2_task():
    threading.Thread(target=job2).start()


def run():
    schedule.every(1).seconds.do(job1_task)
    schedule.every(1).seconds.do(job2_task)

    while True:
        schedule.run_pending()
        time.sleep(1)
run()
利用python 用多線程/多進程 結合 schedule 實現異步定時任務
#! /usr/bin/env python
# -*- coding: utf-8 -*-
import datetime
import schedule
import threading
import time

from lib.logs import Logger
from backends.syn_ldap_to_db import store_ldap_to_db


def syn_ldap_info():
    threading.Thread(target=store_ldap_to_db).start()


def crond_pre_employee():
    schedule.every().day.at("13:40").do(syn_ldap_info)
    # schedule.every(1).seconds.do(syn_ldap_info)
    # schedule.every(1).seconds.do(job2_task)
    while True:
        schedule.run_pending()
        time.sleep(1)

def run_cround():
    print '########################### run crond tasks ##############################'
    now = time.strftime('%Y-%m-%d %H:%M:%S')
    msg = 'pre_staff中定時任務開始監控,時間【%s】' %now
    Logger().log(msg, True)
    threading.Thread(target=crond_pre_employee).start()

run_cround()
定時任務運用
相關文章
相關標籤/搜索