Laravel 대기열을 항상 실행하는 방법

王林
풀어 주다: 2023-05-21 09:45:07
원래의
1113명이 탐색했습니다.

Laravel을 사용한 개발에서는 대기열이 필수적인 부분인 경우가 많습니다. 이는 애플리케이션의 동시 처리 기능을 크게 향상시켜 많은 수의 작업을 효과적으로 관리하고 처리할 수 있도록 해줍니다. 그러나 실제 개발에서는 큐가 불안정하거나, 작업이 많아지면 큐가 갑자기 멈추거나, 작업에서 예외가 발생하면 큐가 자동으로 다시 시작되지 않는 등의 문제에 자주 직면합니다. 이때 큐를 안정적으로 실행하려면 몇 가지 기술이 필요합니다. 이러한 문제를 해결하는 데 도움이 되는 몇 가지 방법은 다음과 같습니다.

1. Supervisor 데몬

Supervisor는 Python으로 작성된 프로세스 제어 시스템으로, If로 인해 프로세스가 차단된 경우 백그라운드에서 프로세스를 지속적으로 모니터링하는 데 도움이 됩니다. 어떤 이유로 종료되면 호스트 프로세스로 다시 시작할 수 있습니다. 이렇게 하면 대기열이 항상 실행될 수 있습니다.

감독자 설치

Centos 시스템 실행

yum install -y 감독자

Ubuntu 시스템 실행

apt-get install -y 감독자

구성 파일 열기

vim /etc/supervisord.conf

라라벨에 참여하세요 -queue 구성 섹션

[program:laravel-queue]
command=php /path/to/artisan queue:work redis --sleep=3 --tries=3
directory=/path/to/your/project
autostart =true
autorestart=true
user=www-data

지침:

  • 프로그램: 프로세스 이름 정의
  • 명령: 실행 명령 정의
  • autostart: 부팅 후 자동으로 시작
  • autorestart: 자동으로 다시 시작
  • user: run 프로세스의 사용자

수정 사항을 저장하고 구성 로드

supervisorctl reload

큐 시작

supervisorctl start laravel-queue

이런 방식으로 큐에 대한 데몬 프로세스를 구현할 수 있습니다. . 대기열이 중지되면 대기열이 항상 실행되도록 프로세스가 자동으로 다시 시작됩니다. 물론 구성 파일의 구성을 통해 여러 작업 프로세스를 실행하여 대기열 처리 기능을 향상시킬 수도 있습니다.

2. Hashicorp의 Nomad를 사용하여 Marathon

Hashicorp의 Nomad는 Marathon과 유사하게 작동합니다. 둘 다 분산 작업 조정을 위한 오픈 소스 도구입니다. Nomad는 위치와 결정을 추상화하여 다양한 유형의 작업 집합을 조율할 수 있습니다. Marathon에 비해 Nomad는 가볍고, 높은 사용자 경험과 쉬운 구성이라는 장점을 가지고 있습니다.

Nomad를 사용하려면 docker 환경이 필요합니다. docker를 설치하지 않은 경우 먼저 apt-get을 통해 설치할 수 있습니다.

apt-get install -y docker.io

  1. Create Nomad Job

에서 작업 만들기 nomad 파일, 구성을 통해 Nomad 작업을 생성합니다:

job "laravel_app" {
datacenters = ["dc1"]
type = "service"

group "app" {

task "laravel-queue" {
  driver = "docker"

  config {
    image = "your_docker_image"
    command = ["php", "artisan", "queue:work", "--tries", "1", "--timeout", "30"]
    args = [
      "--queue=critical,high,default,email,chat,sms",
      "--sleep=3"
    ]
    ports = ["http"]
  }

  resources {
    cpu    = 500
    memory = 128
    network {
      mbits = 10
      port "http" {}
    }
  }

  service {
    name = "laravel-queue"
    port = "http"
    check {
      type     = "http"
      path     = "/status"
      interval = "10s"
      timeout  = "2s"
    }
  }

  restart {
    attempts = 10
    interval = "5m"
    delay    = "25s"
    mode     = "failures"
  }
}
로그인 후 복사

}
}

