廾匸123 level
获赞
37
粉丝
23
关注
2
看过 TA
286
广东海洋大学
2024
Java
IP属地:广东
暂未填写个人简介
私信
关注
04-03 12:11
已编辑
广东海洋大学 Java
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了,因为没手撕。
0 点赞 评论 收藏
分享
关注他的用户也关注了:
牛客网
牛客企业服务