首先架构师不是那么好当,技术实力一定要过关,要具有架构师的思想,其次架构师是企业级开发所需的Dubbo框架、zookeper基本原理、redis分布式缓存、JVM性能优化,Nginx+apache+Tomc
网站架构涉及许多技术,Java程序员想要学习进阶成为架构师,需具备与架构师相匹配的技术能力,这是前提和基础。本篇列举了架构师的必备技术能力,文末随附详细的架构师专题资料。
一、计算机基础
操作系统(推荐现代操作系统)
编译原理
计算机网络
互联网协议
TCP/IP(推荐《TCP/IP协议族》)
HTTP1.1/2.0
HTTPS
OAauth 2.0
REST
二、集合框架(源码)
List
ArrayList
LinkedList
Set:HashSet、TreeSet
Map:TreeMap、ConcurrentHashMap
Queue:ConcurrentLinkedQueue
Stack
Collection的synchronized等方法
三、工具类
Google guava(推荐)
Apache common lang/BeanUtils/Collctions/IO
JSON
fastjson
gson
jackson
四、框架
Spring:IOC、AOP、常用注解
SpringMVC
Mybatis
Shiro
Netty
五、远程调用(RPC)
rmi
Thrift
Dubbo(Dubbox)
服务器治理,也可以作为微服务
gRPC
六、构建
Maven:推荐《Maven实战》
Gradle
七、安全
单项散列算法:MD5、SHA
对称加密:DES
非对称加密:RSA、HTTPS
八、JVM
Java虚拟机(Hotspot实现)
类加载机制
内存模型
GC:回收算法、垃圾收集器
调优
工具:jstack、jmap、jconsole
九、并发编程
Executor框架
Fork/join
happen-before
数据结构:ConcurrentHashMap
线程池:参数设置、原理、拒绝策略
线程状态
Lock/synchronized
原子操作类
并发工具类:CountDownLatch、Semaphore、CyclicBarrier、Exchanger
IO、BIO、AIO、NIO
十、数据
NoSQL:MongoDB
分布式缓存:Memcached、Redis(推荐)
关系数据库
MySQL
引擎
InnoDB(支持事务)
分库分表
Cobar
Mycat
十一、SQL优化
索引
主键索引
组合索引
explain
存储过程
SQL注入:使用#而不使用$
十二、事务隔离级别(ACID)
原子性
一致性
隔离性
持久性
十三、锁
表锁
行锁
悲观锁
数据库设计
十四、范式
第一范式
第二范式
第三范式
E-R图
十五、搜索引擎
Luecene
Solr
ElasticSearch
十六、大数据
Hadoop
Hbase
Spark
Storm/JStorm
十七、算法与数据结构
数组
链表
栈
队列
树
二叉树
B Tree/B+ Tree
红黑树
哈希
十八、排序
内部排序
插入排序
直接插入排序
希尔排序
选择排序
简单选择排序
堆排序
交换排序
冒泡排序
快速排序
归并排序
基数排序
桶排序
外部排序
十九、分布式系统
从集中到分布式
分布式Session:Session复制、Session绑定、Session服务器(靠谱)
分布式缓存:Redis、一致性Hash算法
数据库:读写分离、主从热备、分库分表、一致性
分布式事务、CAP、BASE、2PC/3PC
分布式锁
Redisson
负载均衡、硬件、F5、软件、LVS、Nginx
消息队列:RabbitMQ、ZeroMQ、ActiveMQ、Kafka(推荐)
服务化:服务注册与发现、Zookeeper
架构
微服务
Spring Boot
Dubbo
RPC
SOA
虚拟化
Docker
以上,是架构师必备的技术能力,以下,是架构师进阶专题(已更新至80期),将关键词【架构】私信给优知学院,全部秒收~
都划到这儿了,点个赞呗~
都划到这儿了,点个赞呗~