成为一名Java高级架构师到底需要学习什么?

Java架构师,应该算是一些Java程序员们的一个职业目标了吧。很多码农码了五六年的代码也没能成为架构师。那成为Java架构师要掌握哪些技术呢,总体来说呢,有两方面,一个是基础技术,另一个就是组织能力和提出解决方案能力了。我就跟大家来简要地说说吧。

如果你是想成为Java架构师,那么你首先要是一个Java高级攻城狮。也就是说,基础必须牢固,对Java的了解全面而且深入。

熟练使用各种框架,并知道它们实现的原理。

Jvm虚拟机原理、调优操作,懂得jvm能让你写出性能更好的代码;

池技术也是要掌握的,对象池、连接池、线程池都要会;

Java反射技术,写框架必备的技术;

Java各种集合对象的实现原理,了解这些可以让你在解决问题时选择合适的数据结构,高效地解决问题,写出代码;

nio,注意“直接内存”的特点,使用场景。

还没完,除了上边那些,你还要熟练使用各种数据结构和算法,数组、哈希、链表、排序树等等都是;熟练使用Linux操作系统,也是必备的;熟悉各种协议,比如tcp协议,创建连接三次握手和断开连接四次握手的整个过程,不了解就没法对高并发网络应用做优化,http协议,session和cookie的生命周期与关联;熟悉系统集群、负载均衡、反向代理、动静分离,网站静态化;懂得分布式存储系统nfs,fastdfs,tfs,Hadoop了解他们的优缺点,适用场景,以及分布式缓存技术memcached,redis,提高系统性能必备。

以上这些够了吗?当然不。还有呢,工具nginx必备技能超级好用,高性能,基本不会挂掉的服务器,功能多多,解决各种问题;掌握数据库的设计能力,Mysql必备,最基础的数据工具,主要是免费且好用,对它基本的参数优化,慢查询日志分析,主从复制的配置,至少要成为半个mysql dba,其他数据库也要至少略懂一二;还有队列中间件也要会操作,如消息推送,可以先把消息写入数据库,推送放队列服务器上,由推送服务器去队列获取处理,这样就可以将消息放数据库和队列里后直接给用户反馈,推送过程则由推送服务器和队列服务器完成,好处异步处理、缓解服务器压力,解藕系统。

说了这么多,其实都还是纯粹的基础技术,并且还没有列全。要想成为架构师,除了这些之外,就还要具备我们说的组织能力和解决问题的能力了。

架构师思考的是全局的东西,是如何组织系统,以达到业务要求、性能要求。架构师要针对业务特点、系统的性能要求提出解决问题成本最低的设计方案。为了架构而架构,这是绝对不可取的。你想啊,人家一个几百人用户的系统,访问量不大,数据量也不大,你给人家上集群、分布式储存、高端服务器,肯定能到达性能要求,但是成本高啊。要知道,架构师的作用,一是满足业务需求,二是最低的硬件网络成本和技术维护成本。

架构师还要根据业务发展阶段,提前预见发展到下一个阶段系统架构的解决方案,并且设计当前架构时将架构的升级扩展考虑进去,做到易于升级;否则等系统瓶颈来了,出问题了再去出方案,或现有架构无法扩展直接扔掉重做,或扩展麻烦问题一大堆,这会对企业造成损失。

架构师是经过程序员,开发员,高级开发员等一步步积累而来。一个好的架构师不太可能看一些书就能短期内看会。建议平时写代码时,多思考,而不是仅仅满足于完成功能。可以试着用不同的方法去实现一个功能,分析优缺点。看别人的代码时也要学会别人为什么这么写。等到有了些积累,可以去系统地学些design pattern,并逐渐运用到工作中。熟练后你会发现自己可以写变种的pattern了。到这一步你已经积累了不少需求分析的经验,也能够把需求中的问题抽象出来,代码已经能很好的重用了。这就已经踏入架构师的门槛了,接下来,你要做的是培养自己预测需求变化的能力。当你的设计总是能够以最小的代价适应需求的改变时,就是个合格的架构师了。

第一阶段:java基础知识要牢固,java编程思想,设计模式,effective java这些都算是基础知识。在这基础上,要结合多种项目经验,利用实践来提高基础能力。

第二阶段:开阔眼光,借鉴优秀的项目或开源代码。例如jstorm、hadoop等开源软件,可以下载后利用业余时间研读,提升能力。

第三阶段:结合业务进行架构设计和实践,并多与行业高手交流,提升领域建模等能力

选一个方向,然后多阅读一些高质量代码,站在前辈架构师的肩膀上,才能比较快速的进步,长时间的技术积累,业务项目的积累,合理的方案解决通用问题。多读多写多思考。多读的目的是开拓自己的视野,让自己具备举一反三触类旁通的能力。多写是脚踏实地,避免夸夸其谈纸上谈兵。多思考是融会贯通所读所写。

架构师的学习之路也正式开始。

性能优化

JVM调优

Java程序性能优化

Tomcat

Mysql

Spring IOC

Spring AOP

Spring MVC

Spring 5新特性

Mybatis


分布式架构

架构核心服务层技术

架构关键技术设施

分布式消息通讯 异步于MQ

分布式缓存

Redis

Memcached

MongoDB

数据存储

高并发分流技术Nginx

分布式解决方案


应用框架源码解读


微服务专题

你还不知道微服务?怎么加(zhuang)薪(bi)

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集成实现动态扩容实战


团队协作开发

Git

Maven

Jenkins

Sonar


B2C商城项目实战

撸起袖子干实事,项目经验那点事

系统设计

架构设计

数据库设计

部署设计

基础开发框架讲解

用户管理子系统

用户注册登录(二维码技术)

权限控制(shiro)

单点登录(session统一缓存、sso)

商品管理子系统

商品管理(MongoDB)

商品分类(MongoDB)

商品发布(nosql与mysql数据同步)

热卖商品排行(redis)

搜索子系统

基于ES的全文探索

检索需求分析

检索策略

索引设置

分词算法

命中率优化

订单实时统计

订单子系统

分布式环境生成唯一编号(zookeeper)

下单业务流程(消息中间件)

订单可靠性

秒杀功能(redis)

订单管理

订单功能(mongodb)

支付系统

微信支付对接

支付宝对接

银联对接 开发

分布式调度系统

数据统计

数据同步

任务调度配置

后台系统

日常管理

在线IM系统(websockedNIO)

用户行为分析(日志系统设计)

报表大数据查询优化(mysql查询优化)



欢迎大家加入Java高级架构/互联网:570210627 本群提供免费的学习指导 架构资料 以及免费的解答 不懂得问题都可以在本群提出来 之后还会有职业生涯规划以及面试指导 进群修改群备注:开发年限-地区-经验 方便架构师解答问题

性能优化

性能调优

JVM调优

Java程序性能优化

Tomcat

Mysql


应用框架源码解读

Spring概述

Spring容器

Spring AOP

Spring MVC

Spring 5新特性

Mybatis

分布式架构

分布式架构思维

架构开发基础


架构核心服务层技术


分布式环境指挥官Zookeeper

分布式消息通讯 异步于MQ


分布式缓存Nosql

Redis


Memcached

缓存开发专题

MongoDB

数据存储

高并发分流技术Nginx


分布式常见场景解决方案


微服务架构

Springboot

SpringCloud

Docker虚拟化技术



团队协作开发

Git

Maven

Jenkins

Sonar

B2C商城项目实战


转载于:https://juejin.im/post/59b0e4a75188252449137e2f

你可能感兴趣的:(成为一名Java高级架构师到底需要学习什么?)