一.熟悉新项目的步骤
第一步:了解业务
技术本身就是为了业务而服务,只有首先搞清楚了业务之后才真正算是步入了这个项目的大门。因此,要先搞清新项目:
- 是做什么的? 主要面向什么人群使用?
- 主要提供了哪些功能?
- 项目背景是什么样的?
- 项目涉及的关键业务流程是怎么样的?
- 项目目前面临的挑战是什么?未来规划是什么?
第二步:搭建项目开发环境
简单把开发环境搭建一下。搭建的步骤一般都在项目的 README 文档里面。搭建完成之后,需要确保项目能够在自己的电脑上正确运行。
第三步:看项目技术架构
这个直接看项目的相关依赖就好。拿Java后端项目举例子,如果是 Maven 项目的话看pom.xml,如果是 Gradle 项目就看 build.gradle。可能会涉及下面这几部分,但是并不完全:
-
项目最底层框架是什么?是 Spring 还是 Spring Boot,又或者是其他框架呢?
-
项目依赖了哪些相关的包?挑重点看,比如数据库是 MyBatis 还是 JPA 或者是公司自研的框架呢?
-
项目使用的什么数据库?是 MySQL 还是 PostgreSQL,又或者是其他数据库呢?
-
项目用到了缓存吗?是 Redis 缓存吗?有没有用到本地缓存呢?
-
项目用到了消息队列吗? Kafka 还是 RocketMQ?
-
项目的权限管理这块是怎么做的呢?
-
......
第四步:看项目的代码结构
不同的公司对于项目的结构的划分可能也不同,不过大体都是类似的。以 Java 后端项目为例,常见的项目可能会分为下面三层。但是,复杂的系统分层可能会更多
-
Repository(数据库操作)
-
Service(业务操作)
-
Controller(数据交互)
如果是 DDD 分层架构的话,可能是下面这样的:
-
User Interface(用户界面层)
-
Application(应用层)
-
Domain(模型层)
-
Infrastructure(基础实施层)
第五步:从功能主线/问题出发研究项目源码
一个比较成熟的项目的源码量是非常多,我们不可能都完完整整地看完,也没有必要。
可以通过 debug 调试,研究项目核心代码逻辑。比较推荐的方式就是通过一个功能主线(比如 Dubbo 是如何暴露服务的?)或者问题(比如 ?)出发。
二.面试之前,准备项目经历的小技巧
1.提前搞清楚项目的架构图、技术选型等等。
2.提前想好项目的亮点,针对项目涉及的关键技术进行深度复习。
比如说,你的项目用了消息队列的话,你就很有必要提前想好怎么回答消息队列相关的一些问题:消息队列解决了什么问题、常见消息队列对比、如何保证消息只被消费一次、如何保证消息不被重复消费......。
3.引导面试官问你熟悉的技术。
比如说,你对消息队列比较了解的话,介绍项目的时候就可以多介绍一下自己通过消息队列解决了什么问题。
4.突出个人的贡献比如自己在项目中解决了什么问题,而不只是叙述自己做了什么。