1 安装方法以及相关库文件

  https://github.com/edenhill/librdkafka

2

  • High-level producer
  • High-level consumer
  • Simple (Low-level) consumer
  • 压缩:snappy, gzip, lz4
  • SSL
  • SASL

  consumer有两套API,高级(high-level)和底层(simple)的,应该叫底层API或者低级API,它跟高级API的区别是没有自动负载均衡,而高级API会自动进行负载均衡。

3 kafka主要的用途

  发数据---->producer

    //发一条

    rd_kafka_produce()

    //发多条

    rd_kafka_produce_batch()

  收数据---->consumer

  在收发数据之前至少需要一个统一的句柄,方便kafka内部准备好链接brokers集群,初始化kafka内部结构等

  

  建立这个kafka句柄需要知道连接到哪个broker

  

  发布消息使用rd_kafka_top_t, 

  1. // 对rd_kafka_topic_partition_list_t结构的操作
  2. // 创建
  3. rd_kafka_topic_partition_list_new();
  4. // 增加元素
  5. rd_kafka_topic_partition_list_add();
  6. // 删除元素
  7. rd_kafka_topic_partition_list_del();
  8. // 查找元素
  9. rd_kafka_topic_partition_list_find();
  10.  
  11. // 对rd_kafka_topic_t的操作
  12. // 创建
  13. rd_kafka_topic_new();
  14. // 删除
  15. rd_kafka_topic_destroy();
  16. // 获取该topic的名字
  17. rd_kafka_topic_name();
  18. // 获取该topic传入的应用参数
  19. rd_kafka_topic_opaque();
  20.  
  21. // 使用rd_kafka_topic_partition_list_t的时候,topic+partition是连在一起的,
  22. // 所以给kafka句柄的时候只用一个参数就够了
  23. // 订阅消息
  24. rd_kafka_subscribe (rd_kafka_t *rk,
  25. const rd_kafka_topic_partition_list_t *topics);
  26. // 指定消费的partition,可以在运行时更换
  27. rd_kafka_assign (rd_kafka_t *rk,
  28. const rd_kafka_topic_partition_list_t *partitions);
  29.  
  30. // 用rd_kafka_topic_t比较麻烦,需要配合一个partition才行
  31. // 直接启动consumer了
  32. rd_kafka_consume_start(rd_kafka_topic_t *rkt, int32_t partition,
  33. int64_t offset);
  34. // 每次接收也要带上partition
  35. rd_kafka_message_t *rd_kafka_consume(rd_kafka_topic_t *rkt, int32_t partition,
  36. int timeout_ms);
  37.  
  38. // 发送的时候使用 rd_kafka_topic_t
  39. int rd_kafka_produce(rd_kafka_topic_t *rkt, int32_t partition,
  40. int msgflags,
  41. void *payload, size_t len,
  42. const void *key, size_t keylen,
  43. void *msg_opaque);

后续用了继续做笔记,关于错误处理,topic_partition_list操作等

https://blog.csdn.net/lijinqi1987/article/details/76582067

http://suntus.github.io/2016/07/07/librdkafka--kafka%20C%20api%E4%BB%8B%E7%BB%8D/

