Rumah  >  Artikel  >  pembangunan bahagian belakang  >  Aplikasi teknologi baris gilir dalam penapisan mesej dan perisian tengah mesej dalam PHP dan MySQL

Aplikasi teknologi baris gilir dalam penapisan mesej dan perisian tengah mesej dalam PHP dan MySQL

WBOY
WBOYasal
2023-10-15 12:04:41597semak imbas

Aplikasi teknologi baris gilir dalam penapisan mesej dan perisian tengah mesej dalam PHP dan MySQL

Aplikasi teknologi baris gilir dalam penapisan mesej dan perisian tengah mesej dalam PHP dan MySQL

Pengenalan:
Dengan perkembangan Internet Dengan pembangunan pesat, aplikasi kami bukan lagi hanya halaman web yang ringkas, tetapi melibatkan sejumlah besar tugas tak segerak dan penghantaran mesej. Untuk menjadikan aplikasi kami lebih mantap dan cekap, teknologi beratur menjadi alat penting. Artikel ini akan memperkenalkan aplikasi teknologi baris gilir dalam penapisan mesej dan perisian tengah mesej dalam PHP dan MySQL, dan menyediakan contoh kod khusus.

1. Konsep penapisan mesej:
Penapisan mesej merujuk kepada penapisan dan penapisan mesej mengikut syarat yang ditetapkan supaya aplikasi hanya boleh memproses mesej yang memenuhi syarat dan meningkatkan kecekapan pemprosesan. Dalam PHP, kita boleh menggunakan pangkalan data MySQL untuk melaksanakan penapisan mesej.

  1. Buat jadual mesej:

Pertama, kita perlu mencipta jadual mesej dalam pangkalan data MySQL untuk menyimpan mesej yang belum selesai. Struktur jadual mesej adalah seperti berikut:

