2020“闭关”跳槽季,啃透分布式三大技术:限流、缓存、通讯

2023-11-07

01 分布式限流

1.1 Nginx+ZooKeeper面试常备题(附答案)

 

  • 请解释一下什么是 Nginx?

  • 请列举 x Nginx 的一些特性。

  • 请列举 x Nginx 和 和 Apache 之间的不同点

  • 请解释 x Nginx 如何处理 P HTTP 请求。

  • 在 x Nginx 中,如何使用未定义的服务器名称来阻止处理请求?

  • 使用 “ 反向代理服务器 ”

  • 请列举 x Nginx 服务器的最佳用途。

  • 请解释 x Nginx 服务器上的 r Master 和 和 r Worker 进程分别是什么?

  • 请解释你如何通过不同于 0 80 的端口开启 Nginx?

  • 请解释是否有可能将 x Nginx 的错误替换为 2 502 错误?

  • 在 x Nginx 中,解释如何在 L URL 中保留双斜线? ?

  • 请解释 e ngx_http_upstream_module 的作用是什么?

  • 请解释什么是 K C10K 问题?

  • 请陈述 s stub_status 和 和 r sub_filter 指令的作用是什么?

  • 解释 x Nginx 是否支持将请求压缩到上游?

  • 解释如何在 x Nginx 中获得当前的时间?

  • 用 x Nginx 服务器解释s -s 的目的是什么?

  • 解释如何在 x Nginx 服务器上添加模块?

  • ... ...

  • ZooKeeper 是什么?

  • ZooKeeper 提供了什么?

  • Zookeeper 文件系统

  • 四种类型的 znode

  • Zookeeper 通知机制

  • Zookeeper 做了什么?

  • zk 的命名服务(文件系统)

  • zk 的配置管理(文件系统、通知机制)

  • Zookeeper 集群管理(文件系统、通知机制)

  • Zookeeper 分布式锁(文件系统、通知机制)

  • 获取分布式锁的流程

  • Zookeeper 队列管理(文件系统、通知机制)

  • Zookeeper 数据复制

  • Zookeeper 工作原理

  • zookeeper 是如何保证事务的顺序一致性的?

  • Zookeeper 下 Server 工作状态

  • zookeeper 是如何选取主 leader 的?

  • 分布式通知和协调

  • 机器中为什么会有 leader?

  • zk 节点宕机如何处理?

  • Zookeeper 同步流程

  • zookeeper 负载均衡和 nginx 负载均衡区别

  • zookeeper watch 机制

  • ... ...

1.2 Nginx+ZooKeeper学习文档

  • ZooKeeper-分布式过程协同技术详解

  • 深入理解Nginx模块开发与架构解析第2版

02 分布式缓存

