您当前的位置:首页 > 电脑百科 > 程序开发 > 框架

阿里p8架构师谈:到底什么是架构师

时间:2019-11-14 09:55:40  来源:  作者:

阿里p8架构师谈:到底什么是架构师

 

  • 哲学家常思考的问题:" 我是谁?"" 我从哪里来?"" 要到哪里去?不只是哲学家,我想每个人都有自己对这三个问题的认知。
  • 如果我们要成为架构师,我们自己要面临的三大问题:
  • 找准自己定位:我是谁?在哪里?
  • 怎样做好架构师:我要做什么?
  • 如何搭建架构师知识体系:我该怎么做?
  • 这里面就是做事方法论:目标(我要做什么),方法(计划)(我该怎么做), 执行/行动
  • 找准自己定位:我是谁?在哪里?
  • 怎样做好架构师:我要做什么?
  • 如何搭建架构师知识体系:我该怎么做?
  • 这里面就是做事方法论:目标(我要做什么),方法(计划)(我该怎么做), 执行/行动

一、架构师定义

什么是架构师,这个聊架构话题时永恒的问题。每个公司对架构师的定位也有所不同,因为不同公司所处的阶段,业务模式,应用场景也都不一样。对架构的要求也不一样。

在初创公司的野蛮生长阶段:业务场景和需求边界很难把握,有时候根本不需要架构师,产品需要快速迭代和变现,需求频繁更新,这个时候需要的是快速实现。当然如果公司成长以后,这个阶段就是欠下很多技术债,埋下很多坑,如果人员流动很频繁,后期系统维护成本是非常巨大的。

在公司成长稳定阶段:业务模式和应用场景边界都已经比较清晰,这个时候最需要架构师需要架构师能对线上业务进行模块划分,系统拆分重构,并做好相关高可用的措施,以保证系统的稳定,安全、高效地运行。

不同的行业,对架构师的要求也不同,比如电商业务和AI领域,从架构到业务场景,完全是两个物种。

在百度百科里面这么定义: 系统架构师是一个既需要掌控整体又需要洞悉局部瓶颈并依据具体的业务场景给出解决方案的团队领导任务。具体来说是一个确认和评估系统需求,给出开发规范,搭建系统实现的核心构架,并澄清技术细节、扫清主要难点的技术人员。主要着眼于系统的“技术实现”。因此架构师应该是特定的开发平台、语言、工具的大师,对常见应用场景能马上给出最恰当的解决方案,同时要对所属的开发团队有足够的了解,能够评估自己的团队实现特定的功能需求需要的代价。系统架构师负责设计系统整体架构,从需求到设计的每个细节都要考虑到,把握整个项目,使设计的项目尽量效率高,开发容易,维护方便,升级简单等。

架构师实际上就是软件的总体设计师。打个通俗的比方比如某个工程总设计师,类似三峡工程的总设计师。

架构师的形成一定是在实践中积累起来的,而并非上了几次培训班,读了几本书就可以成功的,架构师是在工程实践中培养出来的!

二、架构师作用/职责

架构师在整个软件系统开发过程中都起着重要的作用,并随着开发进程的推进而其职责或关注点不断地变化。

1、按软件开发过程维度来说:

需求阶段:软件架构师主要负责理解和管理非功能性系统需求,比如软件的可维护性、性能、复用性、可靠性、有效性和 可测试性等等,此外,架构师还要经常审查和客户及市场人员所提出的需求,确认开发 团队所提出的设计;

架构设计阶段:架构师负责对整个系统架构设计,制定开发规范、开发计划,指导整个开发团队完成这个计划。

开发阶段:架构师则成为详细设计者和代码编写者的顾问,并且经常性地要举行一些技术研讨会、技术培训班等;

测试和交付阶段:协调做好相关测试和部署。

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

2、按职能维度:

1)确认需求

架构师要懂得用户需求,理解用户真正想要什么,这使得架构师必须要和分析人员不断沟通,反复确认需求规格说明书,以此来保证他精准清楚用户需求。

项目经理刘先生在受访时说:「架构师会与很多人沟通,例如开发人员,例如我们项目经理,有时甚至是用户本身。架构设计的目的很明确,目的是什么呢?挖掘用户需求。」

2) 系统分解

