CC00007.kafka——|Hadoop&kafka.V07|——|kafka.v07|生产与消费.v02|

一、Kafka开发实战

 

### --- [kafka架构与实战]

~~~     [kakfa开发实战_消息发送]
~~~     [kafka开发实战_消息消费]
### --- 消息的发送与接收

~~~     生产者主要的对象有: KafkaProducer , ProducerRecord 。
~~~     其中KafkaProducer 是用于发送消息的类, ProducerRecord 类用于封装Kafka的消息。
二、KafkaProducer 的创建需要指定的参数和含义:
### --- KafkaProducer 的创建需要指定的参数和含义:

~~~     其他参数可以从org.apache.kafka.clients.producer.ProducerConfig 
~~~     中找到我们后面的内容会介绍到。
~~~     消费者生产消息后,需要broker端的确认,可以同步确认,也可以异步确认。
~~~     同步确认效率低,异步确认效率高,但是需要设置回调对象。
参数说明
bootstrap.servers配置生产者如何与broker建立连接。该参数设置的是初始化参数。
如果生产者需要连接的是Kafka集群,则这里配置集群中几个broker的地址,而不是全部,
当生产者连接上此处指定的broker之后,在通过该连接发现集群中的其他节点。
key.serializer要发送信息的key数据的序列化类。
设置的时候可以写类名,也可以使用该类的Class对象。
value.serilizeracks要发送消息的alue数据的序列化类。
设置的时候可以写类名,也可以使用该类的Class对象。
acks默认值:all。acks=0:
生产者不等待broker对消息的确认,只要将消息放到缓冲区,就认为消息已经发送完成。
该情形不能保证broker是否真的收到了消息,retries配置也不会生效。
发送的消息的返回的消息偏移量永远是-1。
acks=1
表示消息只需要写到主分区即可,然后就响应客户端,而不等待副本分区的确认。
在该情形下,如果主分区收到消息确认之后就宕机了,
而副本分区还没来得及同步该消息,则该消息丢失。
acks=all
首领分区会等待所有的ISR副本分区确认记录。
该处理保证了只要有一个ISR副本分区存活,消息就不会丢失。
这是Kafka最强的可靠性保证,等效于acks=-1
retriesretries重试次数
当消息发送出现错误的时候,系统会重发消息。跟客户端收到错误时重发一样。
如果设置了重试,还想保证消息的有序性,需要设置
MAX_IN_FLIGHT_REQUESTS_PER_CONNECTION=1
否则在重试此失败消息的时候,其他的消息可能发送成功了
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

yanqi_vip

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值