Mengelola Antrian Kerja Laravel Dengan Beanstalk dan Supervisor di Ubuntu 16.04

Beanstalk adalah antrian kerja yang cepat dan sederhana. Ini memungkinkan Anda untuk menjalankan tugas yang memakan waktu secara tidak sinkron, seperti mengirim email, menghubungkan ke API eksternal atau memproses gambar. Dengan melakukannya, Anda akan mengurangi latensi aplikasi web Anda. Laravel menyediakan dukungan untuk beanstalkd.

Dalam tutorial ini kita akan menginstal beanstalkd, mengatur aplikasi demo Laravel dan mengelola pekerja antrian melalui Supervisor . Aplikasi demo akan mendapatkan daftar OS yang tersedia dari Vultr API dan secara acak memilih satu.

Diasumsikan bahwa Anda sudah memiliki Supervisor yang diinstal pada sistem Anda. Jika tidak, Anda harus membaca tutorial berikut tentang cara mengatur Supervisor: Menginstal dan Mengkonfigurasi Supervisor di Ubuntu 16.04

Juga diasumsikan bahwa Anda memiliki akses SSH ke instance Vultr Anda.

Memasang Beanstalk

Langkah pertama yang harus diambil adalah menginstal beanstalkd.

sudo apt-get update
sudo apt-get install beanstalkd

Mulai layanan.

sudo systemctl start beanstalkd

Anda juga dapat mengaktifkan layanan untuk memulai inisialisasi sistem.

sudo systemctl enable beanstalkd

Periksa status layanan dengan mengeluarkan perintah berikut.

sudo systemctl status beanstalkd

Secara default, beanstalkdmendengarkan pada port 11300. Beanstalk menggunakan protokol berbasis teks sederhana yang dijelaskan dalam repositori github-nya . Anda dapat menguji protokolnya dengan menjalankan telnet.

telnet localhost 11300

Tulis yang berikut dan tekan ENTER.

list-tubes

Anda akan melihat daftar tabung yang tersedia di server:

OK 14
---
- default

Untuk menutup koneksi cukup ketik quitdan kemudian tekan ENTER.

Tabung di Beanstalk mewakili antrian kerja. Beanstalk pada dasarnya disusun oleh produsen , konsumen , pekerjaan dan tabung . Produsen menempatkan pekerjaan ke dalam tabung untuk dikonsumsi (diproses) oleh sejumlah konsumen. Perhatikan bahwa baik produsen maupun konsumen hanyalah klien dari server Beanstalk dan benar-benar independen satu sama lain. Dalam istilah praktis ini berarti bahwa dengan menggunakan Beanstalk Anda dapat menghasilkan pekerjaan dalam aplikasi PHP Anda dan memprosesnya di aplikasi NodeJS misalnya. Untungnya, Laravel mengabstraksikan semua ini dan memberi kami API yang sangat sederhana untuk mengirim dan menangani pekerjaan, seperti yang akan kita lihat selanjutnya.

Proyek sampel

Untuk membangun proyek sampel kami, pertama-tama kita perlu menginstal dependensinya. Kami akan menginstal PHP dan Komposer.

sudo apt-get install php php-mbstring php-xml php-common php-zip composer

Sekarang, buat proyek berdasarkan Laravel 5.5.

composer create-project --prefer-dist laravel/laravel vultr "5.5.*"

Selanjutnya cdke folder yang baru dibuat. Kami akan bekerja di direktori ini mulai sekarang. Folder ini dapat direferensikan nanti sebagai PROJECT_ROOT.

cd vultr/

Untuk menggunakan Beanstalk di Laravel kita perlu menginstal satu lagi ketergantungan, klien PHP Beanstalk.

composer require pda/pheanstalk ~3.0

Kita juga perlu membuat representasi Pekerjaan. Di Laravel, ini adalah kelas di dalam app/Jobsfolder. Laravel memiliki perintah konsol untuk membantu kami membuat kelas Pekerjaan. Mari kita ciptakan sampel Job kami.