在架构师认可需求规格说明书后,架构师已明确用户需求是是什么,这时候便看架构师的分解能力了。

系统分解包括纵向分解和横向分解:

横向分解是对系统分解成不同的逻辑层,确定层与层之间的关系。是指基于技术架构层次进行的人员角色分工和任务分解。常见的分层:

应用层:主要负责具体的业务逻辑处理

服务层:提供可复用的服务

数据层:负责数据的存储和访问

分层注意事项:①必须合理规划层次边界和接口;②禁止跨层次的调用及逆向调用。

纵向分解是将不同的功能和服务分割开来,包装成高内聚低耦合的模块单元,有助于软件开发和维护,还便于不同模块的分布式部署,提高网站的并发处理能力和功能扩展能力。

3) 技术选型

在系统分解后,架构师会最终形成软件整体架构,接下来,架构师的职责是技术选型。

前端到底用瘦客户端还是富客户端呢?数据库是用MySQL还是MSSQL又或是Oracle呢?技术选型是非常重要的环节,因为需要了解每种技术的优缺点,如果没有足够经验和深厚的技术功底,技术选型很茫然。

架构师在技术选型阶段会提供参考信息给项目经理,项目经理再从预算、进度、人力、资源等各方面情况来权衡,最终确认。

4) 制定开发规范

架构师在项目开发过程中是「灵魂人物」,并且要具备协调组织能力和懂得人员分工。

在制定技术规格说明阶段,架构师要协调起所有的开发人员,架构师通常会用技术规格说明书与开发人员保持沟通,让开发人员能从各个视角去观测、理解他们负责的模块或者子系统,确保开发人员能够按照架构意图实现各项功能。

3、必备技能关注点:

1)、方向规划:

有想法和技术展望目标,制定短期目标

2)、架构设计:

集思广益来设计,归类总结,根据讨论结果制定规范。设计不仅仅是技术相关(业务流程,业务方向,模块划分组合,框架设计,流程纰漏等),设计出来还是需要实施的。

3)、技术攻关:

疑难技术点攻关,将问题集中化解决,提供平台化解决方案以及选型决策。

4)、解决疑难问题:

定期做总结归纳以此分析问题,解决问题。

发现各类型问题(不仅仅是技术),通过规范,演讲,绘图等方式解决隐患。

5)、互动沟通:

架构通过团队的沟通总结出方向, 部门之间沟通,开发之间沟通,产品之间沟通,市场沟通,沟通后产出图形化文档及设计。

6)、开发规范:

确保系统秩序,统一,规范,稳定,高效地运行。

架构师无论多牛B,但一定要记住架构是要靠团队做出来的:

•架构师:架构通过团队的沟通总结出方向

•RD:研发人员经常提出自己碰到的问题,并分享给大家,思维碰撞促进发展

•PM:产品经常提出设想和规划,能够使得架构符合未来发展需求

•OP:运维经常提出隐患及分析,能使得架构快速拆分模块

•架构师:定期做总结归纳以此分析问题,解决问题

•团队:团队成长、就是每个人的成长、每个人成长眼界自然增长

•团队:团队的成功、就是产品的成功,产品的成功就是公司的成功

公司的成功可以给你加光环,但光环不代表自己的能力代表经历

三、架构师分类

其实架构师就是个title,每个公司称呼都可能不一样,和架构概念一样。

软件架构师:

软件架构师是软件行业中一种新兴职业,工作职责是在一个软件项目开发过程中,将客户的需求转换为规范的开发计划及文本,并制定这个项目的总体架构,指导整个开发团队完成这个计划。主导系统全局分析设计和实施、负责软件构架和关键技术决策的人员,比如这些架构师的title可能是JAVA架构师、Python架构师、LAPM架构师等等。

web架构师:

web架构师是网站系统、功能、模块、流程的设计师,架构师,好比是高楼大厦的设计人员,通常一座大厦在建之前,都先由设计师将蓝图描绘出来,包括其形状、结构、尺寸、材料等等,然后建筑工程师带领工人们按照蓝图将大厦一层一层地建起来

架构师也要看在什么样的公司,中小公司很多架构师都是全能的。通常公司规模和体系越大,分工会越细:大体可以这么分类:

