阿里架构师谈 Java:开发一到三年的程序员怎么在小公司拿到 30K?
前言
金九银十的跳槽面试季已经过了,最近跟朋友在一起聚会的时候,提了一个问题,说 1-3 年的 Java 程序员,薪资区间大致是在 15-25K 左右,那有没有可能提前达到 30K 的薪资呢?有人说这只能是大企业或者互联网企业工程师才能拿到。也许是的,小公司或者非互联网企业拿 30K 的不太可能是初级开发或者码农了,应该已经转管理。还有区域问题,这个是不在我的考虑范围内 因为除了北上广深杭,其他地方也很难达到。
首先:30K 对应的层级分别是什么?
30K 的月薪在 BAT 等一线大厂实在太普遍了,一般是高级工程师和资深工程师的职位,在阿里是 p6~p7 左右,在百度是 t5 左右,腾讯是 t2-3 左右,在京东是 t3-1,美团是 p6 左右,其他的我不了解。
其次:掌握的技能树主要包含哪几个方面:
第一个是基础。比如对集合类,并发包,IO/NIO,JVM,内存模型,泛型,异常,反射,等有深入了解,最好是看过源码了解底层的设计。比如一般面试都会问 ConcurrentHashMap,CopyOnWrite,线程池,CAS,AQS,虚拟机优化等知识点,因为这些对互联网的企业是绝对重要的。而且一般人这关都过不了,还发闹骚说这些没什么用,为什么要面试。举一例子,在使用线程池时候,因为使用了无界队列,在远程服务异常情况下导致内层飙升,怎么去解决?你要是连线程池都不清楚,你怎么去玩?再举一例,由于对 ThreadLocal 理解出错,使用它做线程安全的控制,导致没能实现真的线程安全。所以作为一个拿三万的 JAVA 程序员这点基础是要有的。
第二你需要有全面的互联网主流技术相关知识。从底层说起,你起码得深入了解 mysql,redis,mongodb,nginx,tomcat,rpc,jms 等方面的知识。你要问需要了解到什么程度,我可以给你说个大慨。首先对于 MySQL,你要知道常见的参数设置,存储引擎怎么去选择,还需要了解常见的索引引擎,知道怎么去选择。知道怎么去设计表,怎么优化 sql,怎么根据执行计划去调优。
高级的你需要去做分库分表的设计和优化,一般互联网企业的数据库都是读写分离,还会垂直与水平拆分,所以这个也有经验的成分在里面。然后 redis,mongodb 都是需要了解原理,需要会调整参数的,而 nginx 和 tomcat 几乎都是 JAVA 互联网方面必配,其实很阿里的技术栈选择有点关系。至于 rpc 相关的就多的去,必须各种网络协议,序列化技术,SOA 等等,你要有一个深入的理解。现在应用比较广的 rpc 框架,在国内就是 dubbo 了,可以自行搜索。至于 jms 相关的起码得了解原理吧,一般情况下不是专门开发中间件系统和支撑系统的不需要了解太多细节,国内企业常用的主要是 activeMQ 和 kafka。你能对我说的都研究的比较深入,阿里 p7 都不是太大问题的,当然这个还需要看你的架构能力方面的面试表现了。
第三就是编程能力,编程思想,算法能力,架构能力。首先 30K 程序员对算法的要求我觉得还是比较低,再高级也最多红黑树吧,但是排序和查询的基本算法得会。编程思想是必须的,问你个 AOP 和 IOC 你起码的清清楚楚,设计模式不说每种都用过,但也能了解个几种吧。编程能力这个我觉得不好去评价,但是拿一个 2000W 用户根据姓名年龄排序这种题目也能信手拈来。最后就是架构能力,这种不是说要你设计个多牛逼多高并发的系统,起码让你做一个秒杀系统,防重请求的设计能快速搞定而没有坑吧。
因此在这里我也给那些技术想达到这个高度甚至想往架构师发展的 Java 程序员提供一份详细的进阶路线图,主要针对 1-5 年及以上工作经验的 Java 开发人员,从广度到深度架构图还比较全面的,里面的技术包涵了 Java 高并发、微服务、源码分析、源码分析、高性能、分布式、高可用等内容,这些也是目前互联网企业比较常用的技术,那么来详细看看。(图片可以保存)
JavaEE 高级框架
Maven
分布式储存
高级开发
高并发系统架构
搜索引擎+数据分析
分布式缓存
消息列队
微服务
安全加密
分布式集群
源码解析+虚拟化容器+项目掌控
一套系统性的体系图可以理清你的思路,清楚的知道自己要学习的什么,对你的规划也有一定的帮助
架构视频
面试文档
架构书籍
欢迎大家扫码来关注公众号博主,获取文章全部资料,此公众号会持续更新技术干货、不定期分享 Java 进阶面试宝典、Java 核心知识、架构书籍电子版
评论