美文网首页
PHP 中使用Kafka

PHP 中使用Kafka

作者: 年糕大侠 | 来源:发表于2020-04-01 19:59 被阅读0次
3个问题
  1. 安装 :
    a. 看kafka官方文档会知道,kafka主要给java用的,其他的语言多是通过c/c++的api来间接调用的,所以很显然要做的事情就是安装PHP的扩展(使用c的api),另外也有封装好的PHP包(使用PHP的api)
    b. 自己撸
    https://github.com/edenhill/librdkafka
    https://github.com/arnaud-lb/php-rdkafka
  2. 使用
    使用方面其实无外乎一进一出,能进能出就算体验了一把。
    其实Github上已经给了例子了,我这里copy一下,重点是现在很多网上的文章在入的时候呢,总是采用了循环,反复入,看着挺好,自己真用起来,发现就想入一下的时候问题就来了。这个放到注意事项里面说,先看正确姿势:
<?php
### 创建producer
$conf = new RdKafka\Conf();
$conf->set('log_level', (string) LOG_DEBUG);
$conf->set('debug', 'all');
$rk = new RdKafka\Producer($conf);
$rk->addBrokers("10.0.0.1:9092,10.0.0.2:9092");
### 创建topic
$topic = $rk->newTopic("test");
### 创建message
$topic->produce(RD_KAFKA_PARTITION_UA, 0, "Message payload");
### !!!你发不成功的!!!
  1. 注意事项
    其实但凡你把别人的用例往下看下,你就会发现别人已经温馨提示了: 小心消息丢失
    先说结果,加上后面两句,你就可以发成功了
$producer->poll(0);
$result = $producer->flush(10000);
  1. 为什么?
    可能你根本不会看到这里来,当然也不排除会跟我遇到一样困惑的人:我这里简单说 3 句话:
    a. 发消息是异步的
    b. 网上其他的demo中(死)循环有一定的迷惑性,你很有可能没注意他每次循环的sleep,或者你会误解这个sleep到底是干什么的,其实就是变相保证消息能发送完;但是你在实际业务当中不一定会是循环发消息,所以很有可能你去掉循环的时候把sleep也去掉了,然后就懵了。
    c. 这个flush后面10000(ms),并不会让你等那么久

  2. 总结
    撸官网!撸官网!撸官网!

不知道有多少人抱着有东西就搜博客来解决,这个没问题,在开搞之前,调研的时候,随便搜搜、随便看看,了解一下是个什么东西没问题,真正动手的时候,看官网的东西绝对是捷径,从最终来看绝对是捷径!就算感觉看不懂英文,没事儿,我也不安慰你,因为你活该,who cares,但是你要撸他的示例代码。就这,over。

相关文章

  • 使用php连接操作kafka

    使用php连接操作kafka,从安装kafka到引入php扩展来操作kafka。 一、安装 注:需安装JDK 1....

  • php 使用kafka

    准备工作 安装librdkafka 库 安装php-rdkafka 扩展 编码实现 生产者 代码实现 检验发送是否...

  • php使用kafka

    Ⅰ、kafka扩展安装参考[https://www.jianshu.com/p/c3eea6f43c4d] Ⅱ、代...

  • 消息中间件Kafka - PHP操作使用Kafka

    PHP使用Kafka 我们需要安装libkafka和rdkafka 安装libkafka 下载去GitHub上克隆...

  • PHP安装使用kafka

    1.安装java环境并配置环境变量2.下载kafka安装包并解压3.安装librdkafka库 4.安装php-r...

  • php中使用kafka

    早想用消息队列了,但是一直没有动手今天搞起来 安装kafka wget https://mirror.bit.ed...

  • PHP 中使用Kafka

    3个问题 安装 :a. 看kafka官方文档会知道,kafka主要给java用的,其他的语言多是通过c/c++的a...

  • PHP使用kafka入门

    第一步,kafka安装使用入门 0:环境准备,Linux环境(CentOS为例),wget命令,git命令,jav...

  • Kafka的知识点梳理

    Kafka的用途有哪些?使用场景如何? Kafka中的ISR、AR又代表什么?ISR的伸缩又指什么 Kafka中的...

  • kafka php版本

    https://github.com/search?l=PHP&q=kafka-php&type=Reposito...

网友评论

      本文标题:PHP 中使用Kafka

      本文链接:https://www.haomeiwen.com/subject/fjtzuhtx.html