php artisan make:job FindFavoriteOS

Perbarui app/Jobs/FindFavoriteOS.phpfile sebagai berikut.

<?php

namespace App\Jobs;

use Illuminate\Bus\Queueable;
use Illuminate\Queue\SerializesModels;
use Illuminate\Queue\InteractsWithQueue;
use Illuminate\Contracts\Queue\ShouldQueue;
use Illuminate\Foundation\Bus\Dispatchable;
use Illuminate\Support\Facades\Log;

class FindFavoriteOS implements ShouldQueue
{
    use Dispatchable, InteractsWithQueue, Queueable, SerializesModels;

    /**
     * Create a new job instance.
     *
     * @return void
     */
    public function __construct()
    {
        //
    }

    /**
     * Execute the job.
     *
     * @return void
     */
    public function handle()
    {
        $rawData = file_get_contents('https://api.vultr.com/v1/os/list');
        $list = json_decode($rawData, true);
        shuffle($list);
        $key = array_rand($list);
        $favorite = $list[$key];
        Log::info('My Favorite OS is: ' . $favorite['name']);
    }
}

Metode pegangan adalah apa yang akan dieksekusi secara efektif ketika pekerjaan dikonsumsi. Di sini, kami mengambil data dari Vultr API, secara acak memilih OS dan menulis OS yang dipilih ke file log. File log terletak di storage/logs/laravel.log.

Kami telah menginstal Beanstalk dan mendefinisikan Pekerjaan yang akan dijalankan olehnya. Sekarang saatnya memberitahu Laravel untuk menggunakan Beanstalk sebagai antrian pekerjaan default. Salin .envfile default yang disediakan oleh instalasi Laravel.

cp .env.example .env

Sekarang buka .envfile dan perbarui baris di mana driver antrian ditentukan.

QUEUE_DRIVER=beanstalkd

Akhirnya, buat kunci aplikasi.

php artisan key:generate

Kami sekarang siap untuk mengirim pekerjaan ke antrean kerja Beanstalk.

Mengirim dan menjalankan pekerjaan

Mengirim pekerjaan di Laravel cukup sederhana. Perbarui routes/web.phpfile.

<?php

Route::get('/', function () {
    for ($i = 0; $i < 50; $i++) {
        \App\Jobs\FindFavoriteOS::dispatch();
    }

    return '50 Jobs dispatched!';
});

Meskipun tidak direkomendasikan untuk menjalankan server yang disediakan built-in dalam produksi, kami akan menggunakannya di sini demi singkatnya.

php artisan serve --host 0.0.0.0 --port 8000

Sekarang di browser web, navigasikan ke http://[vultr-instance-ip]:8000. Anda akan melihat pesan berikut.

50 Jobs dispatched!

Buka koneksi SSH baru ke server Anda dan di dalam root proyek kami, jalankan yang berikut ini.

php artisan queue:work --once

Ini adalah output yang diharapkan:

[2018-02-14 00:03:52] Processing: App\Jobs\FindFavoriteOS
[2018-02-14 00:03:53] Processed:  App\Jobs\FindFavoriteOS

Konfirmasikan bahwa log telah dibuat.

cat storage/logs/laravel.log

Mengkonfigurasi Supervisor

Untuk menghindari perlunya memproses antrian secara manual, kami akan menggunakan supervisord. Buat konfigurasi program berikut di /etc/supervisor/conf.d/vultr.conf.

[program:vultr]
process_name=%(program_name)s_%(process_num)02d
command=php [PROJECT_ROOT]/artisan queue:work
autostart=true
autorestart=true
numprocs=8
redirect_stderr=true
stdout_logfile=/var/log/worker.log

Perhatikan bahwa jalur yang benar untuk meletakkan file konfigurasi Supervisor akan tergantung pada pengaturan Anda. Juga, ingatlah untuk mengganti [PROJECT_ROOT]dengan path lengkap ke PROJECT_ROOTsistem Anda.

