mirror of
https://gitee.com/shishan100/Java-Interview-Advanced
synced 2024-12-01 02:28:54 +00:00
38 lines
2.0 KiB
Markdown
38 lines
2.0 KiB
Markdown
|
|
|||
|
分布式系统核心的问题,服务框架、注册中心、网关系统、部署架构、超时重试、幂等防重,生产相关的问题,都搞定了,还是针对面试这块,人家到时候问你很多的生产问题,你必须回答的很好,你可以自己主动聊,说我们在生产环境里做了哪些优化
|
|||
|
|
|||
|
分布式事务,分布式锁
|
|||
|
|
|||
|
核心交易链路,核心数据链路,核心计算链路,核心业务链路,都建议要上分布式事务,保证核心链路的数据一致性
|
|||
|
|
|||
|
面试突击第一季,如果你没看过,务必去看一下,分布式事务这块,几种技术方案,我当时都讲解过了,离落地还有一段距离
|
|||
|
|
|||
|
分布式锁,在分布式系统中用的是非常多的,单块系统,不需要分布式事务,一个系统对应一个数据库,事务都是本地数据库的事务就可以了;锁,很多地方多线程并发修改一些共享资源,在单块系统内部用synchronized锁就可以搞定了
|
|||
|
|
|||
|
|
|||
|
|
|||
|
分布式系统,事务 -> 分布式事务,锁 -> 分布式锁
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
订单服务 -> 创建订单
|
|||
|
-> 库存服务 -> 扣减库存
|
|||
|
-> 积分服务 -> 增加积分
|
|||
|
-> 仓储服务 -> 通知发货
|
|||
|
|
|||
|
|
|||
|
|
|||
|
微服务架构里,哪怕你就部署了一个MySQL在一台高配物理机上,但是在这个MySQL实例中会创建不同的database,db_order,db_inventory,db_credit,db_wms,订单服务涉及到5张表,db_order中就会有5张表
|
|||
|
|
|||
|
|
|||
|
|
|||
|
已经在自己本地插入了一条订单数据了,调用库存服务扣减库存,在db_inventory里执行sql扣减库存,此时库存服务执行失败了,但是对于订单服务,他可能是没有感知到,他的订单还是创建成功了,调用积分服务和仓储服务,积分增加了,还打算对商品进行发货
|
|||
|
|
|||
|
|
|||
|
订单服务 -> 创建了订单,库存服务 -> 扣减了库存,积分服务 -> 增加积分失败,一旦回滚了之后,就会导致创建的订单被取消了,没了,create语句,放在本地事务里,一旦发现失败了,此时就会回滚,就会导致
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|