首先Linux服务器需要安装好Kafka,这里不再具体细说,可以看我前面的文章:Linux搭建Kafka详细一步一步指南(linux启动kafka脚本)-CSDN博客
composer require enqueue/rdkafka:0.10.20
这个版本适合php7.4。具体版本号点击这里:https://packagist.org/packages/enqueue/rdkafka
注意:版本号一定要选对!!!至于版本号该怎么选择,这里也不再细说,可以看我前面的文章:Laravel 使用rdkafka_laravel详细教程(实操避坑)_laravel kafka-CSDN博客
根据你的操作系统和 PHP 版本,安装 rdkafka 扩展。你可以参考 rdkafka 扩展的官方文档来完成安装
可参考文章里面【windows】PHP扩展 安装教程,Linux也差不多,下载对应linux的就可以:Laravel 使用rdkafka_laravel详细教程(实操避坑)_laravel kafka-CSDN博客
打开 config/queue.php
文件,找到 connections
数组,并添加以下配置:
'connections' => [
//kafka消息队列
'rdkafka' => [
'driver' => 'rdkafka',
'brokers' => env('KAFKA_BROKERS', 'localhost'),
'topic' => env('KAFKA_TOPIC', 'default_topic'),
'group_id' => env('KAFKA_GROUP_ID', 'default_group'),
'security_protocol' => 'plaintext', // 可选配置,根据实际情况设置,安全协议,用于与 Kafka 代理进行通信的协议,plaintext,表示明文通信,可以根据实际情况设置其他支持的安全协议,例如 ssl 或 sasl_ssl
'sasl_mechanisms' => null, // 可选配置,根据实际情况设置
'sasl_username' => null, // 可选配置,根据实际情况设置
'sasl_password' => null, // 可选配置,根据实际情况设置
'commit_async' => true, // 可选配置,根据实际情况设置
],
],
<?php
namespace App\Jobs;
use Enqueue\RdKafka\RdKafkaContext;
use Illuminate\Contracts\Queue\ShouldQueue;
use Illuminate\Foundation\Bus\Dispatchable;
use Illuminate\Queue\InteractsWithQueue;
use Illuminate\Queue\SerializesModels;
use Illuminate\Support\Facades\Log;
class KafkaMessage implements ShouldQueue
{
use Dispatchable, InteractsWithQueue, SerializesModels;
protected $message;
/**
* Create a new job instance.
*
* @param string $message
* @return void
*/
public function __construct(string $message)
{
$this->message = $message;
}
/**
* Execute the job.
*
* @return void
*/
public function handle()
{
Log::info('Received Kafka message: ' . $this->message);
}
}
以下是一个示例,演示如何将消息推送到 Kafka 队列:
<?php
namespace App\Http\Controllers;
use App\Jobs\ProcessKafkaMessage;
use Illuminate\Http\Request;
class KafkaController extends Controller
{
public function sendMessage(Request $request)
{
$message = $request->input('message');
KafkaMessage::dispatch($message)
->onQueue('kafka')
->delay(now()->addSeconds(5));
return response()->json(['message' => 'Message sent to Kafka']);
}
}
在这个示例中,将接收到的消息作为参数传递给 KafkaMessage
作业,并将作业推送到名为 "kafka" 的队列上,并设置了延迟时间为 5 秒。
当消息被推送到 Kafka 队列后,作业将自动从队列中获取并执行。在示例中,作业会将接收到的消息记录到日志文件中。
这是一个简单的示例,以演示在 Laravel 中使用 Kafka 消息队列。你可以根据自己的需求进行修改和扩展。记得在使用 Kafka 之前,确保已经设置好正确的 Kafka 连接和主题配置。
在 Laravel 中,你可以使用 queue:work
Artisan 命令来监听 Kafka 消息队列并处理消息。以下是监听 Kafka 消息队列的步骤:
打开终端,并在项目根目录下执行以下命令来启动 Kafka 消息队列监听器:
php artisan queue:work kafka --queue=kafka
这里建议使用Superviso进程管理消息队列监听,可以看我这篇文章,有详细说明:Laravel 队列监听Superviso进程管理(消息队列后台监听)-CSDN博客
有话要说