解决方案架构师:与客户探讨业务需求,将业务、市场,与技术、产品结合起来,为客户提供解决他们需求的方案。比如阿里云针对大客户都有解决方案架构师。

系统架构师: 也称应用架构师。最终确认和评估系统需求,并将业务转换为技术,为研发人员制订核心框架与技术规范 为研发工作澄清技术细节并扫清技术障碍 。服务器负载,可靠性,伸缩,扩展,数据库切分,缓存应用

平台架构师:

这里的平台其实包括两个平台,一个是系统平台,也就是负责搭建多个系统整合的系统应用平台;另外一个其实是基础平台,是专门负责搭建基础技术平台;两者其 实区别蛮大,也经常容易被从业人员混乱。举个简单例子,金蝶有平台架构师一职,但是金蝶BOSS应用和金蝶中间件两者招聘的对象和技术要求是截然不同的。

业务架构师:业务架构其实已经开始脱离技术层面了,但是它要求架构师有跨越多系统的大局观,去整合和组织不同系统的技术平台与交互模式。其实这个职位的未来也就是CIO了。 主要内容:理解业务,梳理模型,设计模式,接口,数据交互。

网络架构师:

过去,我们可能听的最多的是网络工程师。不错,一个优秀的网络架构师必须有足够的网络技术基底,并且它的关注点也是系统的基础架构。比如说如果搭建并优化集群环境,如果构建基于云计算的系统应用与部署等等。它对于像淘宝、腾讯这样的互联网公司是极其重要的。

移动架构师:

移动互联网的迅猛发展横向和纵向都细分出了很多新的职责和岗位,移动架构师的职责和作用日益重要,既要整体和全局考虑整个前后端的软件系统架构,又要重点深入移动客户端的架构设计的方方面面,既要有跨平台思维,又要拿捏好原生和混合开发的尺度,另外移动应用的特点,导致移动架构师必须要比传统系统架构师更加注重非功能性的质量属性。

前端架构师:

这也是移动互联网的迅猛发展而细分出来的新的职责和岗位,这里的前端特指网站开发中的前端,主要考虑前端呈现层的设计(html/css/JS/AJAX/RIA/…),跨浏览器设计等等。

大数据架构师:

比如某些公司做大数据处理,需要理解业务,并通过大数据相关技术来实现。

。。。。。。

四、架构师具备素质能力

• 精通某项技术,能够从本质上类比,触类旁通其他技术

• 对等所有技术,只有合适和不合适,没有喜欢和不喜欢。

• 视野开阔,了解不同技术的优缺点。知道使用某项开源技术实现某项业务需求,能够辨别重复造轮子。

• 精通设计模式,但又不泛用。

• 把系统拆分成多个子系统或模块。模块之间尽量松耦合,使得原先串行的开发任务变得可以并行发展。

• 能清楚系统的瓶颈在什么地方, 不断定位技术难度,开发进度,性能,内存等个方面的瓶颈。不断调整骨干力量解决瓶颈,在风险爆发之前消除隐患。

• 能做好前瞻性设计,预判到需求可能产生的变化。

架构师团队内做的事情

•沟通能力:各个方面都要了解,人人想法及规划都要知道,了解产品思想,用了什么方法实现的

•组织能力:组织推动各种技术的改进及功能的完善

•谈判代表:左右两难的时候的调解人

•设计模块及业务:通过图形化设计发现开发后才会发现的业务问题

•成本规划:通过过往经验评估成本及步伐

•愿望收集:不断收集建议及愿望,一步步实现

•传播布道:不断参与行业交流,提高理论及技术知识科普分享团队

五、架构师职场攻略

《大型网站技术架构+核心原理与案例分析》总结:

架构师需要处理好个人、团队、公司的利益。需要不断的在工作中发现问题,解决问题,提升工作经验,知识技能和核心竞争力。扩大自身影响力,达成工作绩效。

1、发现问题,寻找突破

即使在一流的技术团队,也有数不清的问题,团队人员已经习惯这些积重难返的问题,而且解决问题投入产出比不大。例如:

1)数据库线程池存在安全漏洞。

2)版本管理混乱。

作为一个新人,从局外旁观者的视角看待,自然发现很多问题。如果新人急于表现自己,证明自己,往往是事与愿违,四处碰壁。因此新人要先融入团队,和团队共进退,等熟悉情况,了解问题深浅,再寻找突破口,择机而动。

