关于JAVA架构师

前言:

在计算机软件行业内,大致把程序员分为四级

(1)初级Java程序员的重心在编写代码、运用框架;

(2)中级Java程序员重心在编写代码和框架;

(3)高级Java程序员技术攻关、性能调优;

(4)架构师解决业务和技术问题;

一.架构师工作职能

软件架构师在整个软件开发过程中都起着重要的作用,并随着开发进程的推进而其职责或关注点不断地变化,在需求阶段,软件架构师主要负责理解和管理非功能性系统需求。

比如软件的可维护性、性能、复用性、可靠性、有效性和可测试性等等,此外,架构师还要经常审查客户及市场人员所提出的需求,确认开发团队所提出的设计;在需求越来越明确后,

架构师的关注点开始转移到组织开发团队成员和开发过程定义上;在软件设计阶段,架构师负责对整个软件体系结构、关键构件、接口和开发政策的设计;在编码阶段,

架构师则成为详细设计者和代码编写者的顾问,并且经常性地要举行一些技术研讨会、技术培训班等;随着软件开始测试、集成和交付,集成和测试支持将成为软件架构师的工作重点;在软件维护开始时,

软件架构师就开始为下一版本的产品是否应该增加新的功能模块进行决策。

成为java架构师所需要具备那些技能?

首先你要是一个高级java工程师,熟练使用各种框架,并知道它们实现的原理。

(1)JVM虚拟机原理、调优,懂得jvm能让你写出性能更好的代码;

(2)池技术,什么对象池,连接池,线程池;

(3)Java多线程同步异步;

(4)Java各种集合对象的实现原理;

(5)熟练使用各种数据结构和算法,数组、哈希、链表、排序树;

(6)熟练使用linux操作系统;

(7)熟悉tcp协议;

(8)熟悉http协议;

(9)系统集群、负载均衡、反向代理、动静分离,网站静态化;

(10)分布式存储系统nfs,fastdfs,tfs,Hadoop了解他们的优缺点,适用场景;

(11)分布式缓存技术memcached,redis,提高系统性能必备;

(12)数据库的设计能力,mysql必备;

(13)还有队列中间件。如消息推送;

想成为架构师不是懂了一大堆技术就可以了,这些是解决问题的基础、是工具,不懂这些怎么去提解决方案呢?这是成为架构师的必要条件。

架构师还要针对业务特点、系统的性能要求提出能解决问题成本最低的设计方案才合格,架构师的作用就是第一满足业务需求,第二最低的硬件网络成本和技术维护成本。

架构师还要根据业务发展阶段,提前预见发展到下一个阶段系统架构的解决方案,并且设计当前架构时将架构的升级扩展考虑进去,做到易于升级;否则等系统瓶颈来了,

出问题了再去出方案,或现有架构无法扩展直接扔掉重做,或扩展麻烦问题一大堆,这会对企业造成损失。

二.源码分析

源码分析是一种临界知识,掌握了这种临界知识,能不变应万变,源码分析对于很多人来说很枯燥,生涩难懂。

源码阅读,最核心有三点:技术基础+强烈的求知欲+耐心。

阅读源码的最核心驱动力。绝大多数程序员,对学习的态度,基本上就是这几个层:

三.分布式架构

分布式系统是一个复杂且宽泛的研究领域。

总的来说,分布式系统要做的任务就是把多台机器有机的组合、连接起来,让其协同完成一件任务,可以是计算任务,也可以是存储任务。

如果一定要给近些年的分布式系统研究做一个分类的话,大概可以包括三大部分:

(1)分布式存储系统;

(2)分布式计算系统;

(3)分布式管理系统;

四.微服务

为解决单体架构下的各种问题,微服务架构应运而生。与其构建一个臃肿庞大、难以驯服的怪兽,还不如及早将服务拆分。微服务的核心思想便是服务拆分与解耦,降低复杂性。

微服务强调将功能合理拆解,尽可能保证每个服务的功能单一,按照单一责任原则(Single Responsibility Principle)明确角色。

将各个服务做轻,从而做到灵活、可复用,亦可根据各个服务自身资源需求,单独布署,单独作横向扩展。

五.性能优化

不管是应付前端面试还是改进产品体验,性能优化都是躲不开的话题。

优化的目的是让用户有“快”的感受,那如何让用户感受到快呢?

(1)加载速度真的很快,用户打开输入网址按下回车立即看到了页面;

(2)加载速度并没有变快,但用户感觉你的网站很快;

性能优化取决于多个因素,包括垃圾收集、虚拟机和底层操作系统(OS)设置。有多个工具可供开发人员进行分析和优化时使用,

可以通过阅读 Java Tools for Source Code Optimization and Analysis 来学习和使用它们。

必须要明白的是,没有两个应用程序可以使用相同的优化方式,也没有完美的优化 java 应用程序的参考路径。使用最佳实践并且坚持采用适当的方式处理性能优化。

想要达到真正最高的性能优化,你作为一个 Java 开发人员,需要对 Java 虚拟机(JVM)和底层操作系统有正确的理解。

 

六.并发编程

并发编程是Java程序员最重要的技能之一,也是最难掌握的一种技能。它要求编程者对计算机最底层的运作原理有深刻的理解,

同时要求编程者逻辑清晰、思维缜密,这样才能写出高效、安全、可靠的多线程并发程序。

原文地址:https://www.cnblogs.com/ZJOE80/p/9911857.html