PHP Kafka 使用详解

一 安装PHP扩展
1 rdkafka 安装需要依赖 librdkafka , 所以先安装 librdkafka 自定义目录 下载扩展并且安装

git clone https://github.com/edenhill/librdkafka.git

cd librdkafka ## 找到自己的安装路径

./configure

make && make install

2 安装 php-rdkafka 扩展

git clone https://github.com/arnaud-lb/php-rdkafka.git

cd php-rdkafka ## 找到自己的安装路径

/www/server/php/72/bin/phpize ## 这里根据自己安装PHP的路径执行

./configure --with-php-config=/www/server/php/72/bin/php-config  ## 这里根据自己安装的PHP版本情况填写路径

make && make install

3 在PHP配置文件 php-ini 加上

extension = /www/server/php/72/lib/php/extensions/no-debug-non-zts-20170718/rdkafka.so ##找到自己使用的PHP路径 如果安装多个版本的PHP注意要找到项目使用的PHP版本


重启 php-fpm,查看phpinfo() 或者再命令行执行 php -m 查看扩展是否安装成功

在这里插入图片描述
在这里插入图片描述如果php-m找不到扩展 则需在安装的PHP下找到 /www/server/php/72/etc php-cli.ini (此路径为我的PHP安装路径 需要找到你自己的PHP安装路径) 在此配置文件最下端添加extension = /www/server/php/72/lib/php/extensions/no-debug-non-zts-20170718/rdkafka.so

三 安装 Kafka 服务 开放端口 kafka默认9092端口

1 直接到 kafka官网 , 下载最新的

下载后放在服务器项目的自定目录下 解压  可放在/www/server/ 目录下(Linux服务器)

2 使用命令下载

	命令 如没有wget命令则需yum安装
	wget https://mirror.bit.edu.cn/apache/kafka/2.5.0/kafka_2.13-2.5.0.tgz
	解压,进入目录
	tar -zxvf kafka_2.13-2.5.0.tgz
    cd kafka_2.13-2.5.0

四 启动Kafka服务(在放置kafka文件的根目录下执行命令)

1 使用安装包中的脚本启动单节点 Zookeeper 实例   (新版本的kafka已无需执行此命令)
bin/zookeeper-server-start.sh -daemon config/zookeeper.properties
2 使用 kafka-server-start.sh 启动 kafka 服务
 bin/kafka-server-start.sh config/server.properties //普通启动
 
 bin/kafka-server-start.sh -daemon ./config/server.properties //项目上线后需要以守护进程的方式启动

3 创建topic:

bin/kafka-topics.sh --create --bootstrap-server 127.0.0.1:9092 --replication-factor 1 --partitions 1 --topic test

发消息: bin/kafka-console-producer.sh --broker-list 127.0.0.1:9092 --topic test
>hello
>world

监听消息:bin/kafka-console-consumer.sh --bootstrap-server 127.0.0.1:9092 --topic test --from-beginning

五 PHP 使用Kafka

1创建一个生产者类

<?php

class KafkaProducer

{

    public static $brokerList = '127.0.0.1:9092';

    public static function send($message, $topic)

    {

        self::producer($message, $topic);

    }

    public static function producer($message, $topic = 'test')

    {

        $conf = new \RdKafka\Conf();

        $conf->set('metadata.broker.list', self::$brokerList);

        $producer = new \RdKafka\Producer($conf);

        $topic = $producer->newTopic($topic);

        $topic->produce(RD_KAFKA_PARTITION_UA, 0, json_encode($message));

        $producer->poll(0);

        $result = $producer->flush(10000);

        if (RD_KAFKA_RESP_ERR_NO_ERROR !== $result) {

            throw new \RuntimeException('Was unable to flush, messages might be lost!');

        }

    }

}

2 创建一个消费类

<?php

class KafkaConsumer

{

    public static $brokerList = '127.0.0.1:9092';

      public static function consumer()

    {

        $conf = new \RdKafka\Conf();

        $conf->set('group.id', 'test');

        $rk = new \RdKafka\Consumer($conf);

        $rk->addBrokers("127.0.0.1");

        $topicConf = new \RdKafka\TopicConf();

        $topicConf->set('auto.commit.interval.ms', 100);

        $topicConf->set('offset.store.method', 'broker');

        $topicConf->set('auto.offset.reset', 'smallest');

        $topic = $rk->newTopic('test', $topicConf);

        $topic->consumeStart(0, RD_KAFKA_OFFSET_STORED);

        while (true) {

            $message = $topic->consume(0, 120*10000);

            switch ($message->err) {

                case RD_KAFKA_RESP_ERR_NO_ERROR:

                    var_dump($message);

                    break;

                case RD_KAFKA_RESP_ERR__PARTITION_EOF:

                    echo "No more messages; will wait for more\n";

                    break;

                case RD_KAFKA_RESP_ERR__TIMED_OUT:

                    echo "Timed out\n";

                    break;

                default:

                    throw new \Exception($message->errstr(), $message->err);

                    break;

            }

        }

    }

}

问题汇总

1、 No Java runtime present, requesting install

因为 kafka 需要 java 环境支持,所以安装 java 环境。可以到 javase-jdk14-downloads 选择自己的版本进行下载安装

2、创建 topic 出现:Replication factor: 1 larger than available brokers: 0

意思是至少有一个 brokers. 也就是说并没有有效的 brokers 可以用。你要确保你的 kafka 已经启动了

3、如果安装多个PHP版本 配置信息需要配置到项目使用的PHP版本

  • 5
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
@KafkaListener是Spring Kafka提供的注解,用于标识一个方法作为Kafka消息的监听器。它可以与其他注解一起使用,以配置和定制监听器的行为。 @KafkaListener注解的用法如下所示: - id属性用于指定监听器的唯一标识符。 - idIsGroup属性用于指定id是否作为消费者组的一部分。 - topics属性用于指定监听的主题。 - containerFactory属性用于指定用于创建监听容器的工厂。 - concurrency属性用于指定并发消费者的数量。 - clientIdPrefix属性用于指定消费者的客户端ID前缀。 - groupId属性用于指定消费者组的ID。 - properties属性用于指定其他Kafka消费者的属性。 - errorHandler属性用于指定错误处理器。 除了基本的用法外,@KafkaListener还可以与其他注解一起使用,以进一步定制监听器的行为。例如,可以使用@Payload注解指定消息的有效负载类型,以及使用@Valid注解验证有效负载对象。 要使用@KafkaListener注解,您需要在Spring Kafka配置类中添加@Bean注解来创建KafkaListenerContainerFactory bean,并在您的监听器方法上添加@KafkaListener注解。 您还可以使用KafkaListenerEndpointRegistry来获取已注册的所有监听器容器。这可以在需要动态管理和操作监听器时非常有用。 总结起来,@KafkaListener注解提供了一个方便的方式来创建Kafka消息的监听器,并可以使用各种属性和其他注解来定制它们的行为。同时,使用KafkaListenerEndpointRegistry可以方便地管理和操作已注册的监听器容器。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [@KafkaListener详解使用](https://blog.csdn.net/h4241778/article/details/122416366)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *2* *3* [【spring-kafka】@KafkaListener详解使用](https://blog.csdn.net/u010634066/article/details/109803987)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值