D.为了监听节点的变化,需要使用ZK的watch机制
答案:C
从zk获取注册地址是个集合,需要使用一定的负载算法获取其中的某一个来调用。
3.在什么样的场景下@Transactional会失效?如何解决?
答案:在spring容器中,在一个类内部A方法和B方法都加了@Transactional注解,如果A方法中直接调用B方法,则B方法的事务会失效;可以使用AopContext获取当前对象的动态代理,避免B方法事务失效的问题。
4.对服务器进行心跳检测,如果服务器在线则30s之后再次发起心跳检测,如果服务器不在线,发送短信通知并停止心跳检测,这个场景如何实现?
答案:通过定时任务线程池ScheduledExecutorService的scheduleAtFixedRate方法启动线程每隔30s ping一次服务器,启动之后scheduleAtFixedRate方法会返回当前线程的异步执行结果的引用Future,如果服务器在线,线程会每隔30s触发一次,如果服务区不在线则通过Future.cancel停止本次心跳检测。
5.MyBatis打开调试模式之后,能打印sql语句等信息,这是怎么实现的?实现过程中使用了什么设计模式?
答案:在mybatis的日志模块中,通过动态代理为jdbc的接口无侵入性的增强了日志能力,其本质是使用代理模式,其中ConnectionLogger负责打印连接信息和SQL语句,PreparedStatementLogger负责打印参数信息,ResultSetLogge负责打印数据结果信息。
6.MyBatis是如何为二级缓存动态添加日志、同步控制、阻塞、缓存淘汰策略等附加能力的?用了什么设计模式?
答案:二级缓存使用了装饰器模式为缓存能力添加附加能力的,在缓存模块中有8个装饰器,分别为缓存添加日志、序列化、同步、阻塞等等能力的装饰器,可以在运行期非常灵活的为二级缓存进行增强。
7.多线程编程对我们有什么实际意义?
答案:按照我们一般的业务实现,我们会在一个方法中调用所有相关的业务方法。这种实现带来的问题有什么?
第一,耦合,所有相关的业务方法成了一个业务流程上的必不可少的一步,前面的流程断了,后面的就没法走,整个业务就无法完成,但是有些业务方法其实并不是业务流程上必不可少的一环,是否执行,执行是否成功对业务影响并不大;第二,业务流程上有几个步骤,这个处理时间就是这几个步骤时间的相加,业务越多,步骤越多,处理时间当然就越多。那怎么解决这个问题?让这些业务并行起来而且减少相互之间的关联?当然是请出我们的线程,既可以解耦,又可以提高性能。
8.在单体应用中,使用加锁机制能解决我们所有的线程问题吗?
答案:不能,加锁有可能会造成我们的程序死锁和活锁,同时,synchronized如果加锁不正确,也不能保证数据的线程安全。
9.Netty高性能表现在哪些方面?
答案:IO 线程模型:同步非阻塞,用最少的资源做更多的事。
总目录展示
该笔记共八个节点(由浅入深),分为三大模块。
高性能。 秒杀涉及大量的并发读和并发写,因此支持高并发访问这点非常关键。该笔记将从设计数据的动静分离方案、热点的发现与隔离、请求的削峰与分层过滤、服务端的极致优化这4个方面重点介绍。
一致性。 秒杀中商品减库存的实现方式同样关键。可想而知,有限数量的商品在同一时刻被很多倍的请求同时来减库存,减库存又分为“拍下减库存”“付款减库存”以及预扣等几种,在大并发更新的过程中都要保证数据的准确性,其难度可想而知。因此,将用一个节点来专门讲解如何设计秒杀减库存方案。
高可用。 虽然介绍了很多极致的优化思路,但现实中总难免出现一些我们考虑不到的情况,所以要保证系统的高可用和正确性,还要设计一个PlanB来兜底,以便在最坏情况发生时仍然能够从容应对。笔记的最后,将带你思考可以从哪些环节来设计兜底方案。
篇幅有限,无法一个模块一个模块详细的展示(这些要点都收集在了这份《高并发秒杀顶级教程》里),麻烦各位转发一下(可以帮助更多的人看到哟!)
CodeChina开源项目:【一线大厂Java面试题解析+核心总结学习笔记+最新讲解视频】
由于内容太多,这里只截取部分的内容。
9-1631085198210)]
[外链图片转存中…(img-Lj6a0Dvq-1631085198211)]
由于内容太多,这里只截取部分的内容。