天津小公司面经

一面

1.自我介绍

2.项目websocket 优化 方案

3.websocket 的链接信息如何存储

**直接在代码中存储到 **ConcurrentHashMap中,后续用户访问量上来了,再存储到 redis 中

4.短链接的缓存是干什么的

大量未知用户的访问不至于落到 mysql 中。同时在缓存外面,套了一层布隆过滤器(引诱面试官提问)

5.外面套一层的布隆过滤器是怎么做的

正常思路-> redis 没找到->mysql->分片键没有命中->全库扫描

优化思路->布隆过滤器->有直接放行

------------------>没有就存一个空值->原则:能不进 mysql 就不进 mysql

**6.**mysql 索引优化问题

联合索引+最左匹配+索引下推(开始吟唱八股魔法)

7.场景题:有一个分类需求:如(促销商品-今日畅销-电器-手机-苹果)如何创建 mysql 的表,以及索引如何创建

树表(父 ID,名称,type(区分几级分类),status(状态),排序字段))

索引:父 ID,排序字段。联合索引

反问:

1.你们主要做什么

2.招的这个岗位要做什么

3.公司常用技术栈是什么

4.(通过希望挺大,就没问什么了)

二面:

苹果手机倒扣上,没有录上音。╮(╯▽╰)╭

1.java 有 thread 为什么还要有 future 等

没想到,就说,thread 不太好控制,暂停什么的,要用 sleap
解答:因为 thread 是黑盒,无法观测状态

2.springboot 的 starter 怎么写

说了半天也没背出来。

3.场景题,期末要查看考试结果,排名,怎么做这个需求。

我想的是,这种复合表大概率应该要很多 join。

我的回答:查一次,然后存储到 redis 中,用 zset 来做排名,应为频繁的查询需求,大概率只有一段时间。最后流量少了,就直接落库到 mysql。(存到 redis,最后拉回到 mysql)

哥们对答案很不满意,又说,动态积分排序呢?

还用那一套啊。
哥们很不满意**(;一_一)**

你知道用 mysql 就能解决吗,还还还

相关推荐
山土成旧客14 小时前
【Python学习打卡-Day40】从“能跑就行”到“工程标准”:PyTorch训练与测试的规范化写法
pytorch·python·学习
Yyuanyuxin14 小时前
保姆级学习开发安卓手机软件(一)--安装软件及配置
学习
ps酷教程14 小时前
HttpPostRequestDecoder源码浅析
java·http·netty
闲人编程14 小时前
消息通知系统实现:构建高可用、可扩展的企业级通知服务
java·服务器·网络·python·消息队列·异步处理·分发器
栈与堆15 小时前
LeetCode-1-两数之和
java·数据结构·后端·python·算法·leetcode·rust
●VON15 小时前
跨模态暗流:多模态安全攻防全景解析
人工智能·学习·安全·von
OC溥哥99915 小时前
Paper MinecraftV3.0重大更新(下界更新)我的世界C++2D版本隆重推出,拷贝即玩!
java·c++·算法
星火开发设计15 小时前
C++ map 全面解析与实战指南
java·数据结构·c++·学习·算法·map·知识
*才华有限公司*15 小时前
RTSP视频流播放系统
java·git·websocket·网络协议·信息与通信
gelald15 小时前
ReentrantLock 学习笔记
java·后端