做码农差不多十五年了,聊聊程序员十五年内职业生涯规划,共勉之

  1. 云栖社区>
  2. 博客>
  3. 正文

做码农差不多十五年了,聊聊程序员十五年内职业生涯规划,共勉之

java天坑 2018-10-17 16:13:03 浏览1606
展开阅读全文
做码农差不多十五年了,聊聊程序员十五年内职业生涯规划,共勉之

前言

很多人以为技术人员可以做一直做下去,但是最近我发现这个观点不完全正确,因为能一直做下去的技术人员非常稀少,因为不同的年龄段,公司对技术人员的要求会不一样,如最近传言华为计划裁掉40岁以上的程序员,首先我认为肯定不会裁掉所有40岁以上的技术人员,如CTO或高级技术专家不会被开,因为他们达到了40岁技术人员应该达到的能力,而那些没有达到该年龄段能力的技术人员会被淘汰。

为什么现在各大公司招技术人员这么难还会有公司裁员呢?

因为公司需要换血和降低成本。换血意味着希望进入一些新鲜或者优质血液,让团队能正向发展,新鲜的血液积极性高,潜力好,如刚毕业的学生或工作几年的技术人员。优质的血液,意味着技术能力强,能影响团队技术方向,如某个领域的技术专家,能影响团队事倍功半。

如果你是公司老板,一个工作三年的技术人员和一个工作10年的技术人员能力差不多,而三年的更有技术激情,十年的还要照顾家庭,工资还比三年的多几倍,你会选择留下哪一个呢?是不是会开掉10年的技术人员,再招聘几个三年的呢?这就是现实的残酷。那个十几年工作经验的技术人员离职后开始找工作,但是找到合适的工作会非常困难,首先你的工资基数很大,你期望下家公司能给你更高的薪水,新公司也会考虑招聘你的投入产出比。

所以技术人员需要居安思危,不要被眼前的高薪冲昏了头脑,小富则安是短暂的,逆水行舟才是技术人员走的路,所以我认为技术人员需要以五年为一个技术周期,每个技术周期上都要上升一个技术层级,否则随时可能会被淘汰掉,各层级建议和要求如下:

应届生 - 扎实的技术基础,有技术热情。应届生技术人员我建议进入BAT这样的大型互联网公司,虽然辛苦点,但是工作几年后,技术能力和视野会大于很多工作10年的技术人员。

注意点:系统化的学习技术,研究技术而不是使用技术。

工作5年 - 在技术上做到知其然知其所以然,对用过的技术框架都能知道技术原理和优缺点,多实战少纸上谈兵,学会总结。具备独立分析和解决技术问题的能力。

注意点:很多候选人用过N年JDK,就认为自己精通JAVA,但是面试的时候发现JDK的源码都没看过。我面试阿里的时候,也不明白为啥要问JDK源码或垃圾回收机制,但是当我去解决复杂的线上问题时,我才发现对源码或原理不熟,很难查到问题所在。如果你在小公司或非互联网公司没有这样的技术场景,可以尝试提高下业务架构能力或者利用业余时间实战并钻研技术。

工作十年 - 有大型系统架构经验和技术亮点。架构经验需要在大公司有实战经验。技术亮点就是在某个技术上达到专家级别,当同事遇到某个技术问题会来咨询你,比如遇到Redis问题解决不了时会来找你。短短几句话要求非常高,招聘的时候很多技术人员都卡在这个阶段,需要有很好的技术积累和背景。

注意点:很多技术人员开始转向管理,结果技术和管理都是半桶水,技术首先要达到一定的深度再考虑管理方向。小公司技术总监,技术停留在用,很多技术原理都不知道,如何做技术规划呢?

工作十五年 - 要有很强的业务和技术规划能力,在公司内有影响力,可以影响团队和公司的技术发展方向。也可以尝试换下工作,去成长性好的公司做技术总监,扩展下技术视野。

十五年以上 - 这个我说不好,欢迎通过评论提建议。

如何进入BAT

达到以上要求就可以进入BAT,但是我分析了下最简单进入BAT的方式是工作5年以内的技术人员,因为应届生要求TOP院校的TOP学生,工作八年以上的要求又非常高。

主要用到的技术栈