위 구성 파일은 Docker가 독립형 모드로 실행되는 데 사용되며 프로덕션 환경의 실제 조건에 따라 수정됩니다.

  1. Start Nomad Job

Nomad Job을 시작하려면 다음 명령을 실행하세요.

nomad run job.nomad

이렇게 하면 대기열 시작이 완료됩니다. Nomad는 노드에서 작업을 실행하는 동시에 작업을 모니터링할 수 있습니다. 작업에 문제가 있는 경우 Nomad는 작업을 신속하게 다시 시작하고 상태를 업데이트할 수 있습니다. Nomad Job은 클러스터의 여러 노드 간에 자동으로 마이그레이션할 수 있으므로 특정 노드의 부하를 줄이고 전체 애플리케이션의 견고성을 향상시킬 수 있습니다.

3. AWS SQS 사용

AWS의 SQS(Simple Queue Service)는 분산 애플리케이션 간에 메시지를 효율적으로 전달 및 처리할 수 있으며, 애플리케이션 간 통신 기능을 통해 수평적 확장을 가능하게 합니다. Laravel 프레임워크에서 SQS는 우리 애플리케이션에 쉽게 통합될 수 있습니다. SQS를 지원하는 Laravel Queue 패키지만 설치하면 됩니다. 동시에 AWS SQS에서는 각 대기열에 최소 수명 주기(TTL)가 있습니다. 이 기간 내에 성공적으로 실행되지 않으면 SQS에 의해 작업이 삭제됩니다. 이렇게 하면 작업이 결국 성공적으로 실행될 수 있습니다.

SQS 설치

SQS를 Laravel에 통합하는 것은 비교적 간단합니다. SQS를 지원하는 Laravel Queue 패키지만 설치하면 됩니다. Composer를 통해 직접 설치할 수 있습니다.

composer에는 "aws/aws-sdk-php ^3.0"이 필요합니다.

SQS 구성

.env 구성 파일에 다음 콘텐츠를 추가합니다.

QUEUE_DRIVER=sqs
AWS_ACCESS_KEY_ID=your_aws_access_key
AWS_ 보안 ET_ACCESS_KEY=your_aws_secret_key
AWS_DEFAULT_REGION=us-west-2
SQS_PREFIX=your_queue_prefix

your_aws_access_key, your_aws_secret_key 및 your_queue_prefix를 자신의 것으로 바꾸세요.

큐 시작

php artisan queue:work sqs --queue=default --tries=3 --sleep=3 --timeout=60

위 명령은 SQS 큐를 시작하고 기본 기본 큐를 사용합니다. 여기서 --tries 매개변수는 대기열 작업에 대한 오류 시도 횟수를 나타내고, --sleep은 작업 처리 후 대기열이 정지하는 시간을 나타내며, --timeout은 대기열 작업 시간이 초과될 때 자동 재시도 시간을 나타냅니다. 대기열은 작업을 획득하고 실행하기 위해 지속적으로 반복됩니다.

오류가 발생하면 대기열 작업의 오류 시도 횟수가 소진되거나 실행이 성공할 때까지 대기열이 자동으로 재시도합니다.

요약

이 기사에서는 데몬 프로세스, 작업 조정, 타사 서비스 등을 통해 Laravel 대기열을 계속 실행하는 여러 가지 방법을 소개하며 대기열에 대한 보다 안정적이고 효율적인 작업 지원을 제공할 수 있습니다. 각 방법에는 고유한 장점과 적용 범위가 있으며, 어떤 방법을 선택할지는 실제 상황에 따라 다릅니다.

위 내용은 Laravel 대기열을 항상 실행하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