1
0
mirror of https://github.com/doocs/advanced-java.git synced 2025-01-27 06:30:13 +08:00
advanced-java/docs/distributed-system/distributed-system-interview.md
yanglbme a7cb243259 docs: update UUID desc to fix , rename images
- Update UUID desc to fix 
- Rename img to images
- Fix typo
2019-01-07 15:44:02 +08:00

31 lines
2.7 KiB
Markdown
Raw Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

## 分布式系统面试连环炮
有一些同学,之前呢主要是做传统行业,或者外包项目,一直是在那种小的公司,技术一直都搞的比较简单。他们有共同的一个问题,就是都没怎么搞过分布式系统,现在互联网公司,一般都是做分布式的系统,大家都不是做底层的分布式系统、分布式存储系统 hadoop hdfs、分布式计算系统 hadoop mapreduce / spark、分布式流式计算系统 storm。
分布式业务系统,就是把原来用 Java 开发的一个大块系统,给拆分成**多个子系统**,多个子系统之间互相调用,形成一个大系统的整体。假设原来你做了一个 OA 系统里面包含了权限模块、员工模块、请假模块、财务模块一个工程里面包含了一堆模块模块与模块之间会互相去调用1 台机器部署。现在如果你把这个系统给拆开,权限系统、员工系统、请假系统、财务系统 4 个系统4 个工程,分别在 4 台机器上部署。一个请求过来完成这个请求这个员工系统调用权限系统调用请假系统调用财务系统4 个系统分别完成了一部分的事情,最后 4 个系统都干完了以后,才认为是这个请求已经完成了。
![simple-distributed-system-oa](/images/simple-distributed-system-oa.png)
> 这两年开始兴起和流行 Spring Cloud刚流行还没开始普及目前普及的是 dubbo因此这里也主要讲 dubbo。
面试官可能会问你以下问题。
### 为什么要进行系统拆分?
- 为什么要进行系统拆分如何进行系统拆分拆分后不用dubbo可以吗dubbo和thrift有什么区别呢
### 分布式服务框架
- 说一下的 dubbo 的工作原理?注册中心挂了可以继续通信吗?
- dubbo 支持哪些序列化协议?说一下 hessian 的数据结构PB 知道吗?为什么 PB 的效率是最高的?
- dubbo 负载均衡策略和高可用策略都有哪些?动态代理策略呢?
- dubbo 的 spi 思想是什么?
- 如何基于 dubbo 进行服务治理、服务降级、失败重试以及超时重试?
- 分布式服务接口的幂等性如何设计(比如不能重复扣款)?
- 分布式服务接口请求的顺序性如何保证?
- 如何自己设计一个类似 dubbo 的 rpc 框架?
### 分布式锁
- 使用 redis 如何设计分布式锁?使用 zk 来设计分布式锁可以吗?这两种分布式锁的实现方式哪种效率比较高?
### 分布式事务
- 分布式事务了解吗你们如何解决分布式事务问题的TCC 如果出现网络连不通怎么办XA 的一致性如何保证?
### 分布式会话
- 集群部署时的分布式 session 如何实现?