Rumah > pembangunan bahagian belakang > tutorial php > Bagaimanakah PHP terus mendengar langganan mesej Redis dan mengendalikan tugas tak segerak?

Bagaimanakah PHP terus mendengar langganan mesej Redis dan mengendalikan tugas tak segerak?

WBOY
Lepaskan: 2023-09-05 16:10:01
asal
800 orang telah melayarinya

Bagaimanakah PHP terus mendengar langganan mesej Redis dan mengendalikan tugas tak segerak?

Bagaimanakah PHP terus mendengar langganan mesej Redis dan memproses tugas tak segerak?

Dalam pembangunan PHP, kami sering menghadapi senario memproses tugas tak segerak. Sebagai pangkalan data dalam memori berprestasi tinggi, Redis menyediakan mekanisme Pub/Sub yang boleh digunakan untuk menerbitkan dan melanggan mesej. Artikel ini akan memperkenalkan cara menggunakan PHP untuk mendengar langganan mesej Redis secara berterusan dan menunjukkan cara mengendalikan tugas tak segerak melalui contoh kod.

Memahami mekanisme Pub/Sub Redis

Sebelum kita mula, kita perlu memahami mekanisme Pub/Sub Redis terlebih dahulu. Pub/Sub ialah mekanisme yang digunakan oleh Redis untuk penerbitan dan langganan mesej, yang boleh merealisasikan penghantaran mesej satu-ke-banyak. Antaranya, pengirim mesej dipanggil penerbit (Publisher), dan penerima mesej dipanggil pelanggan (Subscriber).

Mekanisme Pub/Sub Redis terutamanya mempunyai konsep utama berikut:

  • Saluran (saluran): Komunikasi antara penerbitan mesej dan langganan dijalankan melalui saluran. Mesej boleh diterbitkan ke satu atau lebih saluran dan pelanggan boleh memilih untuk melanggan saluran yang diminati.
  • Langganan: Pelanggan melanggan satu atau lebih saluran melalui arahan LANGGANAN Setelah langganan berjaya, mereka boleh menerima mesej daripada saluran tersebut.
  • Penerbitan (penerbitan): Penerbit menerbitkan mesej ke saluran yang ditentukan melalui arahan PUBLISH, dan semua pelanggan yang melanggan saluran tersebut akan menerima mesej tersebut.
  • Nyahlanggan: Pelanggan boleh menyahlanggan satu atau lebih saluran melalui perintah NYAHLANGGAN Setelah penyahlangganan berjaya, mereka tidak akan menerima mesej daripada saluran itu lagi.

PHP melaksanakan langganan mesej Redis dan pemprosesan tugas tak segerak

Seterusnya, kami akan menggunakan PHP untuk melaksanakan langganan mesej Redis dan memproses pemprosesan tugas tak segerak.

1 Pasang sambungan Redis

Pertama, kita perlu memasang sambungan Redis. Anda boleh menggunakan arahan PECL untuk memasang sambungan Redis Perintahnya adalah seperti berikut:

$ pecl install redis
Salin selepas log masuk

Setelah pemasangan selesai, tambahkan konfigurasi berikut dalam fail php.ini:

extension=redis.so
Salin selepas log masuk
#. 🎜🎜#2 Langgan mesej Redis# 🎜🎜#

Gunakan kod PHP untuk menyambung ke Redis dan melanggan mesej adalah seperti berikut:

<?php

$redis = new Redis();
$redis->connect('127.0.0.1', 6379);

$redis->subscribe(['channel1', 'channel2'], function ($redis, $channel, $message) {
    echo "Received message from channel: {$channel}, message: {$message}
";
});

?>
Salin selepas log masuk

Dalam kod di atas, kami mula-mula lulus $redis->connect()</code >Kaedah untuk menyambung ke pelayan Redis. Kemudian, gunakan kaedah <code>$redis->subscribe() untuk melanggan satu atau lebih saluran dan menerima mesej melalui fungsi panggil balik.

3 Terbitkan mesej Redis $redis->connect()方法连接Redis服务器。然后,使用$redis->subscribe()方法订阅一个或多个频道,并通过回调函数接收消息。

3. 发布Redis消息

使用PHP代码发布消息到Redis频道,示例代码如下:

<?php

$redis = new Redis();
$redis->connect('127.0.0.1', 6379);

$message = 'Hello, Redis!';

$redis->publish('channel1', $message);

?>
Salin selepas log masuk

上述代码中,我们首先通过$redis->connect()方法连接Redis服务器。然后,使用$redis->publish()方法将消息发布到指定的频道。

4. 处理异步任务

在消息订阅过程中,我们可以根据实际需求来处理接收到的消息。这里以处理异步任务为例,示例代码如下:

<?php

$redis = new Redis();
$redis->connect('127.0.0.1', 6379);

$redis->subscribe(['task_queue'], function ($redis, $channel, $message) {
    echo "Received message from channel: {$channel}, message: {$message}
";

    // 处理异步任务
    handleAsyncTask($message);
});

function handleAsyncTask($message) {
    // 模拟处理耗时任务
    sleep(5);

    // 处理完成后执行其他逻辑
    echo "Async task handled: {$message}
";
}

?>
Salin selepas log masuk

上述代码中,我们订阅了名为task_queue的频道,并在接收到消息后调用handleAsyncTask()方法处理异步任务。在handleAsyncTask()

Gunakan kod PHP untuk menerbitkan mesej ke saluran Redis. kod di atas, kami mula-mula lulus Kaedah $redis->connect() menyambung ke pelayan Redis. Kemudian, gunakan kaedah $redis->publish() untuk menerbitkan mesej ke saluran yang ditentukan.

4. Memproses tugas tak segerak

Semasa proses langganan mesej, kami boleh memproses mesej yang diterima mengikut keperluan sebenar. Di sini kami mengambil pemprosesan tugas tak segerak sebagai contoh Kod sampel adalah seperti berikut: #🎜🎜#rrreee#🎜🎜#Dalam kod di atas, kami melanggan saluran bernama task_queue dan memanggil handleAsyncTask() mengendalikan tugas tak segerak. Dalam kaedah handleAsyncTask(), kami mensimulasikan pemprosesan tugasan yang memakan masa dan melaksanakan logik lain selepas tugasan selesai. #🎜🎜##🎜🎜#Ringkasan#🎜🎜##🎜🎜#Artikel ini memperkenalkan cara menggunakan PHP untuk mendengar langganan mesej Redis secara berterusan dan menunjukkan cara mengendalikan tugas tak segerak melalui contoh kod. Dengan menggunakan mekanisme Pub/Sub Redis, kami boleh melaksanakan penerbitan dan melanggan mesej dengan berkesan, meningkatkan keselarasan dan kelajuan tindak balas aplikasi. Saya harap artikel ini dapat membantu semua orang dalam proses mengendalikan tugas tak segerak. #🎜🎜#

Atas ialah kandungan terperinci Bagaimanakah PHP terus mendengar langganan mesej Redis dan mengendalikan tugas tak segerak?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Label berkaitan:
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