2、提出问题,寻求支持

1) 把“我的问题”表述成“我们的问题”:

人们都不喜欢问题,问题意味着麻烦。当人们听到你说,“我遇到一个问题的时候”,下意识的远离你的问题。 如果需要他们的支持,就想办法把你的问题变成他们的问题,是他遇到了问题,而你来帮忙解决。

既然你也是团队一员,问题表述为“我们的问题”。

1) 给上司提封闭式问题,给下属提开发式问题:

上司一般是做决策,因此给上司提问需要给出建设性的方案或者建议,然后希望得到他的支持,给上司提问:“你觉得A和B哪个方案更好?”

给下属则相反,用开放式的问题启发他去思考,寻找创新的解决方案。“元芳,这个问题你怎么看?”

3) 指出问题而不是批评人:

如果遇到问题,不要责问他为什么出现问题,而是说问题的紧迫性和解决的优先级。

4)用赞同的方式提出问题:

如果人们遇到:“你这里有问题”可能会本能自我保护而拒绝你的建议。

而如果这么说“我非常赞同你的方案,但是我有个小小的建议”。

3、解决问题,达成绩效

在解决我的问题之前,先解决你的问题:

适当的逃避问题:比如我去开个会,回来再回答的你问题。



Tags:架构师   点击:()  评论:()
声明:本站部分内容及图片来自互联网,转载是出于传递更多信息之目的,内容观点仅代表作者本人,如有任何标注错误或版权侵犯请与我们联系(Email:2595517585@qq.com),我们将及时更正、删除,谢谢。
▌相关推荐
为了构建高并发、高可用的系统架构,压测、容量预估必不可少,在发现系统瓶颈后,需要有针对性地扩容、优化。结合楼主的经验和知识,本文做一个简单的总结,欢迎探讨。1、QPS保障目标...【详细内容】
2021-12-27  Tags: 架构师  点击:(5)  评论:(0)  加入收藏
本系列为 Netty 学习笔记,本篇介绍总结Java NIO 网络编程。Netty 作为一个异步的、事件驱动的网络应用程序框架,也是基于NIO的客户、服务器端的编程框架。其对 Java NIO 底层...【详细内容】
2021-12-07  Tags: 架构师  点击:(17)  评论:(0)  加入收藏
1 概述数据结构和内部编码 无传统关系型数据库的 Table 模型schema 所对应的db仅以编号区分。同一 db 内,key 作为顶层模型,它的值是扁平化的。即 db 就是key的命名空间。 key...【详细内容】
2021-11-01  Tags: 架构师  点击:(28)  评论:(0)  加入收藏
前面已经聊到了如何做高层架构设计,并开始让设计落地,去划分了系统边界,进行了服务和模块的拆分,也就是系统的整体轮廓已经有了。接下来,就该来做整体的技术架构设计了。其实做架...【详细内容】
2021-09-17  Tags: 架构师  点击:(77)  评论:(0)  加入收藏
有朋友或许感兴趣到底什么是解决方案架构师,也肯定有一些人心里充满了困惑:1、架构师又跑售前又做项目,到底是干嘛的?如何成为一个架构师?2、经常听人说方案,究竟什么是方案,怎么写...【详细内容】
2021-08-19  Tags: 架构师  点击:(107)  评论:(0)  加入收藏
第一章:认识SpringSpring认识框架spring全家桶: spring ,springmvc,spring boot,spring cloudspring:出现在2002左右,解决企业开发的难度,减轻对项目模块之间的管理。类和类之间的...【详细内容】
2021-06-24  Tags: 架构师  点击:(123)  评论:(0)  加入收藏
从事近十年的 JavaEE 应用开发工作,现任阿里巴巴公司系统架构师。对分布式服务架构与大数据技术有深入研究,具有丰富的 B/S 架构开发经验与项目实战经验,擅长敏捷开发模式。国...【详细内容】
2021-06-18  Tags: 架构师  点击:(114)  评论:(0)  加入收藏
分布式一致性算法概要随着各种高并发访问、海量数据处理等应用场景越来越多,为了应对这些使用场景,分布式系统应运而生。分布式系统得以发展,得益于诸多优点,比如:可以避免 单点...【详细内容】
2021-04-13  Tags: 架构师  点击:(238)  评论:(0)  加入收藏
前言我们可以从java.io.InputStream类中看到,抽象出一个read方法,用来读取已经打开的InputStream实例中的字节,每次调用read方法,会读取一个字节数据,该方法抽象定义,如下所示:publ...【详细内容】
2021-04-09  Tags: 架构师  点击:(161)  评论:(0)  加入收藏
昨天有网友问我,他原先没有学过奥数,问能不能当系统架构师?其他也有人有疑问,是不是应该先学数学,然后在考研的时候转入计算机? 我先说一下结论,没有学过奥数,完全可以当系统架构师...【详细内容】
2021-03-09  Tags: 架构师  点击:(233)  评论:(0)  加入收藏
▌简易百科推荐
近日只是为了想尽办法为 Flask 实现 Swagger UI 文档功能,基本上要让 Flask 配合 Flasgger, 所以写了篇 Flask 应用集成 Swagger UI 。然而不断的 Google 过程中偶然间发现了...【详细内容】
2021-12-23  Python阿杰    Tags:FastAPI   点击:(6)  评论:(0)  加入收藏
文章目录1、Quartz1.1 引入依赖<dependency> <groupId>org.quartz-scheduler</groupId> <artifactId>quartz</artifactId> <version>2.3.2</version></dependency>...【详细内容】
2021-12-22  java老人头    Tags:框架   点击:(12)  评论:(0)  加入收藏
今天来梳理下 Spring 的整体脉络啦,为后面的文章做个铺垫~后面几篇文章应该会讲讲这些内容啦 Spring AOP 插件 (了好久都忘了 ) 分享下 4ye 在项目中利用 AOP + MybatisPlus 对...【详细内容】
2021-12-07  Java4ye    Tags:Spring   点击:(14)  评论:(0)  加入收藏
&emsp;前面通过入门案例介绍,我们发现在SpringSecurity中如果我们没有使用自定义的登录界面,那么SpringSecurity会给我们提供一个系统登录界面。但真实项目中我们一般都会使用...【详细内容】
2021-12-06  波哥带你学Java    Tags:SpringSecurity   点击:(18)  评论:(0)  加入收藏
React 简介 React 基本使用<div id="test"></div><script type="text/javascript" src="../js/react.development.js"></script><script type="text/javascript" src="../js...【详细内容】
2021-11-30  清闲的帆船先生    Tags:框架   点击:(19)  评论:(0)  加入收藏
流水线(Pipeline)是把一个重复的过程分解为若干个子过程,使每个子过程与其他子过程并行进行的技术。本文主要介绍了诞生于云原生时代的流水线框架 Argo。 什么是流水线?在计算机...【详细内容】
2021-11-30  叼着猫的鱼    Tags:框架   点击:(21)  评论:(0)  加入收藏
TKinterThinter 是标准的python包,你可以在linx,macos,windows上使用它,你不需要安装它,因为它是python自带的扩展包。 它采用TCL的控制接口,你可以非常方便地写出图形界面,如...【详细内容】
2021-11-30    梦回故里归来  Tags:框架   点击:(27)  评论:(0)  加入收藏
前言项目中的配置文件会有密码的存在,例如数据库的密码、邮箱的密码、FTP的密码等。配置的密码以明文的方式暴露,并不是一种安全的方式,特别是大型项目的生产环境中,因为配置文...【详细内容】
2021-11-17  充满元气的java爱好者  博客园  Tags:SpringBoot   点击:(25)  评论:(0)  加入收藏
一、搭建环境1、创建数据库表和表结构create table account(id INT identity(1,1) primary key,name varchar(20),[money] DECIMAL2、创建maven的工程SSM,在pom.xml文件引入...【详细内容】
2021-11-11  AT小白在线中  搜狐号  Tags:开发框架   点击:(29)  评论:(0)  加入收藏
SpringBoot开发的物联网通信平台系统项目功能模块 功能 说明 MQTT 1.SSL支持 2.集群化部署时暂不支持retain&will类型消 UDP ...【详细内容】
2021-11-05  小程序建站    Tags:SpringBoot   点击:(56)  评论:(0)  加入收藏
最新更新
栏目热门
栏目头条