Kafka宕机引发的高可用问题

问题要从一次Kafka的宕机开始说起。

笔者所在的是一家金融科技公司,但公司内部并没有采用在金融支付领域更为流行的RabbitMQ,而是采用了设计之初就为日志处理而生的Kafka,所以我一直很好奇Kafka的高可用实现和保障。从Kafka部署后,系统内部使用的Kafka一直运行稳定,没有出现不可用的情况。

但最近系统测试人员常反馈偶有Kafka消费者收不到消息的情况,登陆管理界面发现三个节点中有一个节点宕机挂掉了。但是按照高可用的理念,三个节点还有两个节点可用怎么就引起了整个集群的消费者都接收不到消息呢?

要解决这个问题,就要从Kafka的高可用实现开始讲起。

面试准备

不论是校招还是社招都避免不了各种面试、笔试,如何去准备这些东西就显得格外重要。 运筹帷幄之后,决胜千里之外!不打毫无准备的仗,我觉得大家可以先从下面几个方面来准备面试:

1. 自我介绍。(介绍自己的项目经历以及一些特长而不是简单自我介绍喜好等)

2. 自己面试中可能涉及哪些知识点、那些知识点是重点。

3. 面试中哪些问题会被经常问到、面试中自己该如何回答。

4. 自己的简历该如何写。

“80%的offer掌握在20%的人手中” 这句话也不是不无道理的。决定你面试能否成功的因素中实力固然占有很大一部 分比例,但是如果你的心态或者说运气不好的话,依然无法拿到满意的 offer。运气暂且不谈,就拿心态来说,千万 不要因为面试失败而气馁或者说怀疑自己的能力,面试失败之后多总结一下失败的原因,后面你就会发现自己会越来 越强大。

另外,大家要明确的很重要的几点是:

1. 写在简历上的东西一定要慎重,这可能是面试官大量提问的地方;

2. 将自己的项目经历完美的展示出来非常重要。

常见面试问题及范围如下

Java基础

  1. 重载和重写的区别

  2. String 和 StringBuffer、StringBuilder 的区别是什么?String 为什么是不可变的?

  3. 自动装箱与拆箱

  4. == 与 equals

  5. final 关键字

  6. Object类的常见方法

  7. Java 中的异常处理

  8. 获取用键盘输入常用的的两种方法

  9. 接口和抽象类的区别是什么

集合框架

  1. Arraylist 与 LinkedList 异同

  2. ArrayList 与 Vector 区别

  3. HashMap的底层实现

  4. HashMap 和 Hashtable 的区别

  5. HashMap 的长度为什么是2的幂次方

  6. HashMap 多线程操作导致死循环问题

  7. HashSet 和 HashMap 区别

  8. ConcurrentHashMap 和 Hashtable 的区别

  9. ConcurrentHashMap线程安全的具体实现方式/底层具体实现

多线程与并发

  1. AQS 原理

  2. AQS 对资源的共享方式

  3. AQS底层使用了模板方法模式

  4. 说一说自己对于 synchronized 关键字的了解

  5. 说说自己是怎么使用 synchronized 关键字,在项目中用到了吗

  6. 讲一下 synchronized 关键字的底层原理

  7. 说说 JDK1.6 之后的synchronized 关键字底层做了哪些优化,可以详细介绍一下这些优化吗

  8. 谈谈 synchronized和ReenTrantLock 的区别

  9. 说说 synchronized 关键字和 volatile 关键字的区别

  10. 为什么要用线程池?

  11. 实现Runnable接口和Callable接口的区别

  12. 执行execute()方法和submit()方法的区别是什么呢?

  13. 如何创建线程池

  14. 介绍一下Atomic 原子类

  15. JUC 包中的原子类是哪4类?

  16. 讲讲 AtomicInteger 的使用

  17. 能不能给我简单介绍一下 AtomicInteger 类的原理

JVM

  1. Java 中会存在内存泄漏吗,简述一下?

  2. 描述一下 JVM 加载 Class 文件的原理机制?

  3. 什么是tomcat类加载机制?

  4. 类加载器双亲委派模型机制?

  5. 垃圾回收常见问题

  6. 什么是GC? 为什么要有 GC?

  7. 简述一下Java 垃圾回收机制?

  8. 如何判断一个对象是否存活?

  9. 垃圾回收的优点和原理,并考虑 2 种回收机制?

  10. Java 中垃圾收集的方法有哪些?

  11. 讲讲你理解的性能评价及测试指标?

  12. 常用的性能优化方式有哪些?

