python Apscheduler 기반 정시 작업 구현
5641 단어 pythonApscheduler정시 임무
안내
작업 장면에서 이런 장면을 만났는데 정기적으로 캐시 인터페이스를 실행하여 동기화 장치 설정에 사용해야 한다.먼저 떠오르는 것은 리눅스의crontab입니다. 정기적이거나 일정 시간 간격으로 임무를 수행할 수 있습니다.그러나 이 시간 임무를 하나의 모듈로 파이썬 프로젝트에 집적하거나 지속화 작업을 원한다면, 분명히crontab는 적용되지 않습니다.Python의 APScheduler 모듈은 이런 문제를 잘 해결할 수 있기 때문에 이 글을 전문적으로 씁니다. 간단한 입문부터 APScheduler의 가장 기초적인 사용 장면과 지구화 임무에 대한 문제를 기록하고 마지막으로 다른 프레임워크와 결합하여 심층적으로 정시 임무 모듈을 맞춤형으로 설정합니다.
간단한 소개
먼저 Apscheduler 모듈에 포함된 네 가지 구성 요소에 대해 간단히 설명합니다.
# -*- coding: utf-8 -*-
from apscheduler.schedulers.blocking import BlockingScheduler
import time
def hello():
print(time.strftime("%c"))
if __name__ == "__main__":
scheduler = BlockingScheduler()
scheduler.add_job(hello, 'interval', seconds=5)
scheduler.start()
예제 출력:
Thu Dec 3 16:01:20 2020
Thu Dec 3 16:01:25 2020
Thu Dec 3 16:01:30 2020
Thu Dec 3 16:01:35 2020
Thu Dec 3 16:01:40 2020
..........
이 간단한 예는 위에서 언급한 몇 가지 구성 요소로 운행 논리를 분석합니다.진급 사용
위의 간단한 예시를 통해 대략적인 작업 프로세스와 각 구성 요소가 전체 프로세스에서의 작용을 이해한다. 아래의 예는 Flask 웹 프레임워크와 Apscheduler 타이머를 결합하여 정해진 시간에 작업을 수행하는 것이다.
# -*- coding: utf-8 -*-
from flask import Flask, Blueprint, request
from apscheduler.executors.pool import ThreadPoolExecutor
from apscheduler.schedulers.background import BackgroundScheduler
from apscheduler.jobstores.redis import RedisJobStore
import time
app = Flask(__name__)
executors = {"default": ThreadPoolExecutor(5)}
default_redis_jobstore = RedisJobStore(db=2,
jobs_key="apschedulers.default_jobs",
run_times_key="apschedulers.default_run_times",
host = '127.0.0.1',
port = 6379
)
scheduler = BackgroundScheduler(executors=executors)
scheduler.add_jobstore(default_redis_jobstore)
scheduler.start()
def say_hello():
print(time.strftime("%c"))
@app.route("/get_job", methods=['GET'])
def get_job():
if scheduler.get_job("say_hello_test"):
return "YES"
else:
return "NO"
@app.route("/start_job", methods=["GET"])
def start_job():
if not scheduler.get_job("say_hello_test"):
scheduler.add_job(say_hello, "interval", seconds=5, id="say_hello_test")
return "Start Scuessfully!"
else:
return "Started Failed"
@app.route("/remove_job", methods=["GET"])
def remove_job():
if scheduler.get_job("say_hello_test"):
scheduler.remove_job("say_hello_test")
return "Delete Successfully!"
else:
return "Delete Failed"
if __name__ == "__main__":
app.run(host="127.0.0.1", port=8787, debug=True)
총결산
마지막으로 요약하자면, 우선 스케줄러가 붕괴되어 다시 회복될 때, 작업 메모리에서 작업이 계속 실행될 수 있도록 작업 메모리를 설정해야 한다.그리고 작업 유형, 예를 들어 CPU 집약형 작업, 프로세스 풀 집행기를 설정해야 합니다. 기본적으로는 스레드 풀 집행기입니다.마지막으로 설정 스케줄러를 만들고 스케줄링을 시작합니다. 시작하기 전에 작업을 추가할 수도 있고, 시작한 후에 추가, 삭제, 작업을 가져올 수도 있습니다.(여기서 알아야 할 점은 응용 프로그램이 작업 메모리, 작업 또는 실행기를 직접 조작하지 않고 스케줄러가 적당한 인터페이스를 제공하여 이 인터페이스를 처리한다는 것이다.)
ApScheduler는 좋은 시간 작업 라이브러리로 동적으로 삭제를 추가할 수 있고 서로 다른 트리거 형식도 지원한다. 이것도 장점이다. 반대로 정적 작업이라면 linux의crontab 도구로 시간 작업을 할 수 있다.이 방면의 기록은 계속 갱신될 것이니 무슨 문제가 있으면 제기할 수 있으니 모두 함께 토론합시다.
이상은python Apscheduler의 사용 방법에 대한 상세한 내용입니다. 더 많은python Apscheduler에 대한 자료는 저희 다른 관련 글을 주목해 주십시오!
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
로마 숫자를 정수로 또는 그 반대로 변환그 중 하나는 로마 숫자를 정수로 변환하는 함수를 만드는 것이었고 두 번째는 그 반대를 수행하는 함수를 만드는 것이었습니다. 문자만 포함합니다'I', 'V', 'X', 'L', 'C', 'D', 'M' ; 문자열이 ...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.