>백엔드 개발 >PHP 튜토리얼 >Zend 작업 대기열로 스케줄링

Zend 작업 대기열로 스케줄링

尊渡假赌尊渡假赌尊渡假赌
尊渡假赌尊渡假赌尊渡假赌원래의
2025-03-01 10:21:11211검색
작업 스케줄링 에 Zend 작업 대기열을 사용하십시오

코어 포인트 Scheduling with Zend Job Queue

Zend Server의 작업 대기열 모듈을 사용하면 비 응체 및 장기 실행 작업의 비동기 실행을 허용하며 병렬 작업을 지원하고, 작업의 지연 또는 정기적 인 실행을 지원하며, GUI를 통해 관리됩니다. 작업 대기열 API는 Zendjobqueue 클래스를 통해 액세스 할 수 있으며,이를 통해 작업을 작성하고 매개 변수를 전달하며 우선 순위, 지속성 및 스케줄링과 같은 기타 작업 옵션을 설정할 수 있습니다. 확장 예제에 표시된 바와 같이, 작업 대기열은 사용자 경험을 향상시키고 응용 프로그램 효율성을 향상시키는 데 사용될 수 있으며 작업을 병렬로 예약하고 실행하여 사용자 대기 시간을 줄일 수 있습니다.

PHP에서 대기열 및 병렬 처리를 처리하기위한 다른 대안 (예 : Cron, PCNTL_Fork, Gearman, Node.js 및 RabbitMQ)이 있지만 작업 대기열은 간단하고 사용하기 쉬운 솔루션을 제공합니다.
  • 대부분의 웹 응용 프로그램은 동기식 통신 모델을 따릅니다. 그러나 비회적 및 장기 실행 작업 (예 : 보고서 생성)은 비동기 실행에 더 적합합니다. 작업을 나중에 오프로드하거나 다른 서버에서 실행하는 한 가지 방법은 Zend Server 5에 제공된 작업 대기열 모듈 (커뮤니티 에디션에 포함되지 않음)을 사용하는 것입니다. 작업 대기열은 시간, 우선 순위 및 종속성에 따라 작업 일정을 허용합니다. 작업을 정기적으로 지연 시키거나 실행할 수 있으며 가장 중요한 것은 동시에 실행할 수 있습니다! 가장 중요한 것은 Zend Server 자체가 상태, 실행 시간 및 출력을 포함하여 작업 실행을 추적하는 관리 GUI를 제공합니다. 작업 대기열 모듈의 주요 장점은 작업을 병렬로 실행하는 기능에 있습니다. Cron 작업과 달리 작업 대기열은 다음을 허용합니다
  • 작업이 완료되기를 기다리지 않고 (비동기 적으로) 작업을 실행합니다. 작업을 한 번만 실행하지만 즉시 (지연된 작업)
  • 는 정기적으로 작업을 실행합니다 (CRON의 반복 작업과 유사하지만 PHP API를 통해 완전히 제어 할 수 있습니다. API를 통한 작업 상태 쿼리, 프로세스 실패 및 필수 및 GUI를 통해 과거, 현재 및 보류중인 작업을 추적합니다.
  • 비동기 작업에 어떤 작업 대기열을 사용할 수 있는지에 대한 몇 가지 예에는 다음이 포함됩니다.
  • 다음 요청에 대한 데이터 준비 (사전 계산) Precache Data 주기적 보고서를 생성 이메일 보내기 임시 데이터 또는 파일을 청소하십시오 외부 시스템과 통신 백엔드 데이터 동기화 모바일 장치

작업 대기열을 사용하는 방법

작업 대기열의 API는 Zendjobqueue 클래스를 통해 사용할 수 있습니다. 대부분의 작업을 수행하려면 Zendjobqueue 객체를 인스턴스화하고 CreateHttpjob () 메소드를 사용하여 작업을 작성하여 작업 큐 서버에 연결합니다.
  • 전체 URL 대신 Createhttpjob ()로 경로를 전달하면 hostname $ _server [ "http_host"]의 값을 가진 작업이 생성됩니다. CRON 스크립트에서 작업을 예약 할 때와 같이 $ _server [ "http_host"]는 사용할 수 없습니다.
<?php
$queue = new ZendJobQueue();
$queue->createHttpJob("http://example.com/jobs/somejob.php");
작업 매개 변수는 쿼리 문자열의 일부 또는 배열로서 CreateHttpJob ()의 두 번째 매개 변수로 전달 될 수 있습니다. 인수가 두 번째 인수로 전달되면 배열은 JSON 호환이어야합니다. 작업 코드에서 매개 변수에 액세스하려면 GetCurrentJobparams () 정적 메소드를 사용할 수 있습니다.

다른 작업 옵션은 CreateHttpJob ()의 세 번째 매개 변수를 통해 사용할 수 있습니다. 다음 키를 포함하는 연관 배열입니다.
<?php
// 这两个调用是等效的
$queue->createHttpJob("/jobs/somejob.php");
$queue->createHttpJob("http://" . $_SERVER["HTTP_HOST"] . "/jobs/somejob.php");

이름 - 선택적 직업 이름 우선 순위 - 해당 상수 우선 순위, 우선 순위 우선 순위 우선 순위 우선 순위 _low, priority_mal, priority_high 및 priority_urgent 에 의해 정의됩니다. 영구 - 직무 이력이 항상 보존되는지 여부를 나타내는 부울 가치

전임자 - 정수 전임자 구인 ID

http_headers - 첨부 된 http 헤더

  • 스케줄 - 크론 스타일 일정 명령 Schedule_Time - 작업 시간을 실행해야합니다 (그러나 작업 대기열의 부하에 따라 실제로이 시간 이후에 실행될 수 있습니다) >
  • 예를 들어, 지연된 작업 또는 중복 작업을 생성하는 것은 다음과 같습니다.
  • 실패 (및 성공)는 다음과 같이 처리 할 수 ​​있습니다
  • 확장 된 예
  • 웹 애플리케이션이 사용자의 요청에 따라 일련의 보고서를 생성하고 보내야한다고 가정합니다. 일반적으로 PHP는 멀티 프로세싱을 지원하지 않고 동기식 통신 모델을 사용하므로 사용자는 요청 된 모든 보고서를 하나씩 생성하고 이메일을 보내려면 기다려야합니다. 이 경우 작업 대기열을 사용하면 사용자가 응용 프로그램의 다른 작업을 수행 할 수있을뿐만 아니라 (작업이 비동기 적으로 수행되기 때문에) 응용 프로그램은 여러 보고서를 동시에 처리 할 수 ​​있습니다 (작업이 병렬로 실행될 수 있기 때문에). 대부분의 보고서는 거의 같은 시간에 완료됩니다.
  • ScheduleReport () 함수는 각 예정된 보고서와 관련된 작업 식별자 목록을 반환합니다. 이 기능에서 Zendjobqueue 클래스의 isjobqueuedaemonrunning () 메소드는 해당 서비스가 실행 중인지 여부와 작업을 예약 할 수 있는지 여부를 확인합니다. 보고서의 우선 순위에 따라, 작업은 즉시 또는 2 분 후에 실행할 수 있습니다 (많은 보고서가 동시에 요청되면 서버의 부하를 줄이기 위해). 작업이 예정된 후에는 ID가 성공적으로 생성 된 모든 작업 목록에 저장됩니다. 작업 ID를 이해하는 것은 작업을 모니터링하거나 작업을 취소 할 수있는 것이 매우 중요합니다. ScheduleReport () 함수에 대한 호출은 다음과 같습니다.
  • 앞에서 언급했듯이 예정된 작업도 취소 할 수 있습니다. 그러나 일단 작업이 진행되면 완료됩니다. 따라서 요청 된 우선 순위가 긴급하지 않은 경우 사용자는 예정된 보고서의 전달을 취소하는 데 2 ​​분이 걸립니다.
  • cancelReport () 함수는 실행되지 않은 예정된 보고서 대기열에서 작업을 삭제합니다. 그런 다음 작업 스크립트는 다음과 같습니다
  • runreport () 함수는 최종적으로 제공된 매개 변수를 기반으로 보고서를 준비하고 보냅니다. 완료 후 작업 상태가 성공으로 설정됩니다 (오류가 발생하면 논리 실패).
  • 대안 물론 작업 대기열에 대한 대안이 있습니다. CRON, PCNTL_FORK 및 PHP/Java Bridge를 통한 Java 기반 솔루션도 필요에 따라 살펴볼 가치가 있습니다. Gearman, Node.js 및 RabbitMQ와 같은 더 흥미로운 도구가 있습니다.

    요약

    Zend Server의 작업 대기열이 PHP에서 대기열과 병렬 처리를 처리하는 유일한 방법은 아니지만 "PHP Company"에서 지원하는 매우 간단한 솔루션이며 사용하기가 매우 쉽습니다. Zend의 Phpcloud가 더욱 성공적으로되면서 Job Deue 채택이 더 광범위해야합니다. 이 기사에서 샘플 코드의 전체 내용을 보려면 GitHub에서 찾을 수 있습니다. Varina와 Jay Patel/Shutterstock의 사진 Zend 큐에 대한 FAQS (FAQ)

    Zend 큐의 주요 기능은 무엇입니까?
    Zend Queue는 Zend 프레임 워크의 구성 요소로 다양한 큐잉 시스템에 간단한 API를 제공합니다. 이를 통해 개발자는 데이터를 생성, 관리 및 처리하거나 처리 할 수 ​​있습니다. 즉, 작업이 백그라운드에서 실행될 수있어 웹 응용 프로그램의 성능 및 사용자 경험이 향상됩니다. 배열, sqlite 등과 같은 여러 백엔드를 지원합니다.

    Zend 큐는 웹 애플리케이션의 성능을 어떻게 개선합니까?

    Zend 큐는 작업의 비동기 처리를 허용하여 웹 응용 프로그램의 성능을 향상시킵니다. 이는 기본 실행 스레드를 차단하지 않고 작업을 백그라운드에서 실행할 수 있음을 의미합니다. 사용자는 응용 프로그램과 계속 상호 작용하기 전에 작업이 완료 될 때까지 기다릴 필요가 없으므로 웹 응용 프로그램의 응답 성을 크게 향상시킬 수 있습니다. Zend 큐에서 새 대기열을 만드는 방법은 무엇입니까? Zend 큐에서 새 대기열을 만들려면 CreateQueue 메소드를 사용할 수 있습니다. 이 방법에는 큐 이름과 시간 초과의 두 가지 매개 변수가 필요합니다. 타임 아웃 매개 변수는 선택 사항이며 기본값은 null입니다. 예는 다음과 같습니다.

    Zend 대기열의 대기열에 메시지를 추가하는 방법은 무엇입니까?

    Zend 대기열의 큐에 메시지를 추가하려면 보내기 메소드를 사용할 수 있습니다. 이 메소드에는 매개 변수가 필요합니다 : 큐에 추가 될 메시지가 필요합니다. 예는 다음과 같습니다.

    Zend 대기열의 대기열에서 메시지를 처리하는 방법은 무엇입니까?

    Zend 큐의 대기열에서 메시지를 처리하려면 수신 방법을 사용할 수 있습니다. 이 메소드는 처리를 위해 큐에서 일련의 메시지를 검색합니다. 예는 다음과 같습니다.

    Zend 대기열에서 대기열을 삭제하는 방법은 무엇입니까?

    Zend 큐에서 큐를 삭제하려면 Deletequeue 메소드를 사용할 수 있습니다. 이 메소드에는 매개 변수가 필요합니다. 큐의 이름을 삭제해야합니다. 예는 다음과 같습니다.

    Zend 대기열에 대기열이 존재하는지 확인하는 방법은 무엇입니까?

    Zend 대기열에 큐가 존재하는지 확인하려면 ISExists 메소드를 사용할 수 있습니다. 이 메소드에는 하나의 매개 변수가 필요합니다. 큐의 이름을 확인해야합니다. 예는 다음과 같습니다.

    Zend 큐의 대기열에서 메시지 수를 계산하는 방법은 무엇입니까?

    Zend 대기열의 큐의 메시지 수를 계산하려면 카운트 메소드를 사용할 수 있습니다. 이 메소드는 큐의 메시지 수를 반환합니다. 예는 다음과 같습니다.

    <?php
    $queue = new ZendJobQueue();
    $queue->createHttpJob("http://example.com/jobs/somejob.php");
    Zend 대기열의 대기열에서 모든 메시지를 지우는 방법은 무엇입니까?

    Zend 큐의 대기열의 모든 메시지를 지우려면 Purge 메소드를 사용할 수 있습니다. 이 메소드는 큐의 모든 메시지를 삭제합니다. 예는 다음과 같습니다.

    Zend 대기열에서 대기열의 시간 초과 시간을 설정하는 방법은 무엇입니까?

    위의 코드 예제는 기사에 언급 된 Zend 작업 대기열이 아니라 Zend_queue를 기반으로합니다. Zend 작업 대기열의 API는 약간 다를 수 있으므로 Zend Server의 공식 문서를 참조해야합니다.
    <?php
    // 这两个调用是等效的
    $queue->createHttpJob("/jobs/somejob.php");
    $queue->createHttpJob("http://" . $_SERVER["HTTP_HOST"] . "/jobs/somejob.php");

    위 내용은 Zend 작업 대기열로 스케줄링의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

    성명:
    본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.