2.1 memcached+MongoDB+Redis面试常备题(附答案)

  • memcached 是怎么工作的?

  • memcached 最大的优势是什么?

  • memcached 和服务器的 local cache (比如 PHP 的 的 APC 、mmap 文件等)相比,有什么优缺点?

  • memcached 和 和 MySQL 的 的 query cache 相比,有什么优缺点?

  • memcached 的 的 cache 机制是怎样的?

  • memcached 如何实现冗余机制?

  • 我需要把 memcached 中的 item 批量导出导入,怎么办?

  • memcached 如何处理容错的?

  • 如何将 memcached 中 中 item 批量导入导出?

  • memcached 是如何做身份验证的?

  • memcached 的多线程是什么?如何使用它们?

  • memcached 能接受的 key 的最大长度是多少?

  • memcached 对 对 item 的过期时间有什么限制?

  • memcached 最大能存储多大的单个 item ?

  • 为什么单个 item 的大小被限制在 1M byte 之内?

  • ... ...

  • redis 简介

  • 为什么要用 redis /为什么要用缓存(高性能、高并发)

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

  • redis 和 memcached 的区别

  • redis 常见数据结构以及使用场景分析(String、Hash、List、Set、Sorted Set

  • redis 设置过期时间

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

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

  • redis 事务

  • Redis 常见异常及解决方案(缓存穿透、缓存雪崩、缓存预热、缓存降级

  • 分布式环境下常见的应用场景(分布式锁、分布式自增 ID

  • Redis 集群模式(主从模式、哨兵模式、Cluster 集群模式

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

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

  • ... ....

  • 你说的 NoSQL 数据库是什么意思?NoSQL 与 RDBMS 直接有什么区别?为什么要使用和不使用NoSQL 数据库?说一说 NoSQL 数据库的几个优点?

  • NoSQL 数据库有哪些类型?

  • MySQL 与 MongoDB 之间最基本的差别是什么?

  • 你怎么比较 MongoDB、CouchDB 及 CouchBase?

  • MongoDB 成为最好 NoSQL 数据库的原因是什么?

  • 32 位系统上有什么细微差别?

  • journal 回放在条目(entry)不完整时(比如恰巧有一个中途故障了)会遇到问题吗?

  • 分析器在 MongoDB 中的作用是什么?

  • 名字空间(namespace)是什么?

  • 如果用户移除对象的属性,该属性是否从存储层中删除?

  • 能否使用日志特征进行安全备份?

  • 允许空值 null 吗?

  • 更新操作立刻 fsync 到磁盘?

  • 如何执行事务/加锁?

  • 为什么我的数据文件如此庞大?

  • 启用备份故障恢复需要多久?

  • 什么是 master 或 primary?

  • 什么是 secondary 或 slave?

  • 我必须调用 getLastError 来确保写操作生效了么?

  • 我应该启动一个集群分片(sharded)还是一个非集群分片的 MongoDB 环境?

  • 分片(sharding)和复制(replication)是怎样工作的?

  • 数据在什么时候才会扩展到多个分片(shard)里?

  • 当我试图更新一个正在被迁移的块(chunk)上的文档时会发生什么?

  • 如果在一个分片(shard)停止或者很慢的时候,我发起一个查询会怎样?

  • 我可以把 moveChunk 目录里的旧文件删除吗?

  • 我怎么查看 Mongo 正在使用的链接?

  • 如果块移动操作(moveChunk)失败了,我需要手动清除部分转移的文档吗?

  • 如果我在使用复制技术(replication),可以一部分使用日志(journaling)而其他部分则不使用吗?

  • 当更新一个正在被迁移的块(Chunk)上的文档时会发生什么?

  • MongoDB 在 A:{B,C}上建立索引,查询 A:{B,C}和 A:{C,B}都会使用索引吗?

  • 如果一个分片(Shard)停止或很慢的时候,发起一个查询会怎样?

  • MongoDB 支持存储过程吗?如果支持的话,怎么用?

  • 如何理解 MongoDB 中的 GridFS 机制,MongoDB 为何使用 GridFS 来存储文件?

  • ... ....

2.2 memcached+MongoDB+Redis学习文档

  • MongoDB权威指南

03 分布式通讯

3.1 ActiveMQ+Kafka+RabbitMQ面试常备题(附答案)

  • Kafka 的设计时什么样的呢?

  • 数据传输的事物定义有哪三种?

  • Kafka 判断一个节点是否还活着有那两个条件?

  • producer 是否直接将数据发送到 broker 的 leader(主节点)?

  • Kafa consumer 是否可以消费指定分区消息?

  • Kafka 消息是采用 Pull 模式,还是 Push 模式?

  • Kafka 存储在硬盘上的消息格式是什么?

  • Kafka 高效文件存储设计特点:

  • Kafka 与传统消息系统之间有三个关键区别

  • Kafka 创建 Topic 时如何将分区放置到不同的 Broker 中

  • Kafka 新建的分区会在哪个目录下创建

  • partition 的数据如何保存到硬盘

  • kafka 的 ack 机制

  • Kafka 的消费者如何消费数据

  • 消费者负载均衡策略

  • 数据有序

  • kafaka 生产数据时数据的分组策略

  • ... ...

  • 什么是 ActiveMQ?

  • ActiveMQ 服务器宕机怎么办?

  • 丢消息怎么办?

  • 持久化消息非常慢

  • 消息的不均匀消费。

  • 死信队列。

  • ActiveMQ 中的消息重发时间间隔和重发次数吗?

  • ... ...

  • RabbitMQ 中的 broker 是指什么?cluster 又是指什么?

  • 什么是元数据?元数据分为哪些类型?包括哪些内容?与 cluster 相关的元数据有哪些?元数据是如何保存的?元数据在 cluster 中是如何分布的?

  • RAM node 和 disk node 的区别?

  • RabbitMQ 上的一个 queue 中存放的 message 是否有数量限制?

  • RabbitMQ 概念里的 channel、exchange 和 queue 这些东东是逻辑概念,还是对应着进程实体?这些东东分别起什么作用?

  • vhost 是什么?起什么作用?

  • 在单 node 系统和多 node 构成的 cluster 系统中声明 queue、exchange ,以及进行 binding 会有什么不同?

  • 客户端连接到 cluster 中的任意 node 上是否都能正常工作?

  • cluster 中 node 的失效会对 consumer 产生什么影响?若是在 cluster 中创建了mirrored queue ,这时 node 失效会对 consumer 产生什么影响?

  • 能够在地理上分开的不同数据中心使用 RabbitMQ cluster 么?

  • 为什么 heavy RPC 的使用场景下不建议采用 disk node ?

  • 向不存在的 exchange 发 publish 消息会发生什么?向不存在的 queue 执行consume 动作会发生什么?

  • routing_key 和 binding_key 的最大长度是多少?

  • RabbitMQ 允许发送的 message 最大可达多大?

  • 什么情况下 producer 不主动创建 queue 是安全的?

  • “dead letter”queue 的用途?

  • 为什么说保证 message 被可靠持久化的条件是 queue 和 exchange 具有durable 属性,同时 message 具有 persistent 属性才行?

  • 什么情况下会出现 blackholed 问题?

  • 如何防止出现 blackholed 问题?

  • Consumer Cancellation Notification 机制用于什么场景?

  • Basic.Reject 的用法是什么?

  • 为什么不应该对所有的 message 都使用持久化机制?

  • RabbitMQ 中的 cluster、mirrored queue,以及 warrens 机制分别用于解决什么问题?存在哪些问题?

  • ... ...

3.2 学习文档

  • [中文]分布式系统原理与范型

注意:全部面试问题+学习文档——https://docs.qq.com/doc/DVmdhWUxaTUNYbHBO

总结

今天要分享的三大分布式技术:缓存、通讯、限流就到这里,相关的面试题目以及学习书籍都已整理成下图所示的三个文档, 可以免费分享给大家一起学习

 

《一线互联网大厂Java核心面试题库》GitHub项目:https://github.com/minfei-miffy/Java-mianshi-note

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

2020“闭关”跳槽季,啃透分布式三大技术:限流、缓存、通讯 的相关文章

  • 按键时关闭 ModalWindow

    我希望能够在用户按下某个键 在我的例子中是 ESC 时关闭 ModalWindow 我有一个用于按键的 Javascript 侦听器 它调用取消按钮 ID 的单击事件 jQuery modalWindowInfo closeButtonId
  • 如何将本机库链接到 IntelliJ 中的 jar?

    我正在尝试在 IntelliJ 中设置 OpenCV 但是我一直在弄清楚如何告诉 IntelliJ 在哪里可以找到本机库位置 在 Eclipse 中 添加 jar 后 您可以在 Build Config 屏幕中设置 Native 库的位置
  • Mockito:如何通过模拟测试我的服务?

    我是模拟测试新手 我想测试我的服务方法CorrectionService correctPerson Long personId 实现尚未编写 但这就是它将执行的操作 CorrectionService将调用一个方法AddressDAO这将
  • Junit:如何测试从属性文件读取属性的方法

    嗨 我有课ReadProperty其中有一个方法ReadPropertyFile返回类型的Myclass从属性文件读取参数值并返回Myclass目的 我需要帮助来测试ReadPropertyFile方法与JUnit 如果可能的话使用模拟文件
  • .properties 中的通配符

    是否存在任何方法 我可以将通配符添加到属性文件中 并且具有所有含义 例如a b c d lalalala 或为所有以结尾的内容设置一个正则表达式a b c anything 普通的 Java 属性文件无法处理这个问题 不 请记住 它实际上是
  • Pig Udf 显示结果

    我是 Pig 的新手 我用 Java 编写了一个 udf 并且包含了一个 System out println 其中的声明 我必须知道在 Pig 中运行时该语句在哪里打印 假设你的UDF 扩展了 EvalFunc 您可以使用从返回的 Log
  • 如何获取之前的URL?

    我需要调用我的网络应用程序的 URL 例如 如果有一个从 stackoverflow com 到我的网站 foo com 的链接 我需要 Web 应用程序 托管 bean 中的 stackoverflow 链接 感谢所有帮助 谢谢 并不总是
  • Java 公历日历更改时区

    我正在尝试设置 HOUR OF DAY 字段并更改 GregorianCalendar 日期对象的时区 GregorianCalendar date new GregorianCalendar TimeZone getTimeZone GM
  • 在 junit 测试中获取 javax.lang.model.element.Element 类

    我想测试我的实用程序类 ElementUtils 但我不知道如何将类作为元素获取 在 AnnotationProcessors 中 我使用以下代码获取元素 Set
  • jdbc mysql loginTimeout 不起作用

    有人可以解释一下为什么下面的程序在 3 秒后超时 因为我将其设置为在 3 秒后超时 12秒 我特意关闭了mysql服务器来测试mysql服务器无法访问的这种场景 import java sql Connection import java
  • Hibernate 的 PersistentSet 不使用 hashCode/equals 的自定义实现

    所以我有一本实体书 public class Book private String id private String name private String description private Image coverImage pr
  • 当 OnFocusChangeListener 应用于包装的 EditText 时,TextInputLayout 没有动画

    不能比标题说得更清楚了 我有一个由文本输入布局包裹的 EditText 我试图在 EditText 失去焦点时触发一个事件 但是 一旦应用了事件侦听器 TextInputLayout 就不再对文本进行动画处理 它只是位于 editText
  • 如何访问JAR文件中的Maven资源? [复制]

    这个问题在这里已经有答案了 我有一个使用 Maven 构建的 Java 应用程序 我有一个资源文件夹com pkg resources 我需要从中访问文件 例如directory txt 我一直在查看各种教程和其他答案 但似乎没有一个对我有
  • 如何在谷歌地图android上显示多个标记

    我想在谷歌地图android上显示带有多个标记的位置 问题是当我运行我的应用程序时 它只显示一个位置 标记 这是我的代码 public class koordinatTask extends AsyncTask
  • logcat 中 mSecurityInputMethodService 为 null

    我写了一点android应显示智能手机当前位置 最后已知位置 的应用程序 尽管我复制了示例代码 并尝试了其他几种解决方案 但似乎每次都有相同的错误 我的应用程序由一个按钮组成 按下按钮应该log经度和纬度 但仅对数 mSecurityInp
  • java.io.Serialized 在 C/C++ 中的等价物是什么?

    C C 的等价物是什么java io Serialized https docs oracle com javase 7 docs api java io Serializable html 有对序列化库的引用 用 C 序列化数据结构 ht
  • Opencv Java 灰度

    我编写了以下程序 尝试从彩色转换为灰度 Mat newImage Imgcodecs imread q1 jpg Mat image new Mat new Size newImage cols newImage rows CvType C
  • 包 javax.el 不存在

    我正在使用 jre6 eclipse 并导入 javax el 错误 包 javax el 不存在 javac 导入 javax el 过来 这不应该是java的一部分吗 谁能告诉我为什么会这样 谢谢 米 EL 统一表达语言 是 Java
  • 使用反射覆盖最终静态字段是否有限制?

    在我的一些单元测试中 我在最终静态字段上的反射中遇到了奇怪的行为 下面是说明我的问题的示例 我有一个基本的 Singleton 类 其中包含一个 Integer public class BasicHolder private static
  • Java中super关键字的范围和使用

    为什么无法使用 super 关键字访问父类变量 使用以下代码 输出为 feline cougar c c class Feline public String type f public Feline System out print fe

随机推荐

  • 计算机视觉的定义,应用及整个系统

    定义 计算机视觉是使用计算机及相关设备对生物视觉的一种模拟 它的主要任务就是通过对采集的图片或视频进行处理以获得相应场景的三维信息 就像人类和许多其他类生物每天所做的那样 计算机视觉是一门关于如何运用照相机和计算机来获取我们所需的 被拍摄对
  • Linux查看当前目录下文件及文件夹的大小

    使用场景 查看服务器磁盘空间使用情况 快速定位当前目录下的大文件夹 快速找出大文件 推荐一个比较好用的命令 du h max depth 1 当前参数讲解 h 以可读性较好的方式显示尺寸 例如 1K 1M 1G max depth N 显示
  • objc学习笔记-基础

    1 xcode 4 3 3以后 NSAutoreleasePool 的用法发生改变 由 NSAutoreleasePool pool NSAutoreleasePool alloc init pool drain 变为 autoreleas
  • MySQL的分片(一)——分布式数据库概述

    系统分析 OLAP or OLTP 在互联网时代 海量数据的存储与访问成为系统设计与使用的瓶颈问题 对于海量数据处理 按照使用场景 主要分为两种类型 联机事务处理 OLTP 和联机分析处理 OLAP 联机事务处理 OLTP 也称为面向交易的
  • Typora+PicGo+GitHub搭建免费图床

    准备工作 Typora官网 PicGo官网 PicGo Core配置文件 Github 或Gitee Github准备图床仓库 新建一个仓库 仓库一定要设置为public公共仓库 生成私人令牌 Github主页右上角点击用户头像 gt Se
  • 课程2:《黑马程序员_Java基础视频-深入浅出精华版》-视频列表-

    day01 avi 01 01 计算机基础 计算机概述 avi day01 avi 01 02 计算机基础 计算机硬件和软件概述 avi day01 avi 01 03 计算机基础 软件开发和计算机语言概述 avi day01 avi 01
  • 用数学思想演绎的一些系统概念

    在这一部分要给出系统的数学定义 因为公式编辑器有时候不太好用 所以尽量简化 系统的定义 增长 竞争 整体 和 机械化 中心化 最终形态 最终形态的类型 学科中的同构 学科的联合 1 系统的定义 系统的数学定义如下 系统是由元素 元素之间相互
  • ip route 路由命令详解

    523条消息 ip route 命令详解 thj blog的博客 CSDN博客 ip route命令详解 Linux如何查看网关地址 study goup 博客园 cnblogs com 添加路由192 20 30 0 24网段走eth0网
  • python接口自动化测试视频教程百度云全集_python自动化运维测试框架实战视频教程百度云资源...

    python自动化运维测试框架实战视频教程百度云资源 web app 接口自动化 自动化框架 课程目录 开学典礼 上 开学典礼 下 python基础 Python入门 预习视频 python基础 对象与变量 预习视频 python基础 字符
  • Visio里Mathtype公式变形问题解决

    直接从word或者ppt复制MathType公式到Visio里可能会发生公式的变形 查找了一下解决办法 记录一下 建议不要只要从其他office软件直接复制过来 第一步 找到Visio工具栏的插入 然后选择对象 双击插入就可以了 后面的其他
  • QT5背景图片不显示的问题解决方法

    将qt creator左栏的项目 gt 概要 gt shadow build里的勾去除 使生成的debug文件放在源代码目录下 问题就解决了 更多绿色版本软件及机器视觉学习资料 请关注关注公众号 机器视觉智能解决方案
  • 5. 模块化编程

    HI 大家好 我是茶桁 上一节中我们学习了Python基本的流程控制 并且预告了这一节的内容 就是将要学习 模块化编程 那什么是模块化编程呢 按照维基百科的说法 模块化编程 英语 modular programming 是强调将计算机程序的
  • 军品研制过程介绍

    对于新入军品这个行业的新人来说 很难找到一个标准 或者程序等 将整个军品研制过程描述展示出来 本文章将系统性的讲述整个研制过程 一 军品研制过程 军品研制过程分为以下几个过程 可参照GJB 3273 论证阶段 L 技术性能指标可行性论证 方
  • C++访问限定符private、public、protected的使用场景

    众所周知 C 中有3种访问符 分别是private public protected 其中private和public比较好理解 private 只能由该类中的函数 其友元函数访问 不能被任何其他访问 更不能由该类的对象在类外进行访问 类成
  • 软件连接设置_丰田Techstream软件初探(刷一键升窗)

    前面通过我介绍 丰田Mini vci J2534检测线在64位系统安装 不少同学已经购买了J2534数据线 并在64位系统下安装成功了 如安装不成功 可以通过公众号的文字输入栏 发文字给我 我尽量及时解答 今天给大家聊聊如何使用丰田Tech
  • 功能测试基础之界面测试

    功能测试基础之界面测试 文章目录 功能测试基础之界面测试 前言 一 易用性 简述 易用性细则 二 规范性 简述 规范性细则 三 合理性 简述 合理性细则 四 美观与协调性 简述 美观与协调性细则 五 菜单位置 简述 菜单测试细则 六 独特性
  • JSP页面UTF-8格式中文字符串乱码问题解决方法

    JSP页面使用utf8格式保存中文字符串到文件或进行socket传送接收数据时 常常会出现乱码 这里给出了一个解决方法 实践检验行之有效 0 页面属性设置
  • 在linux shell中使用ftp命令来实现自动登陆、上传与下载

    前段时间有个需求 需要利用crontab定时往某个FTP上传文件 原以为linux中带的ftp命令只支持交互式的操作 没法在命令行下使用 所以后来打算利用PHP中提供的ftp命令来做 但是很不幸的发现ftp模块不是PHP的标准模块 还需要自
  • 到底什么是“容器适配器”?

    首先 我们要明白适配器是干什么的 其实就是一个接口转换装置 是得我们能用特定的方法去操作一些我们本来无法操作的东西 举一个例子 比如你的一个设备支持串口线 而你的电脑支持的是usb口 这时候 我们没有必要重新买一个支持usb的设备 只需要一
  • 2020“闭关”跳槽季,啃透分布式三大技术:限流、缓存、通讯

    01 分布式限流 1 1 Nginx ZooKeeper面试常备题 附答案 请解释一下什么是 Nginx 请列举 x Nginx 的一些特性 请列举 x Nginx 和 和 Apache 之间的不同点 请解释 x Nginx 如何处理 P