Rumah > rangka kerja php > Laravel > Bagaimana untuk melaksanakan baris gilir laravel sepanjang masa

Bagaimana untuk melaksanakan baris gilir laravel sepanjang masa

王林
Lepaskan: 2023-05-21 09:45:07
asal
1188 orang telah melayarinya

Baris gilir selalunya merupakan bahagian penting dalam pembangunan menggunakan Laravel. Ia boleh meningkatkan keupayaan pemprosesan serentak aplikasi, membolehkan sejumlah besar tugas diurus dan diproses dengan berkesan. Walau bagaimanapun, dalam pembangunan sebenar, kita sering menghadapi masalah sedemikian: baris gilir tidak stabil, baris gilir tiba-tiba berhenti apabila terdapat banyak tugas, atau baris gilir tidak boleh dimulakan semula secara automatik apabila pengecualian berlaku dalam tugasan. Pada masa ini kita memerlukan beberapa kemahiran untuk membolehkan baris gilir berjalan dengan stabil. Berikut adalah beberapa kaedah untuk membantu anda menyelesaikan masalah ini.

1. Supervisor daemon

Supervisor ialah sistem kawalan proses yang ditulis dalam Python Ia adalah alat biasa untuk mengurus proses pada pelayan Linux . Jika proses keluar atas sebab tertentu, ia boleh dimulakan semula dengan proses hos. Ini memastikan baris gilir anda sentiasa boleh dijalankan.

Pasang penyelia

Pelaksanaan sistem Centos

yum install -y penyelia

pelaksanaan sistem Ubuntu

apt-get install -y supervisor

Buka fail konfigurasi

vim /etc/supervisord.conf

Tambah bahagian konfigurasi laravel-queue kami

[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

Penerangan:

  • program: Tentukan nama proses
  • arahan: Tentukan arahan yang sedang dijalankan
  • autostart: Auto-start at boot
  • autorestart: automatik restart
  • user: pengguna yang menjalankan proses

Simpan pengubahsuaian dan muatkan konfigurasi

supervisorctl reload

Mulakan baris gilir

supervisorctl start laravel-queue

Dengan cara ini anda boleh melaksanakan proses daemon untuk baris gilir. Jika baris gilir berhenti, proses akan dimulakan semula secara automatik untuk memastikan baris gilir sentiasa berjalan. Sudah tentu, anda juga boleh menjalankan berbilang proses kerja melalui konfigurasi dalam fail konfigurasi untuk meningkatkan keupayaan pemprosesan baris gilir.

2. Integrasikan Marathon menggunakan Hashicorp's Nomad

Hashicorp's Nomad beroperasi sama dengan Marathon Kedua-duanya adalah alat sumber terbuka untuk orkestrasi tugasan. Nomad dapat mengatur satu set pelbagai jenis tugasan dengan mengabstraksikan lokasi dan keputusan mereka. Berbanding dengan Marathon, Nomad mempunyai kelebihan ringan, pengalaman pengguna yang tinggi dan konfigurasi yang mudah.

Menggunakan Nomad memerlukan persekitaran docker. Jika anda tidak memasang docker, anda boleh memasangnya melalui apt-get first:

apt-get install -y docker.io

<.>
    Buat Kerja Nomad
Buat fail job.nomad dalam direktori akar projek dan buat Kerja Nomad melalui konfigurasi:

kerja "laravel_app" {

pusat data = ["dc1" ]
type = "service"

kumpulan "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"
  }
}
Salin selepas log masuk

}

}

Fail konfigurasi di atas menggunakan docker dalam mod bersendirian Jalankan dan ubah suai mengikut situasi sebenar dalam persekitaran pengeluaran.

    Mulakan Kerja Nomad
Jalankan arahan berikut untuk memulakan Kerja Nomad:

kerja nomad run.nomad

Itu sahaja. Permulaan barisan. Nomad akan menjalankan tugas kami pada nod dan boleh memantau kerja pada masa yang sama; apabila terdapat masalah dengan tugas, Nomad boleh memulakan semula tugas dengan cepat dan mengemas kini status. Nomad Job boleh berhijrah secara automatik antara nod yang berbeza dalam kelompok, yang boleh mengurangkan beban pada nod tertentu dan meningkatkan keteguhan aplikasi keseluruhan.

3. Menggunakan AWS SQS

SQS (Perkhidmatan Gilir Mudah) AWS ialah perkhidmatan untuk baris gilir mesej, yang boleh menghantar dan memproses mesej dengan cekap antara aplikasi yang diedarkan, dan membenarkan penskalaan pemprosesan mesej secara mendatar keupayaan antara aplikasi. Dalam rangka kerja Laravel, SQS boleh disepadukan dengan mudah ke dalam aplikasi kami. Kami hanya perlu memasang pakej Laravel Queue yang menyokong SQS. Pada masa yang sama, dalam AWS SQS, setiap baris gilir mempunyai kitaran hayat minimum (TTL) Jika ia tidak berjaya dilaksanakan dalam tempoh masa ini, tugasan akan dipadamkan oleh SQS. Ini memastikan bahawa tugas akhirnya akan dilaksanakan dengan jayanya.

Pasang SQS

Mengintegrasikan SQS dalam Laravel agak mudah. ​​Anda hanya perlu memasang pakej Laravel Queue yang menyokong SQS. Ia boleh dipasang terus melalui Komposer:

komposer memerlukan "aws/aws-sdk-php ^3.0"

Konfigurasikan SQS

Tambah kandungan berikut pada konfigurasi .env fail:

QUEUE_DRIVER=sqs

AWS_ACCESS_KEY_ID=your_aws_access_key
AWS_SECRET_ACCESS_KEY=your_aws_secret_key
AWS_DEFAUL=usREQS-West-Great _queue_prefix

Ganti your_aws_access_key, your_aws_secret_key and your_queue_prefix dengan anda sendiri.

Mulakan baris gilir

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

Arahan di atas akan mulakan baris gilir SQS, dan menggunakan baris gilir lalai, di mana parameter --tries menunjukkan bilangan percubaan ralat untuk tugas baris gilir, --sleep menunjukkan masa untuk baris gilir berehat selepas memproses tugas, dan --tamat masa menunjukkan masa cuba semula automatik apabila tugas giliran tamat. Barisan gilir akan terus berkitar untuk mendapatkan tugasan dan melaksanakannya:

Apabila ralat berlaku, baris gilir akan mencuba semula secara automatik sehingga bilangan percubaan ralat tugas baris gilir habis atau pelaksanaan berjaya.

Ringkasan

Dalam artikel ini, kami memperkenalkan beberapa kaedah untuk memastikan baris gilir Laravel dijalankan Melalui proses daemon, orkestrasi tugas, perkhidmatan pihak ketiga, dll., kami boleh menyediakan sokongan operasi yang lebih stabil dan cekap untuk baris gilir. Setiap kaedah mempunyai kelebihan dan skop penggunaannya sendiri. Kaedah yang mana untuk dipilih bergantung pada situasi sebenar anda.

Atas ialah kandungan terperinci Bagaimana untuk melaksanakan baris gilir laravel sepanjang masa. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

sumber:php.cn
Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan