Rumah >pembangunan bahagian belakang >tutorial php >Pilihan mod pemindahan data Swoole dan Workerman antara PHP dan MySQL

Pilihan mod pemindahan data Swoole dan Workerman antara PHP dan MySQL

WBOY
WBOYasal
2023-10-15 17:00:59641semak imbas

Pilihan mod pemindahan data Swoole dan Workerman antara PHP dan MySQL

Pilihan mod pemindahan data oleh Swoole dan Workerman antara PHP dan MySQL

Pengenalan:
Dalam aplikasi PHP, interaksi data dengan pangkalan data MySQL adalah keperluan yang sangat biasa. Dalam pengaturcaraan rangkaian PHP, Swoole dan Workerman ialah dua rangka kerja sumber terbuka yang biasa digunakan, yang menyediakan keupayaan komunikasi rangkaian berprestasi tinggi. Artikel ini akan membandingkan pilihan Swoole dan Workerman dalam mod penghantaran data PHP dan MySQL, dan memberikan contoh kod khusus.

1. Swoole
Swoole ialah enjin komunikasi rangkaian PHP tak segerak berprestasi tinggi. Lapisan bawahnya ditulis dalam bahasa C dan boleh berinteraksi secara langsung dengan kernel sistem pengendalian. Berbanding dengan pengaturcaraan rangkaian PHP tradisional, Swoole mempunyai keupayaan konkurensi yang lebih tinggi dan penggunaan sumber yang lebih rendah. Berikut ialah contoh kod untuk menggunakan Swoole untuk merealisasikan penghantaran data antara PHP dan MySQL:

<?php
// 创建一个Swoole的TCP服务器
$server = new SwooleServer('127.0.0.1', 9501);

// 监听连接事件
$server->on('Connect', function ($server, $fd) {
    echo "Client {$fd} connected
";
});

// 监听数据接收事件
$server->on('Receive', function ($server, $fd, $fromId, $data) {
    // 连接MySQL数据库
    $conn = new mysqli('localhost', 'root', 'password', 'database');
    // 执行SQL查询操作
    $result = $conn->query($data);
    // 处理查询结果
    // ...
    // 返回查询结果
    $server->send($fd, $result);
    // 关闭数据库连接
    $conn->close();
});

// 监听关闭连接事件
$server->on('Close', function ($server, $fd) {
    echo "Client {$fd} closed
";
});

// 启动服务器
$server->start();

Dalam kod di atas, kami mencipta pelayan TCP Swoole dan mendengar tiga acara: sambungan, penerimaan data dan penutupan sambungan. Apabila pelanggan berjaya menyambung, acara Connect akan dicetuskan apabila pelanggan menghantar data, acara Receive akan dicetuskan ke pangkalan data MySQL dalam acara ini dan laksanakan operasi pertanyaan SQL akhirnya, hasil pertanyaan dikembalikan kepada klien dan sambungan pangkalan data ditutup. Apabila pelanggan memutuskan sambungan, acara Tutup dicetuskan. Connect事件;当客户端发送数据时,会触发Receive事件,我们可以在该事件中连接MySQL数据库,并执行SQL查询操作;最后,将查询结果返回给客户端,并关闭数据库连接。当客户端断开连接时,会触发Close事件。

二、Workerman
Workerman是一款高性能的PHP异步网络通信框架,它采用纯PHP编写,无需依赖其他扩展。Workerman通过事件驱动的方式处理网络请求,具有低延迟、高并发的特点。以下是使用Workerman实现PHP与MySQL数据传输的示例代码:

<?php
// 引入Workerman的自动加载文件
require_once __DIR__ . '/vendor/autoload.php';

use WorkermanWorker;

// 创建一个Worker监听端口,创建MySQL数据库连接
$worker = new Worker('tcp://127.0.0.1:9502');
$worker->onWorkerStart = function ($worker) {
    // 连接MySQL数据库
    $conn = new mysqli('localhost', 'root', 'password', 'database');
    $worker->conn = $conn;
};

// 客户端连接时触发的事件
$worker->onConnect = function ($connection) use ($worker) {
    echo "Client {$connection->id} connected
";
};

// 客户端发送数据时触发的事件
$worker->onMessage = function ($connection, $data) use ($worker) {
    // 执行SQL查询操作
    $result = $worker->conn->query($data);
    // 处理查询结果
    // ...
    // 返回查询结果给客户端
    $connection->send($result);
};

// 客户端断开连接时触发的事件
$worker->onClose = function ($connection) {
    echo "Client {$connection->id} closed
";
};

// 启动Worker
Worker::runAll();

在上述示例代码中,我们创建了一个Workerman Worker实例,并监听了端口9502。在Worker的onWorkerStart事件中,创建了MySQL数据库连接,该连接可以在整个Worker的生命周期中使用。当客户端连接成功后,会触发onConnect事件;当客户端发送数据时,会触发onMessage事件,在该事件中连接MySQL数据库,并执行SQL查询操作;最后,将查询结果返回给客户端。当客户端断开连接时,会触发onClose

2. Workerman

Workerman ialah rangka kerja komunikasi rangkaian tak segerak PHP berprestasi tinggi Ia ditulis dalam PHP tulen dan tidak perlu bergantung pada sambungan lain. Workerman mengendalikan permintaan rangkaian dalam cara yang didorong oleh peristiwa, menampilkan kependaman rendah dan serentak tinggi. Berikut ialah contoh kod untuk menggunakan Workerman untuk melaksanakan pemindahan data antara PHP dan MySQL:
rrreee

Dalam contoh kod di atas, kami mencipta contoh Workerman Worker dan mendengar port 9502. Dalam acara onWorkerStart Pekerja, sambungan pangkalan data MySQL dibuat, yang boleh digunakan sepanjang kitaran hayat Pekerja. Apabila klien berjaya menyambung, acara onConnect akan dicetuskan apabila pelanggan menghantar data, acara onMessage akan dicetuskan dalam acara ini, pangkalan data MySQL disambungkan dan pertanyaan SQL dilaksanakan, akhirnya, kembalikan hasil pertanyaan kepada klien. Apabila pelanggan memutuskan sambungan, peristiwa onClose akan dicetuskan. 🎜🎜Ringkasan: 🎜Kedua-dua Swoole dan Workerman menyediakan keupayaan komunikasi rangkaian berprestasi tinggi dan memainkan peranan yang sangat baik dalam penghantaran data antara PHP dan MySQL. Rangka kerja yang mana untuk dipilih boleh dipilih berdasarkan keperluan projek, pengalaman pembangunan dan pilihan peribadi. Di atas adalah pengenalan kepada mod penghantaran data PHP dan MySQL pilihan Swoole dan Workerman saya harap ia akan membantu pembaca. 🎜

Atas ialah kandungan terperinci Pilihan mod pemindahan data Swoole dan Workerman antara 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