• [酷]比西方国家的预约排队制要高明多了! 2019-03-21
  • 普京力挽狂澜,从北高加索平叛到格鲁吉亚兴兵,从克里米亚回归到叙利亚反恐,给了俄罗斯人民新生——这一切都是和中国同志的支持分不开的。 2019-03-18
  • 合肥:敬业医生头天接受手术 次日打着吊瓶工作 2019-03-18
  • “一带一路”中小企业国际合作高峰论坛三大亮点 2019-03-14
  • “自己做不到的事情,还看不得别人做”.....好像目前正在热议的特朗谱长公主伊万卡在推特上引用的一句“中国谚语”.....巧合吗? 2019-03-14
  • 山西拨付2.7亿元资金支持全省七大河流生态修复治理 2019-03-06
  • 【诗会马克思】第四期 :《怪影》节选 2019-02-21
  • 端午节山东无高温、无大雨 整体在30℃左右 2019-02-14
  • 香港特区立法会通过广深港高铁“一地两检”条例草案--旅游频道 2019-02-14
  • 捷途X70X70S正式下线 将于第3季度上市 2019-01-08
  • 2016环球医院院长领导力闭门会议 2019-01-08
  • 福彩3d开奖结果走势图:Nginx整合Kafka的方法示例

    文章TAG:nginx 整合 Kafka
    时间:2018-11-14来源/作者:兴趣e族 编辑:源码库 文章热度:

    山西十一选五遗漏10 www.fqjb.net 背景

    nginx-kafka-module是nginx的一个插件,可以将kafka整合到nginx中,便于web项目中前端页面埋点数据的收集,如前端页面设置了埋点,即可将用户的一些访问和请求数据通过http请求直接发送到消息中间件kafka中,后端可以通过程序消费kafka中的消息来进行实时的计算。比如通过SparkStream来实时的消费Kafka中的数据来分析用户PV,UV、用户的一些行为及页面的漏斗模型转化率,来更好的对系统进行优化或者对来访用户进行实时动态的分析。

    具体整合步骤

    1.安装git

    yum install -y git

    2.切换到/usr/local/src目录,然后将kafka的c客户端源码clone到本地

    cd /usr/local/src
    git clone https://github.com/edenhill/librdkafka

    3.进入到librdkafka,然后进行编译

    cd librdkafka
    yum install -y gcc gcc-c++ pcre-devel zlib-devel
    ./configure
    make && make install

    4.安装nginx整合kafka的插件,进入到/usr/local/src,clone nginx整合kafka的源码

    cd /usr/local/src
    git clone https://github.com/brg-liuwei/ngx_kafka_module
    

    5.进入到nginx的源码包目录下 (编译nginx,然后将将插件同时编译)

    cd /usr/local/src/nginx-1.12.2
    ./configure --add-module=/usr/local/src/ngx_kafka_module/
    make && make install
    

    6.修改nginx的配置文件:设置一个location和kafaka的topic,详情请查看当前目录的nginx.conf

    #添加配置(2处)
    kafka;
    kafka_broker_list f1:9092 f2:9092 f3:9092;
    
    location = /kafka/access {
    kafka_topic access888;
    }
    

    如下图:

    Nginx,整合,Kafka

    Nginx,整合,Kafka

    7.启动zk和kafka集群(创建topic)

    zkServer.sh start
    kafka-server-start.sh -daemon config/server.properties
    

    8.启动nginx,报错,找不到kafka.so.1的文件

    error while loading shared libraries: librdkafka.so.1: cannot open shared object file: No such file or directory

    9.加载so库

    #开机加载/usr/local/lib下面的库
    echo "/usr/local/lib" >> /etc/ld.so.conf
    #手动加载
    ldconfig

    10.测试,向nginx中写入数据,然后观察kafka的消费者能不能消费到数据

    curl //localhost/kafka/access -d "message send to kafka topic"
    curl //localhost/kafka/access -d "小伟666"测试

    也可以模拟页面埋点请求接口来发送信息:

    Nginx,整合,Kafka

    后台Kafka消费信息如图:

    Nginx,整合,Kafka

    以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持ASPKU源码库。


    注:相关教程知识阅读请移步到服务器教程频道。
    相关服务器教程
    热门标签

    服务器教程Rss订阅服务器教程搜索

  • [酷]比西方国家的预约排队制要高明多了! 2019-03-21
  • 普京力挽狂澜,从北高加索平叛到格鲁吉亚兴兵,从克里米亚回归到叙利亚反恐,给了俄罗斯人民新生——这一切都是和中国同志的支持分不开的。 2019-03-18
  • 合肥:敬业医生头天接受手术 次日打着吊瓶工作 2019-03-18
  • “一带一路”中小企业国际合作高峰论坛三大亮点 2019-03-14
  • “自己做不到的事情,还看不得别人做”.....好像目前正在热议的特朗谱长公主伊万卡在推特上引用的一句“中国谚语”.....巧合吗? 2019-03-14
  • 山西拨付2.7亿元资金支持全省七大河流生态修复治理 2019-03-06
  • 【诗会马克思】第四期 :《怪影》节选 2019-02-21
  • 端午节山东无高温、无大雨 整体在30℃左右 2019-02-14
  • 香港特区立法会通过广深港高铁“一地两检”条例草案--旅游频道 2019-02-14
  • 捷途X70X70S正式下线 将于第3季度上市 2019-01-08
  • 2016环球医院院长领导力闭门会议 2019-01-08