要利用 PHP 實(shí)現(xiàn)任務(wù)隊(duì)列,你可以遵循以下步驟:
tasks
的表,其中包含 id
、task_name
和 status
等字段。CREATE TABLE tasks (
id INT AUTO_INCREMENT PRIMARY KEY,
task_name VARCHAR(255) NOT NULL,
status VARCHAR(50) NOT NULL DEFAULT 'pending'
);
// 使用 PDO
$dsn = 'mysql:host=localhost;dbname=your_database';
$username = 'your_username';
$password = 'your_password';
$options = [
PDO::ATTR_ERRMODE => PDO::ERRMODE_EXCEPTION,
PDO::ATTR_DEFAULT_FETCH_MODE => PDO::FETCH_ASSOC,
];
$db = new PDO($dsn, $username, $password, $options);
// 使用 mysqli
$servername = "localhost";
$username = "your_username";
$password = "your_password";
$dbname = "your_database";
$conn = new mysqli($servername, $username, $password, $dbname);
if ($conn->connect_error) {
die("連接失敗: " . $conn->connect_error);
}
tasks
表中。function addTaskToQueue($taskName) {
global $db;
$stmt = $db->prepare("INSERT INTO tasks (task_name, status) VALUES (:task_name, :status)");
$stmt->bindParam(':task_name', $taskName);
$stmt->bindParam(':status', 'pending');
$stmt->execute();
}
tasks
表中獲取所有狀態(tài)為 “pending” 的任務(wù),并執(zhí)行相應(yīng)的操作。你還可以根據(jù)需要設(shè)置一個(gè)時(shí)間間隔來定期檢查新任務(wù)。function processTasks() {
global $db;
while (true) {
$stmt = $db->prepare("SELECT * FROM tasks WHERE status = 'pending'");
$stmt->execute();
$tasks = $stmt->fetchAll();
foreach ($tasks as $task) {
// 在這里執(zhí)行任務(wù)操作,例如調(diào)用其他 PHP 腳本或 API
echo "Processing task: " . $task['task_name'] . PHP_EOL;
// 更新任務(wù)狀態(tài)為 "completed"
$updateStmt = $db->prepare("UPDATE tasks SET status = 'completed' WHERE id = :id");
$updateStmt->bindParam(':id', $task['id']);
$updateStmt->execute();
}
// 設(shè)置時(shí)間間隔,例如每分鐘檢查一次新任務(wù)
sleep(60);
}
}
addTaskToQueue()
函數(shù)將任務(wù)添加到隊(duì)列中,并使用 processTasks()
函數(shù)處理隊(duì)列中的任務(wù)。// 添加任務(wù)到隊(duì)列
addTaskToQueue("Example task");
// 處理隊(duì)列中的任務(wù)
processTasks();
這樣,你就可以利用 PHP 實(shí)現(xiàn)一個(gè)簡單的任務(wù)隊(duì)列系統(tǒng)了。請注意,這個(gè)示例僅用于演示目的,實(shí)際應(yīng)用中可能需要考慮更多的因素,例如錯(cuò)誤處理、日志記錄、分布式處理等。