Di sini kami mengonfigurasi Supervisor untuk secara otomatis mulai memproses antrian dan, jika terjadi skrip, untuk memulai kembali. Perhatikan juga bahwa kita tidak membuat satu pekerja tunggal, tetapi 8 proses. Anda bebas untuk instantiate namun banyak proses yang Anda anggap perlu tergantung pada aplikasi Anda.

Untuk memungkinkan Supervisor mengelola pekerja kami, paksakan untuk membaca ulang konfigurasinya.

sudo supervisorctl reread
sudo supervisorctl update

Jika layanan Supervisor belum dimulai, Anda harus memulainya.

sudo systemctl start supervisord

Sekarang mari kita lihat apakah pekerjaan sedang diproses.

tail -f storage/logs/laravel.log

Di browser web, navigasikan ke http://[vultr-instance-ip]:8000. Anda akan melihat log yang dihasilkan di konsol Anda.

Kesimpulan

Kami telah berhasil mengonfigurasi aplikasi Laravel untuk menggunakan Beanstalk sebagai antrian kerja. Kami juga mendemonstrasikan cara menggunakan Supervisor untuk mengelola pekerja.



Leave a Comment

Cara Memasang Panel Kontrol Hosting Mudah di Ubuntu 16.04

Cara Memasang Panel Kontrol Hosting Mudah di Ubuntu 16.04

Pelajari langkah-langkah untuk memasang Panel Kontrol Hosting Mudah (EHCP) di Ubuntu 16.04 dengan panduan ini.

Cara Memasang Graylog Server pada CentOS 7

Cara Memasang Graylog Server pada CentOS 7

Menggunakan Sistem yang Berbeda? Graylog server adalah perangkat lunak manajemen log sumber terbuka siap pakai perusahaan. Ia mengumpulkan log dari berbagai sumber dan menganalisis

Cara Memasang Anchor CMS pada Fedora 26 LAMP VPS

Cara Memasang Anchor CMS pada Fedora 26 LAMP VPS

Menggunakan Sistem yang Berbeda? Anchor CMS adalah Content Engine System (CMS) Blog Engine yang super-sederhana dan sangat ringan, gratis, dan terbuka

Siapkan Berbagi NFS di Debian

Siapkan Berbagi NFS di Debian

NFS adalah sistem file berbasis jaringan yang memungkinkan komputer untuk mengakses file di seluruh jaringan komputer. Panduan ini menjelaskan bagaimana Anda dapat mengekspos folder melalui NF

Cara Memasang GitBucket di Ubuntu 16.04

Cara Memasang GitBucket di Ubuntu 16.04

Panduan ini mencakup instalasi dasar dan pengaturan GitBucket untuk instance Vultr yang menjalankan Ubuntu 16.04, dan mengasumsikan bahwa Anda menjalankan perintah sebagai

Cara Memasang Directus 6.4 CMS pada Fedora 26 LAMP VPS

Cara Memasang Directus 6.4 CMS pada Fedora 26 LAMP VPS

Menggunakan Sistem yang Berbeda? Directus 6.4 CMS adalah Headless Content Management System (CMS) yang kuat dan fleksibel, gratis dan open source yang menyediakan pengembang

Cara Memasang Mattermost 5.2 di Ubuntu 16.04

Cara Memasang Mattermost 5.2 di Ubuntu 16.04

Menggunakan Sistem yang Berbeda? Mattermost adalah sumber terbuka, alternatif yang di-host-sendiri ke layanan pesan Slack SAAS. Dengan kata lain, dengan Mattermost, Anda ca

Menyiapkan Server TeamTalk di Linux

Menyiapkan Server TeamTalk di Linux

TeamTalk adalah sistem konferensi yang memungkinkan pengguna untuk memiliki percakapan audio / video berkualitas tinggi, obrolan teks, transfer file, dan berbagi layar. Itu saya