面试大公司基本都会问的技术,也是大公司经常用到的一些技术

性能调优

性能优化如何理解

  • 性能基准
  • 什么是性能优化
  • 衡量标准

JVM调优

  • jvm虚拟机的内存解析
  • 垃圾收集器
  • 实战调优案例与解决方案
  • JVM运行时区

Java程序员性能优化

  • 优雅的创建对象
  • 注意对象的通用方法
  • 类的设计陷阱
  • 泛型需要注意的问题
  • java方法的那些坑
  • 程序设计的通用规则

Tomcat

  • 线程模型分析
  • 生产环境配置及调优
  • 运行机制及框架

Mysql

  • 探析BTree机制
  • 执行计划深入分析
  • Mysql索引优化详解
  • 慢查询分析与SQL优化

应用框架源码解读

  1. Spring IOC
  2. Spring Aop
  3. Spring MVC
  4. Spring5的新特性
  5. Mybatis

Spring IOC

  • SpringFrammework体系结构
  • 源码分析
  • BeanFactory源码分析
  • BeanDefiniton源码分析
  • Bean生命同期
  • 依赖实现

Spring Aop

  • Aop源码分析
  • transaction事物分析
  • Springcache框架源码分析

Spring MVC

  • MCV简介与设计思想
  • SpringMVC组成
  • 源码解读DispatchServlet

Spring5新特性

  • 容器增加
  • 函数式编程
  • webFlux模块介绍
  • kotlin介绍
  • Testing改进
  • 兼容性问题

Mybatis

  • mybatis组成
  • 核心源码分析
  • 手写Mybatis

分布式架构

互联网分布式架构是非常重要的一个技术,基本上所有的大公司都会用分布式

分布式架构思维

  • 大型互联网架构演进过程
  • 架构师应具备的分布式知识
  • 主流分布式架构设计详解

架构开发基础

  • 多线程开发
  • 高性能NIO框架

架构核心服务层技术

  • 服务的前世今生
  • 深入理解通讯协议
  • 基于 分布式RPC解决方案
  • dubbo全解析

架构关键基础设施

  • 分布式环境指挥官zookeeper
  • 分布式消息通讯异步与MQ
  • 分布式缓存
  • 数据存储SQL&NoSQL
  • 高并发分流技术Nginx

分布式解决方案

  • 分布式解决方案
  • Session跨域共享实战
  • 分布式事物解决方案实战
  • 分布式锁解决方案实战
  • 分布式单点登录实战SSO
  • 分布式调度任务系统
  • 分布式配置中心

微服务架构技术

微服务这块应该不用多说了,知道微服务技术的至少能多加5k薪资

  1. SpringBoot
  2. SpringCloud
  3. Docker虚拟化技术

SpringBoot

  • 与微服务的区别于联系
  • 快速构建SpringBoot工程
  • SpringBoot核心组件剖析
  • 快速集成mybatis实战
  • 快速集成Dubbo及案例实战
  • 构建集成 redis及案例实战
  • 构建Swagger插件实现API
  • 管理及接口测试体系

SpringCloud

  • Zuul路由网关详解源码探析
  • Ribbon客户端负载均衡原理
  • Feign声明式服务调用方式
  • Eureka注册中心构件
  • Config配置服务中心
  • svn、git快速集成
  • Sleuth调用链路跟踪
  • BUS消息总线技术

Docker虚拟化技术

  • 介绍、安装与使用
  • compose部署脚本
  • service服务编排
  • redis分布式集群部署
  • docker file构建
  • 通过maven插件打包镜像
  • 部署及运行应用程序kubernetes编配
  • 构建Mysql集群实战
  • 高可用SpringCloud微服务与docker集成实现动态扩容实战

团队协作开发

这个是常用的开发工具类的,提升团队效率

  1. Git
  2. Maven
  3. Jenkins
  4. Sonar

加群:795632998获取往期Java高级架构资料、源码、笔记、视频

Dubbo、Redis、设计模式、Netty、zookeeper、Spring cloud、分布式、

高并发等架构技术,获取以下资料

架构师视频资料

15396704691659157597030
153967046918019c5064362
153967046906052e7af604f

网友评论

登录后评论
0/500
评论
java天坑
+ 关注