JavaGuide面试突击版笔记(三)

Kafka

  • Kafka 是⼀个分布式流式处理平台,主要有两⼤应⽤场景:消息队列、数据处理
  • 和其他消息队列相⽐,Kafka的优势在哪⾥
  1. 极致的性能 :基于 Scala Java 语⾔开发,设计中⼤量使⽤了批量处理和异步的思想
  2. ⽣态系统兼容性很好
  • Kafka 的多分区(Partition)以及多副本(Replica)机制有什么好处
  1. Kafka 通过给特定 Topic 指定多个 Partition, ⽽各个 Partition 可以分布在不同的 Broker , 这样便能提供比较好的并发能⼒(负载均衡)
  2.  
    Partition 可以指定对应的 Replica , 这也极⼤地提⾼了消息存储的安全性 , 提⾼了容灾能⼒,不过也相应的增加了所需要的存储空间
  • Kafka 如何保证消息的消费顺序?
  1. 1 Topic 只对应⼀个 Partition
  2. (推荐)发送消息的时候指定 key/Partition
  • ​​​​​​​Kafka 如何保证消息不丢失

​​​​​​​采用回调函数的形式,如果消息发送失败,检查失败原因之后重新发送

 ListenableFuture<SendResult<String, Object>> future =
kafkaTemplate.send(topic, o);
 future.addCallback(result -> logger.info("⽣产者成功发送消息到topic:{}
partition:{}的消息", result.getRecordMetadata().topic(),
result.getRecordMetadata().partition()),
 ex -> logger.error("⽣产者发送消失败,原因:{}",
ex.getMessage()));

回调函数

一般情况下,应用程序会时常通过API调用库里所预先备好的函数。但是有些库函数却要求应用先传给它一个函数,好在合适的时候调用,以完成目标任务。这个被传入的、后又被调用的函数就称为回调函数

回调实际上有两种:阻塞式回调和延迟式回调

下列例子是阻塞式回调

#回调函数1
#生成一个2k形式的偶数
def double(x):
    return x * 2
    
#回调函数2
#生成一个4k形式的偶数
def quadruple(x):
    return x * 4

def getOddNumber(k, getEvenNumber):
    return 1 + getEvenNumber(k)
    
#起始函数,这里是程序的主函数
def main():    
    k = 1
    #当需要生成一个2k+1形式的奇数时
    i = getOddNumber(k, double)
    print(i)
    #当需要一个4k+1形式的奇数时
    i = getOddNumber(k, quadruple)
    print(i)
2020/5月/15好上传最新 JavaGuide 目前已经 70k+ Star ,目前已经是所有 Java 类别项目中 Star 数量第二的开源项目了。Star虽然很多,但是价值远远比不上 Dubbo 这些开源项目,希望以后可以多出现一些这样的国产开源项目。国产开源项目!加油!奥利给! 随着越来越多的人参与完善这个项目,这个专注 “Java知识总结+面试指南 ” 项目的知识体系和内容的不断完善。JavaGuide 目前包括下面这两部分内容: Java 核心知识总结; 面试方向:面试题、面试经验、备战面试系列文章以及面试真实体验系列文章 内容的庞大让JavaGuide 显的有一点臃肿。所以,我决定将专门为 Java 面试所写的文章以及来自读者投稿的文章整理成 《JavaGuide面试突击》 系列,同时也为了更加方便大家阅读查阅。起这个名字也犹豫了很久,大家如果有更好的名字的话也可以向我建议。暂时的定位是将其作为 PDF 电子书,并不会像 JavaGuide 提供在线阅读本。我之前也免费分享过PDF 本的《Java面试突击》,期间一共更新了 3 个本,但是由于后面难以同步和订正所以就没有再更新。《JavaGuide面试突击》 pdf 由于我工作流程的转变可以有效避免这个问题。 另外,这段时间,向我提这个建议的读者也不是一个两个,我自己当然也有这个感觉。只是自己一直没有抽出时间去做罢了!毕竟这算是一个比较耗费时间的工程。加油!奥利给! 这件事情具体耗费时间的地方是内容的排优化(为了方便导出PDF生成目录),导出 PDF 我是通过 Typora 来做的。
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值