Systemd chủ yếu được sử dụng để quản lý các service trên môi trường Linux, nhưng nó cũng cho phép chúng ta quản lý các service với quyền không phải là root. Điều này, làm cho systemd trở thành một giải pháp thay thế tuyệt vời cho service như supervisord vì nó có thể phát hiện sự cố và tự khỏi động lại service.

Còn chần chừ gì nữa, chúng ta sẽ bắt đầu setting service cho Laravel Queue Workers nào.

Cài đặt Laravel Queue Workers with Systemd

Đầu tiên, chúng ta, sẽ tạo ra một file service có tên là queue-main.service nằm trong thư mục /etc/systemd/system, bằng cách chạy lệnh comamnd sau đây:

touch /etc/systemd/system/queue-main.service

Tiếp theo, chúng ta sẽ phân quyền cho file queue-main.service bằng lệnh command sau đây:

chmod 664 /etc/systemd/system/queue-main.service

Tiếp theo, bạn hay chỉnh sửa file queue-main.service như sau:

# Laravel queue worker using systemd
# ----------------------------------
#                                   
# /lib/systemd/system/queue-main.service
#                                  
# run this command to enable service:
# systemctl enable queue-main.service
[Unit]
Description=queue-service
[Service]
Type=simple
User=nginx
WorkingDirectory=/path/to/my/project
ExecStart=/usr/bin/php artisan queue:work --queue=high,default
Restart=always
StandardOutput=append:/path/to/my/project/storage/logs/queaue.log
StandardError=append:/path/to/my/project/storage/logs/queue.log
[Install]
WantedBy=multi-user.target

Để systemd nhận ra các thay đổi của bạn, bạn cần chạy lệnh command sau đây:

systemctl daemon-reload

Bây giờ, bạn có thể quản lý Laravel Queue Workers với systemd:

# Bắt đầu sử dụng service
systemctl start queue-main
# Dừng sử dụng service
systemctl stop queue-main
# Khởi động lại service
systemctl restart queue-main
# Hiện thị trang thái service
systemctl status queue-main

Nếu bạn muốn systemd này tự động khởi động khi người dùng đăng nhập, bạn có enable/disable bằng lệnh comamnd sau:

# Enable
systemctl enable queue-main
# Disable 
systemctl disable queue-main

Xem logs

Tất cả mọi thứ về lệnh PHP sẽ được ghi vào stdout, stderr và sẽ được ghi bởi journald. Bạn có thể sử dụng lệnh command sau để xem log:

journalctl -u queue-main

Tự động khởi động lại khi bị lỗi

Thành thật mà nói mọi thứ trên systemd đều có thể bị tắt khi chúng gặp sự cố và bạn muốn đảm bảo rằng nó sẽ tự khởi động lại, May mắn thay, bạn có thể chỉ định trong cấu hình systemd để nó tự khởi động lại khi gặp sự cố không mong muốn

Thêm phần sau vào [Service] trong file queue-main.service

RestartSec=10s
Restart=on-failure

Điều này làm cho systemd khởi động lại service sau 10s khi nó bị dừng với mã lỗi khác 0. Nếu bạn sử dụng exited, systemd coi công việc đã xong và không khởi động lại service cho đến khi bạn khởi động theo cách thủ công.

Nếu bạn vẫn không chắc chắn với xử lý trên, bạn có thể sử dụng crontab để xem service cho đang chạy hay không, nếu nó không chạy thì chúng ta bật service một lần nữa

Đầu tiên, bạn hãy tạo một file bash start_queue_main.sh với nội dung sau:

#!/bin/bash
  
HOME=/root
LOGNAME=root
PATH=/usr/local/sbin:/usr/local/bin:/sbin:/bin:/usr/sbin:/usr/bin
LANG=en_US.UTF-8
SHELL=/bin/sh
PWD=/root
systemctl is-active --quiet queue-main && echo service is running || systemctl start queue-main

Sau đó, chúng ta sẽ setting crontab cứ 1 phút sẽ chạy file bash này một lần

* * * * * /usr/bin/sh /path/to/my/bash/start_queue_main.sh >> /dev/null 2>&1

Tôi hy vọng bạn thích hướng dẫn này. Nếu bạn có bất kỳ câu hỏi nào hãy liên hệ với chúng tôi qua trang contact. Cảm ơn bạn.

CÓ THỂ BẠN QUAN TÂM

Laravel 9 REST API With Sanctum Authentication

Laravel 9 REST API With Sanctum Authentication

Laravel Sanctum Laravel Sanctum cung cấp một hệ thống authentication đơn giản cho các SPA, ứng dụng Mobile và API đơn giản sử dụng token. Sanctum cho phép ứng dụng của bạn phát hành các mã token...

Laravel Logging Of Database Queries

Laravel Logging Of Database Queries

Laravel là một Framework PHP mạnh mẽ và linh hoạt, giúp cho việc phát triển ứng dụng trở nên đơn giản và dễ dàng hơn. Một trong những tính năng hữu ích của Laravel là khả năng ghi nhật ký truy vấn...

Laravel Change Expire Time Cookie Remember

Laravel Change Expire Time Cookie Remember

Vấn đề Đôi khi, trang web của bạn chỉ muốn người dùng sử chức năng remembering users  trong 7 ngày hoặc là 30 ngày chẳng hạn. Nhưng Authentication của Laravel không cung cấp cho chúng ta tùy chọn đ...

Integrating OpenAI in Laravel

Integrating OpenAI in Laravel

OpenAI OpenAI là một phòng thí nghiệm nghiên cứu trí tuệ nhân tạo (AI) của Mỹ bao gồm tổ chức phi lợi nhuận OpenAI Incorporated (OpenAI Inc.) và công ty con hoạt động vì lợi nhuận OpenAI Limited Par...

Laravel UI Password Reset Expired

Laravel UI Password Reset Expired

Trong thư viện laravel/ui, thì chức năng password reset dù cho token có hết hạn thì vẫn có truy cập vào trang password reset, đến khi bạn submit form thì mới thông báo là token đã hết hạn. Nhưng có mộ...

Laravel Many to Many Eloquent Relationship

Laravel Many to Many Eloquent Relationship

Many To many Relationship là mối quan hệ hơi phức tạp hơn mối quan hệ 1 - 1 và 1- n. Ví dụ một user có thể có nhiều role khác nhau, trong đó role cũng được liên kết với nhiều user khác nhau. Vì vậy...

Method WhereAny / WhereAll  in Laravel Eloquent

Method WhereAny / WhereAll in Laravel Eloquent

New Laravel 10: Eloquent WhereAny() và WhereAll() Laravel cung cấp cho chúng ta khả năng xây dựng các truy vấn dữ liệu mạnh mẽ với Eloquent ORM, giúp chúng ta có thể xử lý các truy vấn cơ sở dữ li...

Csv import with Validation for Laravel

Csv import with Validation for Laravel

Trong một bài viết lúc trước, mình đã chia sẻ đến các bạn cách xây dựng một service import và export CSV sử dụng Facades, nếu có bạn nào không biết hoặc đã quên các bạn có thể tham khảo lại bài viết t...

Document Laravel API With OpenAPI (Swagger)

Document Laravel API With OpenAPI (Swagger)

Swagger là gì? Swagger là một Ngôn ngữ mô tả giao diện để mô tả các API RESTful được thể hiện bằng JSON. Swagger được sử dụng cùng với một bộ công cụ phần mềm mã nguồn mở để thiết kế, xây dựng, l...

ManhDanBlogs