3.21 web开发工程师(穿戴) 没记录面经,只能回忆一些重点的。1、使用nginx 如何搭建单体项目的后端集群 上来就给我干懵了,我寻思我不是面运维啊。还是支支吾吾地答了一下 。拦截前端请求location /,设置请求头 proxy_set_header,设置转发地址proxy_pass。但是没说到重点的upstream ,于是就只能跳过了。2、Spring的事务失效 答:①事务方法非public修饰 ②非事务方法调用事务方法 解决方案: 既然事务失效的原因是方法内部调用走的是this,而不是代理对象。那我们只要想办法获取代理对象不就可以了嘛。这里,我们可以借助AspectJ来实现。 ③事务传播行为不对 ④事务方法的异常被捕获了 ⑤没加@Service注解 3、分布式锁的实现 答:①redis的setnx实现 ②基于zookeeper的有序节点实现 ③redisson 4、redisson的实现原理 这里没讲好。redisson应该是使用WatchDog实现锁续期,防止业务未完成导致锁过期,后续就无法保证线程并发安全。以UUID+线程id作为key,使用lua脚本删锁和上锁,以及使用redlock防止redis主从复制时,单节点宕机导致锁失效的场景。简单概括了。5、Mysql与redis的数据一致性 刚开始要我介绍了一下点赞的业务,使用redis合并写功能,先把点赞放入redis,在定时获取点赞,写入数据库,mq通知其他服务点赞的数量,后续是否点赞可先通过redis管道命令查询redis 中点赞是否存在,再查数据库,返回是否点赞。这里我寻思他应该问的是这个,我就答了拿到记录后即刻删除掉redis记录,再写入数据库。 没想到他是问缓存与数据库的数据一致性,结果就被喷不合理。后面想了一下确实回答错了,并且我的小说网站是读多写少的场景,先更新数据库,再删缓存,是比较好的,然后中间再通过mq补偿,防止删缓存失败,或者延时双删也行。只不过当时以为问的点赞业务,所以说错了之后,被质疑直接问懵了。 大致就这么多,第二天就秒挂了,寻思也是kpi了,因为没手撕。