Menggunakan kunci SSH Anda untuk masuk ke pengguna non-root

Menggunakan kunci SSH Anda untuk masuk ke pengguna non-root

Vultr menyediakan fitur yang memungkinkan Anda untuk melakukan pra-instal kunci SSH setelah membuat instance baru. Ini memungkinkan Anda untuk mengakses pengguna root server, namun, th

Cara Menginstal PostgreSQL 11.1 Di Arch Linux

Cara Menginstal PostgreSQL 11.1 Di Arch Linux

Prasyarat Server Vultr berjalan terbaru Arch Linux (lihat artikel ini.) Akses Sudo. Perintah yang diperlukan untuk dijalankan karena root diawali oleh #, dan satu

Cara Memasang Manajer File Terminal Ranger di Linux

Cara Memasang Manajer File Terminal Ranger di Linux

Ranger adalah manajer file berbasis baris perintah dengan binding kunci VI. Ini memberikan antarmuka kutukan minimalis dan bagus dengan tampilan pada hierarki direktori

Cara Memasang Redmine di Ubuntu 16.04

Cara Memasang Redmine di Ubuntu 16.04

Menggunakan Sistem yang Berbeda? Redmine adalah alat manajemen proyek berbasis web gratis dan open source. Itu ditulis dalam Ruby on Rails dan mendukung banyak database

Cara Membangun Brotli Dari Sumber di Ubuntu 18.04 LTS

Cara Membangun Brotli Dari Sumber di Ubuntu 18.04 LTS

Menggunakan Sistem yang Berbeda? Brotli adalah metode kompresi baru dengan rasio kompresi yang lebih baik daripada GZIP. Kode sumbernya dihosting secara publik di Githu ini

Atur Akun Pengguna khusus SFTP di CentOS 7

Atur Akun Pengguna khusus SFTP di CentOS 7

Pada kesempatan tertentu, Administrator Sistem mungkin perlu membuat akun pengguna dan membatasi akses mereka untuk hanya mengelola file mereka sendiri melalui sFTP, tetapi tidak

Menggunakan Tampilan MySQL pada Debian 7

Menggunakan Tampilan MySQL pada Debian 7

Pendahuluan MySQL memiliki fitur hebat yang dikenal sebagai tampilan. Tampilan adalah kueri yang disimpan. Pikirkan mereka sebagai alias untuk permintaan yang panjang. Dalam panduan ini,

Cara Memasang Nginx 1.14 Di Arch Linux

Cara Memasang Nginx 1.14 Di Arch Linux

Prasyarat Server Vultr berjalan terbaru Arch Linux (lihat artikel ini.) Akses Sudo. Perintah yang harus dijalankan sebagai root diawali oleh #. Th

Nonaktifkan atau Batasi Login Root melalui SSH di Linux

Nonaktifkan atau Batasi Login Root melalui SSH di Linux

Mengizinkan login root melalui SSH umumnya dianggap sebagai praktik keamanan yang buruk di seluruh industri teknologi. Sebagai gantinya, Anda dapat melakukan administrativ sensitif

Cara Memasang Seafile Server di Ubuntu 16.10

Cara Memasang Seafile Server di Ubuntu 16.10

Menggunakan Sistem yang Berbeda? Seafile (versi komunitas) adalah solusi sinkronisasi dan berbagi file sumber gratis dan terbuka yang mirip dengan ownCloud. Sepanjang kecerdasan

Cara Memasang Thelia 2.3 pada Debian 9

Cara Memasang Thelia 2.3 pada Debian 9

Menggunakan Sistem yang Berbeda? Thelia adalah alat sumber terbuka untuk membuat situs web e-bisnis dan mengelola konten online yang ditulis dalam PHP. Kode sumber thelia i

Cara Memasang MongoDB 4.0 di Arch Linux

Cara Memasang MongoDB 4.0 di Arch Linux