网络编程与操作系统

  1. TCP、UDP 协议的区别

  2. 在浏览器中输入url地址 ->> 显示主页的过程

  3. 各种协议与HTTP协议之间的关系

  4. HTTP长连接、短连接

  5. TCP 三次握手和四次挥手(面试常客)

  6. 简单介绍一下 Linux 文件系统?

  7. 一些常见的 Linux 命令了解吗?

MySQL

  1. 说说自己对于 MySQL 常见的两种存储引擎:MyISAM与InnoDB的理解?

  2. 数据库索引了解吗?

  3. 为什么索引能提高查询速度?

  4. Mysql如何为表字段添加索引?

  5. 对于大表的常见优化手段说一下?

Spring

  1. Spring Bean 的作用域

  2. Spring 事务中的隔离级别

  3. Spring 事务中的事务传播行为

  4. AOP是什么?

  5. IOC是什么?

分布式

  1. 为什么要用 redis缓存?

  2. 为什么要用 redis 而不用 map/guava 做缓存?

  3. redis 和 memcached 的区别?

  4. redis 常见数据结构以及使用场景分析?(String,Hash,List,Set,Sorted Set)

  5. redis 设置过期时间

  6. redis 内存淘汰机制(MySQL里有2000w数据,Redis中只存20w的数据,如何保证Redis中的数据都是热点数据?)

  7. redis 持久化机制(怎么保证 redis 挂掉之后再重启数据可以进行恢复)?

  8. redis 事务

  9. 缓存雪崩和缓存穿透问题解决方案

  10. 如何解决 Redis 的并发竞争 Key 问题

  11. 如何保证缓存与数据库双写时的数据一致性?

  12. 什么是消息队列?为什么要用消息队列?

  13. 通过异步处理提高系统性能(削峰、减少响应所需时间)

  14. 降低系统耦合性

  15. 使用消息队列带来的一些问题

  16. JMS两种消息模型

  17. JMS 五种不同的消息正文格式

  18. 常见的消息队列对比

  19. 什么是 Dubbo?为什么要用 Dubbo?

  20. 什么是 RPC?RPC原理是什么?

  21. Dubbo 工作原理?

  22. 解释一下什么是负载均衡?

  23. 看看 Dubbo 提供的负载均衡策略?

  24. zookeeper宕机与dubbo直连的情况?

总结

总体来说,如果你想转行从事程序员的工作,Java开发一定可以作为你的第一选择。但是不管你选择什么编程语言,提升自己的硬件实力才是拿高薪的唯一手段。

如果你以这份学习路线来学习,你会有一个比较系统化的知识网络,也不至于把知识学习得很零散。我个人是完全不建议刚开始就看《Java编程思想》、《Java核心技术》这些书籍,看完你肯定会放弃学习。建议可以看一些视频来学习,当自己能上手再买这些书看又是非常有收获的事了。

这些视频如果需要的话,可以无偿分享给大家,点击这里即可免费领取

件实力才是拿高薪的唯一手段。

如果你以这份学习路线来学习,你会有一个比较系统化的知识网络,也不至于把知识学习得很零散。我个人是完全不建议刚开始就看《Java编程思想》、《Java核心技术》这些书籍,看完你肯定会放弃学习。建议可以看一些视频来学习,当自己能上手再买这些书看又是非常有收获的事了。

这些视频如果需要的话,可以无偿分享给大家,点击这里即可免费领取