CREATE TABLE `messages` (
  `id` INT(11) NOT NULL AUTO_INCREMENT,
  `message` VARCHAR(255) NOT NULL,
  `status` TINYINT(1) NOT NULL DEFAULT '0',
  `created_at` TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,
  PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;

Jadual mesej mengandungi medan berikut:

  • id: pengecam unik mesej, auto- menambah kunci utama.
  • mesej: Kandungan mesej.
  • status: Status mesej, 0 bermakna tidak diproses, 1 bermakna diproses.
  • created_at: Masa penciptaan mesej.
  1. Sisipkan mesej:

Seterusnya, kita perlu memasukkan beberapa mesej yang belum selesai ke dalam jadual mesej. Contoh kod berikut boleh digunakan:

<?php
// 连接数据库
$mysqli = new mysqli("localhost", "username", "password", "database");

// 插入消息
$query = "INSERT INTO messages (message) VALUES ('Message 1'), ('Message 2'), ('Message 3')";
$mysqli->query($query);

// 关闭数据库连接
$mysqli->close();
?>

Kod di atas akan memasukkan tiga mesej yang belum selesai ke dalam jadual mesej.

  1. Tapis dan proses mesej:

Seterusnya, kita perlu menulis skrip PHP untuk menapis dan memproses mesej. Contoh kod khusus adalah seperti berikut:

<?php
// 连接数据库
$mysqli = new mysqli("localhost", "username", "password", "database");

// 获取未处理的消息
$query = "SELECT * FROM messages WHERE status = 0";
$result = $mysqli->query($query);

// 处理消息
while ($row = $result->fetch_assoc()) {
    $message = $row['message'];
    
    // 处理消息的代码
    // ...
    
    // 标记为已处理
    $query = "UPDATE messages SET status = 1 WHERE id = {$row['id']}";
    $mysqli->query($query);
}

// 关闭数据库连接
$mysqli->close();
?>

Kod di atas mula-mula memperoleh mesej yang tidak diproses, kemudian memproses mesej satu persatu dan menandakannya sebagai diproses. Logik pemprosesan mesej boleh ditulis mengikut keperluan sebenar.

2. Konsep perisian tengah mesej:
Perisian tengah mesej merujuk kepada mekanisme yang digunakan untuk menyampaikan mesej dan melaksanakan komunikasi tak segerak dalam sistem yang diedarkan. Dalam PHP, kita boleh menggunakan perpustakaan pihak ketiga untuk melaksanakan fungsi perisian tengah mesej. Berikut menggunakan RabbitMQ sebagai contoh untuk memperkenalkan.

  1. Pasang RabbitMQ:

Pertama, kita perlu memasang sambungan PHP RabbitMQ. Anda boleh memasangnya menggunakan arahan berikut:

$ pecl install amqp
  1. Hantar mesej:

Seterusnya, kita perlu menulis skrip PHP untuk menghantar mesej. Contoh kod khusus adalah seperti berikut:

<?php
// 创建连接
$connection = new AMQPConnection([
    'host' => 'localhost',
    'port' => '5672',
    'login' => 'guest',
    'password' => 'guest'
]);
$connection->connect();

// 创建通道
$channel = new AMQPChannel($connection);

// 创建交换机
$exchange = new AMQPExchange($channel);
$exchange->setName('my_exchange');
$exchange->setType(AMQP_EX_TYPE_DIRECT); // 直连交换机
$exchange->declareExchange();

// 创建消息
$message = 'Hello, RabbitMQ';

// 发布消息
$exchange->publish($message, 'my_routing_key');

// 关闭连接
$connection->disconnect();
?>

Dalam kod di atas, kami mula-mula membuat sambungan, kemudian mencipta saluran dan suis, dan mengisytiharkan jenis suis. Kami kemudian mencipta mesej dan menerbitkannya menggunakan kekunci penghalaan yang ditentukan. Jenis suis dan kekunci penghalaan yang sesuai boleh dipilih berdasarkan keperluan sebenar.

  1. Menggunakan mesej:

Seterusnya, kita perlu menulis skrip PHP untuk menggunakan mesej. Contoh kod khusus adalah seperti berikut:

<?php
// 创建连接
$connection = new AMQPConnection([
    'host' => 'localhost',
    'port' => '5672',
    'login' => 'guest',
    'password' => 'guest'
]);
$connection->connect();

// 创建通道
$channel = new AMQPChannel($connection);

// 创建交换机
$exchange = new AMQPExchange($channel);
$exchange->setName('my_exchange');
$exchange->setType(AMQP_EX_TYPE_DIRECT); // 直连交换机
$exchange->declareExchange();

// 创建队列
$queue = new AMQPQueue($channel);
$queue->setName('my_queue');
$queue->declareQueue();
$queue->bind('my_exchange', 'my_routing_key');

// 消费消息
while ($message = $queue->get()) {
    $message->ack();
    
    // 处理消息的代码
    // ...
}
?>

Dalam kod di atas, kami mula-mula membuat sambungan, kemudian mencipta saluran dan suis, dan mengisytiharkan jenis suis. Kami kemudian membuat baris gilir dan mengikat baris gilir ke suis. Akhir sekali, kami menggunakan mesej dalam baris gilir dalam satu gelung dan memproses setiap mesej.

Kesimpulan:
Melalui contoh kod di atas, kita dapat melihat aplikasi teknologi baris gilir dalam penapisan mesej dan perisian tengah mesej dalam PHP dan MySQL. Penapisan mesej boleh membantu kami memproses mesej yang belum selesai dengan cekap dan meningkatkan prestasi aplikasi. Perisian tengah mesej boleh membantu kami melaksanakan komunikasi tak segerak dan penghantaran mesej dalam sistem teragih. Sudah tentu, kod sampel di atas hanyalah asas, anda boleh mengoptimumkan dan memanjangkannya mengikut keperluan anda sendiri. Harap artikel ini membantu anda!

Atas ialah kandungan terperinci Aplikasi teknologi baris gilir dalam penapisan mesej dan perisian tengah mesej dalam PHP dan MySQL. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
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