Prasyarat Server Vultr berjalan terbaru Arch Linux (lihat artikel ini) Akses Sudo: Perintah yang diperlukan untuk dijalankan karena root diawali oleh #, dan satu

Cara Memasang Panel Kontrol Hosting Mudah di Ubuntu 16.04

Cara Memasang Panel Kontrol Hosting Mudah di Ubuntu 16.04

Pelajari langkah-langkah untuk memasang Panel Kontrol Hosting Mudah (EHCP) di Ubuntu 16.04 dengan panduan ini.

Wawasan tentang 26 Teknik Analisis Data Besar: Bagian 1

Wawasan tentang 26 Teknik Analisis Data Besar: Bagian 1

Wawasan tentang 26 Teknik Analisis Data Besar: Bagian 1

6 Hal yang Sangat Menggila dari Nintendo Switch

6 Hal yang Sangat Menggila dari Nintendo Switch

Banyak dari Anda tahu Switch keluar pada Maret 2017 dan fitur-fitur barunya. Bagi yang belum tahu, kami sudah menyiapkan daftar fitur yang membuat 'Switch' menjadi 'gadget yang wajib dimiliki'.

Janji Teknologi Yang Masih Belum Ditepati

Janji Teknologi Yang Masih Belum Ditepati

Apakah Anda menunggu raksasa teknologi untuk memenuhi janji mereka? periksa apa yang belum terkirim.

Fungsionalitas Lapisan Arsitektur Referensi Big Data

Fungsionalitas Lapisan Arsitektur Referensi Big Data

Baca blog untuk mengetahui berbagai lapisan dalam Arsitektur Big Data dan fungsinya dengan cara yang paling sederhana.

Bagaimana AI Dapat Membawa Otomatisasi Proses ke Tingkat Selanjutnya?

Bagaimana AI Dapat Membawa Otomatisasi Proses ke Tingkat Selanjutnya?

Baca ini untuk mengetahui bagaimana Kecerdasan Buatan menjadi populer di antara perusahaan skala kecil dan bagaimana hal itu meningkatkan kemungkinan untuk membuat mereka tumbuh dan memberi keunggulan pada pesaing mereka.

CAPTCHA: Berapa Lama Itu Bisa Tetap Menjadi Teknik yang Layak Untuk Perbedaan Human-AI?

CAPTCHA: Berapa Lama Itu Bisa Tetap Menjadi Teknik yang Layak Untuk Perbedaan Human-AI?

CAPTCHA telah berkembang cukup sulit bagi pengguna untuk dipecahkan dalam beberapa tahun terakhir. Apakah itu akan tetap efektif dalam deteksi spam dan bot di masa mendatang?

Singularitas Teknologi: Masa Depan Peradaban Manusia yang Jauh?

Singularitas Teknologi: Masa Depan Peradaban Manusia yang Jauh?

Saat Sains Berkembang dengan kecepatan tinggi, mengambil alih banyak upaya kita, risiko menundukkan diri kita pada Singularitas yang tidak dapat dijelaskan juga meningkat. Baca, apa arti singularitas bagi kita.

Telemedicine Dan Perawatan Kesehatan Jarak Jauh: Masa Depan Ada Di Sini

Telemedicine Dan Perawatan Kesehatan Jarak Jauh: Masa Depan Ada Di Sini

Apa itu telemedicine, perawatan kesehatan jarak jauh dan dampaknya terhadap generasi mendatang? Apakah itu tempat yang bagus atau tidak dalam situasi pandemi? Baca blog untuk menemukan tampilan!

Pernahkah Anda Bertanya-tanya Bagaimana Hacker Menghasilkan Uang?

Pernahkah Anda Bertanya-tanya Bagaimana Hacker Menghasilkan Uang?

Anda mungkin pernah mendengar bahwa peretas menghasilkan banyak uang, tetapi pernahkah Anda bertanya-tanya bagaimana cara mereka mendapatkan uang sebanyak itu? mari berdiskusi.