Java面试题!5年经验Java程序员面试27天,看看这篇文章吧!相关推荐

  1. 直接上干货!5年经验Android程序员面试27天,大厂直通车!

    前言 我最近在筹备Android面试的相关文章,我发现,Framework是一个十分重要的点,被不少大厂所看重. 如图,这是我们的一个技术交流群里面的对话↓↓↓ 前阵子我写的Android技术文里面, ...

  2. 阿里P8亲自讲解!5年经验Android程序员面试27天,附答案

    前言 2020年,互联网裁员潮下,我度过了人生中最清晰的半年. 今年我本命年,熬过了程序员35的坎,却在36岁被公司破产来了当头一棒,领完了当月份的工资,老板,也是我哥们的老李走进我的办公室,没有迂回 ...

  3. 膜拜大佬!5年经验Android程序员面试27天,高级面试题+解析

    前言 网上关于启动优化的文章多不胜数,内容千篇一律,大都是列举一些耗时操作,采用异步加载.懒加载等. 而在面试过程中,关于启动优化的问题,如果只是很表面地回答耗时操作应该放在子线程,显然太过于普通,无 ...

  4. 5年经验Android程序员面试27天,大厂直通车!

    前言 我最近在筹备Android面试的相关文章,我发现,Framework是一个十分重要的点,被不少大厂所看重. 如图,这是我们的一个技术交流群里面的对话↓↓↓ 前阵子我写的Android技术文里面, ...

  5. iOS开发:SQLite使用,5年经验Android程序员面试27天

    * 什么是主键 * 主键(Primary Key,简称PK)用来唯一地标识某一条记录 * 例如t_student可以增加一个id字段作为主键,相当于人的身份证 * 主键可以是一个字段或多个字段 16. ...

  6. java只会用不知道原理6_程序员面试宝典之14道初级Java面试题分享

    程序员面试宝典之14道初级Java面试题分享 程序员面试宝典之14道初级Java面试题分享! 关于赢在面试的Java题系列基本收集整理完成了,所有题目都是经过精心挑选的,很基础又考验求职者的基本功,应 ...

  7. java中10d是什么意思_java程序员面试自我介绍

    java程序员面试自我介绍 当面试考官随便地问你:"谈谈你自己的情况如何?"这是面试中的第一个问题.此刻,你应把在此之前所有紧张不安的情绪稳定下来.因为这个问题,应试者已经做了充分 ...

  8. 最近整理的一些常见的面试题,面试大全,黑马程序员面试宝典题库---最新技术--篇

    第八章 最新技术(评论区留言获取原件) 一. Redis 1. Redis 的特点? Redis 是由意大利人 Salvatore Sanfilippo(网名: antirez)开发的一款内存高速缓存 ...

  9. 最近整理的一些常见的面试题,面试大全,黑马程序员面试宝典题库---框架--篇

    框架(评论留言获取原件) 一. SpringMVC 1. SpringMVC 的工作原理 a. 用户向服务器发送请求,请求被 springMVC 前端控制器 DispatchServlet 捕获: b ...

  10. 毕业半年无工作经验的程序员面试会遇到哪些问题

    本人小菜鸟一个,学的java后端,老家江西坐标上海,20届普本软件工程毕业生,种种原因导致21年1月底才开始找工作,基础学的一般,开个贴记录下面试遇到的问题,慢慢提升自己,大部分答案都是百度的 202 ...

最新文章

  1. ecshop 商品颜色尺寸仿淘宝选择功能教程(2.7.0版本)
  2. button点击改变颜色_【干货】眉笔颜色要选对,三步教你选择正确眉色
  3. 解决安装linux时未挂载文件而导致的重启失败
  4. @ngrx入坑angular的schema,爽的一逼!
  5. socket模拟http的登陆_利用 Python + Selenium 实现自动登陆签到
  6. windows+mysql+解压版_Windows操作系统安装MySQL解压版
  7. 磐石云服务器_磐石云爆款高防云服务器3年仅699元 限量100台 BGP线路 1核2G
  8. LeetCode 965单值二叉树-简单
  9. opencv之在图像上绘制标记---drawMarker
  10. MATLAB中如何取整
  11. python哪个版本好用-python用哪个版本好
  12. mysql execute stmt_[转载]MySql 数据库--stmt语句
  13. 叮咚:分享一款超棒的模组:IDO-SOM6Y08
  14. keycloak 的配置与ftl模板文件的表达式相互关联
  15. Google ArCode官网 ARCode支持机型
  16. 无线网络有信号显示未连接网络连接服务器,路由器无线网络受限制或无连接怎么办...
  17. jzojs 100047. 【NOIP2017提高A组模拟7.14】基因变异
  18. 热模块替换/热更新 HMR
  19. jzoj 4246【五校联考6day2】san
  20. JS中如何取某个指定字符(前)后的字符串

热门文章

  1. 智慧校园整体解决方案
  2. Java面试之项目介绍
  3. MATLAB 和 Python 建模和仿真
  4. 【MATLAB图像融合】[18]双通道PCNN模型实现图像融合
  5. cad尺寸标注快捷键_CAD中还能这样快速标注尺寸?怪不得同事天天准时下班
  6. PICT-测试用例生成工具
  7. 我珍藏很久的网盘资源搜索网站和下载神器
  8. 3G是IPv6的3G(转)
  9. 钢构件建筑材料英国UKCA认证—EN 13381-8
  10. c语言实用程序6,C语言实用程序设计100例流程图