当前位置: 首页 > news >正文

京东社招——Java后端开发面试复盘

最近参加了京东大数据的面试,整个过程涵盖了项目细节、基础八股文以及手撕算法。本文将这次面试中遇到的9个核心问题进行了复盘和深度整理,特别是关于RabbitMQ的消息积压处理以及MySQL的RR隔离级别实现。

base:北京


1. 项目问题:你的项目中提到了网页数据爬取,代码中用了什么框架/工具?

爬取主要针对一些静态代码资源及开发者工具能够看见的接口返回JSON,对于前者,简单的静态页面,使用了HttpClient / OkHttp发送HTTP请求,结合Jsoup解析HTML DOM元素;后者则寻找接口所需参数,如csrfToken, cookie 参与接口调用。

2. 项目问题:为什么选用 RabbitMQ,有没有遇到消息积压问题,怎么解决,RabbitMQ 内部数据分片了吗?

相比于Kafka的大吞吐量日志处理,我们业务需要的是可靠的、低延迟的消息传递,且涉及复杂的路由逻辑。RabbitMQ基于Erlang,对AMQP协议支持好,社区活跃,且提供了消息确认(ACK)、持久化机制,适合我们的项目需求。

RabbitMQ 本身不进行类似于数据库的分库分表或Kafka的Partition分区。它的数据存储要么在内存中,要么在磁盘上。严格来说,它没有做数据分片,而是通过镜像队列做数据冗余来保证高可用。

3. 八股问题:线程模型有哪几种?线程池?

4. 八股问题:你刚刚提到的 NIO,AIO 是什么?

5. 八股问题:MySQL 的事务隔离级别?RR 具体是怎么实现的?

6. 项目+八股+发散问题:你们项目中 Redis 是怎么用的?封装的什么数据?是用SpringBoot 封装好的 bootstrap 吗?其底层?或者说让你自己做一个 bootstrap 你有思路吗?

7. 算法题1:字符串的最大不重复子串(力扣原题)

8. 算法题2:手写生产者/消费者

9. SQL题:有两张表 table_a(id, name, sd_id) 与 table_b(sd_id, ...),其中 sd_id 在 table_b 中是主键,查询 sd_id 在 table_a 中出现而在 table_b 不存在的值。

http://www.jsqmd.com/news/472882/

相关文章:

  • 面向强随机性场景的短期净负荷功率预测:基于集成学习的元学习器设计
  • 勒索病毒专盯数据库? TDE 透明加密如何筑起“最后一道防线
  • Linuex操作系统的优化
  • 分库分表(一)
  • vmd分解联合小波阈值降噪MATLAB代码。具体实现功能如下: 1.数据加载与预处理 数据从CSV文件读取并转换为数组,处理了多列数据的情况。 采样频率 Fs 设置为1000 Hz,这是后续时频分析的
  • PID算法(3)- PID就是求【针对控制量的一个比例+积分+微分】的值
  • 复现论文:基于动力学Wulff图理解和控制异质外延——以GaN为例
  • 类与对象说人话
  • K-Means聚类算法的数据可视化与综合分析:从原理到实践的完整指南
  • Agent-Browser 简明教程
  • 多智能体事件触发一致性
  • SQL 客户端远程登录服务器详细操作教程
  • 6 个动作锻炼核心肌群,让你的腰力更强!
  • 再斩国际设计大奖!玛吉斯VS6、HP6荣获2026德国iF设计奖
  • 多相流模拟在含裂缝非均质地层中的数值计算研究——基于间断伽辽金方法的探索
  • 2026年如何查看AI关键词排名?品牌在AI回答中的排序一键测
  • nginx的核心功能
  • 智能体赋能的企业运营分析与决策支持系统:从认知架构到自动化闭环
  • MVI56-BAS通讯模块
  • 企业微信外部客户群自动化管理:建群+群发+踢人一体化
  • gdb基础操作
  • 基于自适应PI的构网型变流器预同步控制策略复现报告
  • 实验室纯水机怎么选?2026 纯水系统品牌及选型全攻略
  • Claude Code Task 系统:任务管理与进度追踪
  • 液压挖掘机主机厂整机CAD图纸
  • 膜结构车棚性价比排名深度解析
  • 【01】Openclaw 的安装及配置
  • Python自动化实现思路
  • 【Mac】如何开启 Chrome Gemini 侧边栏?
  • MATLAB环境下一种基于小波散射网络的纹理图像分类方法与基于小波散射变换和深度学习的寄生虫感...