kafka之c接口常用API------librdkafka的更多相关文章

  1. Kafka命令行操作及常用API

    一.Kafka命令行操作 1.查看当前集群已存在的主题 bin/kafka-topic.sh --zookeeper hd09-01:2181 --list 2.创建主题 bin/kafka-topi ...

  2. 常用API接口汇总

    下面列举了100多个国内常用API接口,并按照 笔记.出行.词典.电商.地图.电影.即时通讯.开发者网站.快递查询.旅游.社交.视频.天气.团队协作.图片与图像处理.外卖.消息推送.音乐.云.语义识别 ...

  3. Java基础学习笔记十二 类、抽象类、接口作为方法参数和返回值以及常用API

    不同修饰符使用细节 常用来修饰类.方法.变量的修饰符 public 权限修饰符,公共访问, 类,方法,成员变量 protected 权限修饰符,受保护访问, 方法,成员变量 默认什么也不写 也是一种权 ...

  4. Spring Boot入门(四):开发Web Api接口常用注解总结

    本系列博客记录自己学习Spring Boot的历程,如帮助到你,不胜荣幸,如有错误,欢迎指正! 在程序员的日常工作中,Web开发应该是占比很重的一部分,至少我工作以来,开发的系统基本都是Web端访问的 ...

  5. 常用API接口

    引用  常用API接口汇总

  6. Map容器——TreeMap及常用API,Comparator和Comparable接口

    TreeMap及常用API ①   TreeMap类通过使用红黑树实现Map接口; ②   TreeMap提供按排序顺序存储键/值对的有效手段,同时允许快速检索; ③   不像散列(HashMap), ...

  7. kafka系列九、kafka事务原理、事务API和使用场景

    一.事务场景 最简单的需求是producer发的多条消息组成一个事务这些消息需要对consumer同时可见或者同时不可见 . producer可能会给多个topic,多个partition发消息,这些 ...

  8. java基础3.0:Java常用API

    本篇介绍Java基础中常用API使用,当然只是简单介绍,围绕重要知识点引入,巩固开发知识,深入了解每个API的使用,查看JavaAPI文档是必不可少的. 一.java.lang包下的API Java常 ...

  9. 【OpenGL游戏开发之二】OpenGL常用API

    OpenGL常用API 开发基于OpenGL的应用程序,必须先了解OpenGL的库函数.它采用C语言风格,提供大量的函数来进行图形的处理和显示.OpenGL库函数的命名方式非常有规律.所有OpenGL ...

随机推荐

  1. 【四】MongoDB索引管理

    一.索引介绍 在mongodb中,索引用来支持高效查询.如果没有索引,mongodb必须在整个集合中扫描每个文档来查找匹配的文档.但是如果建立合适的索引,mongodb就可以通过索引来限制检查的文档数 ...

  2. in型子查询陷阱,exists子查询

    in 型子查询引出的陷阱 select goods_id from goods where cat_id in (1,2,3) 直接用id,不包含子查询,不会中陷阱 题: 在ecshop商城表中,查询 ...

  3. java 获取访问主机的ip地址

    Java的api的说法: getHeader public java.lang.String getHeader(java.lang.String name) Return the first val ...

  4. Oracle的控制文件和日志文件

    --什么是控制文件 控制文件是数据库的一个二进制文件,它主要记录数据库的名称. 数据库的数据文件存放位置等信息. 一个控制文件只能属于一个数据库.如果控制文件丢失,这数据库就无法操作. --下面查询语 ...

  5. HIVE- 数据倾斜

    数据倾斜就是由于数据分布不均匀,数据大量集中到一点上,造成数据热点.大多数情况下,分为一下三种情况: 1.map端执行比较快,reduce执行很慢,因为partition造成的数据倾斜. 2.某些re ...

  6. matlab点云处理函数

    1. pcread: 输入文件名,返回pointCloud类(用于存储点云).eg: pcloud = pcread(“filename.ply”) 2. pcshow: 输入pointCloud类, ...

  7. Linux各个文件夹的主要作用 (源地址

    (源地址blog.csdn.net/lonelysky/article/details/5374230,侵删) linux下的文件结构,看看每个文件夹都是干吗用的 /bin 二进制可执行命令 /dev ...

  8. C#中substring ()的用法

    C#中substring ()的用法:http://www.cnblogs.com/bluespace/archive/2007/12/11/782336.html

  9. 与STL文件相关的各类学习地址

    几个网址: 1.STL :https://en.wikipedia.org/wiki/STL_(file_format)#ASCII_STL 2.一个博客的文章地址: 三维图形数据格式 STL的 读取 ...

  10. sublime text _注册码

    转自:https://9iphp.com/web/html/sublime-text-3-license-key.html 使用方法 打开 Sublime Text 3 的 “Help”–“Enter ...