一、编程基础
Java语言
语言基础:基础语法 面向对象 接口 容器 异常 泛型 反射 注解 I/O 图形化
JVM:类加载机制 字节码执行机制 JVM内存模型 GC垃圾回收 JVM性能监控与故障定位 JVM调优
并发/多线程:并发编程基础 线程池 锁 并发容器 原子类 JUC并发工具类
数据结构和算法
数据结构:字符串 数组 链表 二叉树 堆、栈、队列 哈希
算法:查找 排序 贪心 分治 动态规划 回溯
计算机网络
ARP协议 IP/ICMP协议 TCP/UDP协议 DNS/HTTP/HTTPS协议 Session/Cookie
数据库/SQL
SQL语句书写 SQL语句优化 事务以及隔离级别 索引 锁
操作系统
进程/线程 并发/锁 内存管理和调度 I/O原理
设计模式
单例 工厂 代理 策略 模板方法 观察者 适配器 责任链 建造者
二、研发工具
集成开发环境
Eclipse、Intellij IDEA、VS Code
Linux系统
Linux常用命令 基本Shell脚本
代码管理工具
Git SVN
项目管理/构建工具
Maven Gradle
三、应用框架
后 端
Spring家族
Spring:IOC AOP
Spring MVC
Spring Boot:
自动配置、开箱即用
整合Web
整合数据库(事务问题)
整合权限(Shiro、Spring Security)
整合各种中间件(缓存、MQ、RPC框架、NIO框架)
整合其他组件
Spring Cloud:一种编程模型,一系列接口,一套生态,微服务开发标准,为了解决微服务架构遇到的问题
服务器软件
Web服务器:Nginx
应用服务器:Tomcat Jetty Undertow
中间件
缓存:Redis(5大数据类型、事务、消息通知、管道、持久化、集群) Memcache
消息队列:RocketMQ RabbitMQ Kafka
RPC框架:Dubbo gRPC Thrift Netty
数据库
ORM层框架:MyBatis Hibernate JPA
连接池:Druid HikariCP C3P0
分库分表:MyCat Sharding-JDBC Sharding-Sphere
搜索引擎
ElasticSearch Solr
分布式/微服务
1.服务注册与发现:Eureka Consul Zookeeper Nacos(流行)
2.API网关:Zuul GateWay(流行)
3.服务调用(负载均衡):Ribbon Feign
4.熔断/降级:Hystrix Sentinel(流行)
5.配置中心:Config Apollo Nacos(流行)
6.认证和授权:Shiro、Spring Security、OAuth2、SSO单点登录
7.分布式事务:
JTA接口(Atomikos组件)
2PC、3PC
XA模式
TCC模式(tcc-transaction、ByteTCC、EasyTransaction、Seata(阿里))
SAGA模式(ServiceComb、Seata(阿里))
LCN(tx-lcn)
8.任务调度:Quartz Elastic-Job
9.链路追踪与监控:Zipkin Sleuth SkyWalking
10.日志分析与监控:ELK(ElasticSearch、Logstash、Kibana)
虚拟化/容器化
容器技术:Docker
容器编排技术:K8S(Kubernetes) Swarm(过时)
前 端
基础套餐
三大件:HTML JavaScript CSS
基础库:jQuery Ajax
模板框架
JSP/JSTL Thymeleaf FreeMarker
组件化框架
Vue React Angular
四、运维知识
Web服务器:Nginx
应用服务器:Tomcat Jetty Undertow
CDN加速(内容分发网络 Content Delivery Network)
持续集成/持续发布:Jenkins
代码质量检查:Sonar
日志收集/分析:ELK
五、成神之路
徒手撕源码 光脚造轮子 闭目深度调优 吊打面试官
六、平稳降落
调节心态,注意身体,飞得多高不重要,重要的是如何平稳降落