来自:袁鸣凯

来源:CSDN博客

   正文   

来点轻松的话题。我们调剂一下后再继续讲CAS SSO单点登录吧因为后面的内容全部和代码有关,大家会觉得枯燥。所以今天我们先来点”番外篇“,讲讲什么是架构师,什么是架构这个永恒的话题吧。此篇源出自我在公司内部写的一个PPT,它是用于在公司内部向广大技术人员做普及用的一个资料,而CSDN这边的编辑不支持图文混排的效果,因此一些章节我就直接截取自我的PPT里的内容了,这样可能对大家在阅读上会显得更加生动和活泼一些吧。架构的定义

  • 一个程序和计算系统软件体系结构是指系统的一个或多个结构。结构中包括软件的构建,构建的外部可见属性以及它们之间的相互关系。
  • 体系结构并非可运行软件。确切的说,它是一种表达,使软件工程师能够:
    • 分析设计在满足规定需求方面的有效性。
    • 在设计变更相对容易的阶段,考虑体系结构可能的选择方案。
    • 降低与软件构造相关联的风险。
软件架构的生命周期

软件开发有其生命周期,它应该是:

而软件架构也有着其生命周期,它又是怎么样的呢?
软件架构的重要性

为什么说一个软件架构是很重要的呢?直接编程直接开发,多EASY?请看下面几点:

  • 软件架构能够满足系统的品质
  • 架构设计使受益人达成一致的目标
  • 架构设计能够支持计划编制过程
  • 架构设计对系统开发的指导性
  • 架构设计能够有效地管理复杂性
  • 架构设计为复用奠定了基础
  • 架构设计能够降低维护费用
  • 架构设计能够支持冲突分析
什么是好的软件架构

这个问题,可能大家一直都在问,包括一些IT企业也在问,对于这个问题的回答,可能不仅仅是一个简单的语句或者是定义就可以回答的出的,我们来看下面的几个形象的例子:

这个是什么东东呢?乐高玩具,乐高玩具大家肯定都玩过吧?

它即可以以一个完整的模型卖给你,你也可以把它全部打碎了重新从一个模型自由的再去组装成另一个模型,因为每一个乐高的模块在横向、坚向里都有标准的接口,这就是我们常说的高内聚、低耦合。

什么又是糟糕的架构

大家看看上面这幅图是什么?

一个是清代的八股文,一个是孔乙己。还记得回字的四种写法吗?那么你专门就研究回字的四种写法 ,但你有没有想过我把回字折开来又可以变成几个字?是否好折?

要知道最时髦的并不一定是最好的

为什么M1A2和阿帕奇直升机里不用A8处理器,或者是最新的奔腾处理器啊?实用、经过检验的才是最好的!

成功的软件又是怎么样的呢

我们谈的是软件架构,架构的最终体现是一个软件,那么什么是成功的架构什么是成功的软件呢?

大家看左边的这个图,是美国的“阿利伯克级”宙斯盾驱逐舰,右边的是印度模仿美国的宙斯盾自己设计和建造的”德里级”的“咖喱盾”驱逐舰。

两艘战舰一对比,怎么样?

  • 一个是模块化的设计,整体线条流畅,战损时模块可以任意替换。
  • 一个却是拼拼凑凑,线路外露,甲板上布满了各种电子设备和天线,一旦战损,极难维护
架构之美

架构,架构,到底什么是架构?我以前上大学时有一个70多岁的老教授,他上课每讲20分钟左右,需要2个同学”架“着去上一次WC,我们的架构师当然不是指这种”架构师“。那么我们一直说的架构,到底它是一个什么样的东西呢?怎么样又可以做出一个完美的架构呢?

架构就像是迷踪拳

动作轻灵敏捷,灵活多变,它其实违背一切传统拳法,因此可以克敌制胜。

架构就像是独孤九剑,破剑式、破枪式、无招胜有招,它发源于传统武术,又扩展了传统的武术

架构就像是一件艺术珍品,有时一个看似简单的架构往往却是一件艺术珍品。

大家知道这幅画吗?他是挪威画家蒙克的一幅作品叫”呐喊“,蒙克这个人是一个疯子,这幅画很简单,就是随手涂鸦一般,但是大家可知道这幅画值多少钱吗?2012年该画在纽约苏富比拍卖上以1.19亿美元被拍卖。

架构的意境

一个好的架构不应该受限于框架,受限于语言,受限于技术,受限于各种条条框框,它是一种意境。

架构时需要考虑的几个基本因素

JAVA通用领域的相关技术

当然,我们这边主要说的是JAVA,那么作为一名学习JAVA、J2EE的架构师来说,要具备一些什么样的技能才能达到架构师的水平呢?

上面这张图,我们这样来看,它分为3个部分:
  • 顶部,是我们需要掌握的一些技术领域的知识,它可以使我们应对通用领域如电商、企业OA、银行保险金融等领域的一些解决方案和设计
  • 中部,为了达到顶部这些技术我们需要了解的一些中间件、数据库、开发框架这些知识,它是一根支柱
  • 底部,底部呢?它是我们的基础,为铺设我们通向中间或者更上层的一个基石,这也是为什么大家有时发觉我的博客和其它博客有不一样的地方,不仅仅有编程还有”中间“的这一层即数据库、性能、安全、框架搭建这些东西混合在里面的原因,因为我不希望大家通过阅读完了我的博客还只是停留在一个码农、码工、螺丝钉的这种水平上。
架构师的职能

说了这么多架构,我们来说说架构师吧。

大家看到了没有,架构师的第一职责就是关注:non-functional requirements,即非功能性需求。很多人对功能性需求和非功能性需求的界线划分还是不清楚,我这边举2个例子说明一下吧:

功能性需求

页面查询,这个查询是关联哪些哪些数据库表,因为我的业务是有这样这样的需求,在界面A里点了一个按钮,然后弹出窗口B,在窗口B里要显示什么样的数据,最后界面A里点完后,当我打开界面B时哪块数据已经随之发生了更改。

非功能性需求

我们的系统查询速度小于2S,是否考虑使用异步查询、使用队队列机制,系统要求可以容纳1000个并发,这个系统要可以做成插件式的,要可以横向扩展,要符合XXX协议,这个Webservice要做成SOAP HEAD内带有BASIC认证,还是做成符合NTLM的认证的,还是使用令牌环认证的?这个下拉框要做成即可输入又可以下拉的,这块认证要访问LDAP?

很多以业务为主的项目型公司认为架构师就是trouble shooting(即排错、查错的意思,就是有错误、出问题了再找架构师),把架构师当成了fireman(救火员),可是你不自己想想为什么出了问题架构师过来2秒、2分钟或者1天半可以解决你们1个月几十人天天到零晨也解决不了的问题呢?嗯?

解决了说这是人家应该的,解决不了,说人家架构师不合格呢?是不是我们应该从这个软件最早的框架上、架构上去发现一下问题呢?

架构师啊,这不是一个trouble shooting的问题啊。

在节前我也进行了一些面试,出于纯技术角度来说,即走架构师,TECH LEADER这样的路线的侯选人。我还是发觉了不少的问题这也是中国的一个通病:即我们的程序员,很多时候不是在做程序,而更多时候是在做业务逻辑,成了一个某一领域的业务人员了。

当然,我们的程序员在其职业生涯的前3年、4年都是做某一块领域的代码的,这个是没有问题的,但是请一定一定记住,我们是编码,是IT,是程序员,不是“业务人员”!!!

什么是IT?什么是程序员?什么是Tech Leader?什么是架构师?这个问题大家有必要好好的去问一下自己,去好好的想一下,架构师的要求是什么?

我这边随便说一些东西:相信对一些要走技术道路的同学们是有帮助的:

TCP/IP协议,加密解密,计算机原理(增补反码),JPG码,MPEG2-3协议,逻辑电子电路,计算机编译器原理(堆、栈、队列),这些东西你平时工作时一直用到吗?这些是你一直关注的底层吗?

如果你是要走技术路线,一定一定请记得“数据库+ASP/JSP”不是技术,它只比表单制作,报表制作人员稍微强了那么一点点。

请一定记住,技术路线关注的是非功能性需求,非功能性需求啊,就是一种一通百通的东西,有了这块底蕴,任何需求和你说清了,对你来说是没有任何“难度”的,或者你再去学,是可以举一反三的啊。

最近一直面试一些侯选人,做架构师的,在此过程中我对此深有感受,找一个程序员开发不难,招一个架构师,难。。。唉,我觉得大家有必要要考虑一下,如果我走技术路线,我缺什么,我怎么补,还要关注些什么?

科技是第一生产力,管理方法论中的所谓的六SIGMA即六西格玛的第一条就是“技术人才是当下企业的第一生产力”,大家看看能够发财的是哪些公司?阿里,淘宝,支付宝,GOOGLE, 通讯,互联网,高科技等等等一些企业,他们靠的不是业务逻辑,而是真正的技术,这足以说明问题了,所以大家如果要走技术道路,请多关注一下更细节,更底层的东西吧。

这也是为什么我在之前的博文中所阐述的那些东西的原因,可见企业IT项目开发之七宗罪。

第一宗罪:重业务不重技术
    第二宗罪:编程开发人员沦为业务开发人员、沦为码农
    第三宗罪:IT市场沦为自由市场、小菜场一样的叫买
    第四重罪:技术无用论的诞生
    第五宗罪:闭门造车,与实际脱节,完全抛弃业务
    第六宗罪:消极怠工 
    第七宗罪:不思进取

架构师的分类

一般会把架构师分为:

  • 业务架构师即BA
  • 系统架构师SA
其实从严格意义上业说架构师是可以分成三类的:

一般就是把系统架构师和应用架构师合成一类。这个从本质上来讲倒没有什么太大的区别,不伤大雅。

架构师会做什么

一个架构师在一个团队中或者说在一个企业中它具体要做哪些日常工作呢?

架构师并不是万能的

架构师很牛B,可是架构师也是人,他不是超人。

架构师需要掌握的软技巧

技术,是架构师的Hard Skill,那么架构师的Soft Skill有哪些呢?

架构师不是皇冠上的明珠

大家一定一定要记住,架构师决不是像大家想像中的那样,是所谓的皇冠上的明珠,架构师承担的责任是相当的大的。


如何成为架构师

人类是如何进化的?学习、使用工具、社会协作性、不断的总结经验。


架构师也会退化到比一般的程序员都不如。如果停止了学习的步伐,那么。。。。。。

谈架构师的自我修养

学习之道

需要掌握的基本功中的基本功

大家注意,上面这个列表在学习时是有先后顺序的,从上至下分别为第一步,第二步,第三步。。。。。。不要觉得枯燥,你可以去试试,真的,被折腾着和被快乐着。Bad artist copy good artist steal

放正你的心态
不断的需要自我激励
成功的唯一方法便是,承认现实,超越现实,鼓起勇气并善用它。
  • 学会平静的对待生活中的不完美之处,适应自己的情绪,了解如何让它们自然宣泄出去
  • 学习如何把不完美的地方转换成我们的优势,激发我们的创造力
  • 自我激励,不管外部条件是否有激励性,找到一种激发最佳状态的情绪,学习如何在我们的意识中制造一些波动来激励我们前进

正文结束

推荐阅读 ↓↓↓

1.

2.

3.

4.

5.

6.

7.

8.

一个人学习、工作很迷茫?

点击「阅读原文」加入我们的小圈子!

一个架构师谈什么是架构,以及怎么成为架构师相关推荐

  1. 阿里P8架构师谈:微服务Dubbo和SpringCloud架构设计、优劣势比较

    本文主要围绕微服务的技术选型.通讯协议.服务依赖模式.开始模式.运行模式等几方面来综合比较Dubbo和Spring Cloud 这2种开发框架.架构师可以根据公司的技术实力并结合项目的特点来选择某个合 ...

  2. 阿里P8架构师谈:从单体架构、到SOA、再到微服务的架构设计详解

    本文涉及的内容以及知识点如下: 1.单体架构 2.单体架构的拆分 3.SOA与微服务的区别 4.微服务的优缺点 5.微服务的消息 6.服务集成 7.数据的去中心化 单体架构 Web应用程序发展的早期, ...

  3. 阿里P8架构师谈:Zookeeper的原理和架构设计,以及应用场景

    什么是 Zookeeper Zookeeper 分布式服务框架是Apache Hadoop 的一个子项目,它主要是用来解决分布式应用中经常遇到的一些数据管理问题,如: 统一命名服务 状态同步服务 集群 ...

  4. 阿里P8架构师谈:Restful、SOAP、RPC、SOA、微服务之间的区别

    内容大纲: 1.介绍Restful.SOAP.RPC.SOA以及微服务 2.重点谈谈SOA与微服务的区别 3.以及为什么要使用微服务架构 什么是Restful Restful是一种架构设计风格,提供了 ...

  5. 阿里P8架构师谈:Dubbo的详细介绍、设计思路、以及4大适用场景

    Dubbo是什么? Dubbo是一个分布式服务框架,致力于提供高性能和透明化的RPC远程服务调用方案,以及SOA服务治理方案. 简单的说,dubbo就是个服务框架,如果没有分布式的需求,其实是不需要用 ...

  6. 高并发架构系列:Spring Cloud的核心成员、以及架构实现详细介绍

    高并发架构系列:Spring Cloud的核心成员.以及架构实现详细介绍 什么是微服务 微服务的概念源于Martin Fowler所写的一篇文章"Microservices". 微 ...

  7. 一个架构师谈什么是架构以及怎么成为一个架构师--转载

    原文地址:http://blog.csdn.net/lifetragedy/article/details/43925857 新年新事,来点轻松的话题.我们调剂一下后再继续讲CAS SSO单点登录吧因 ...

  8. 一个15年的架构师谈“如何成为一名优秀的解决方案架构师”

    摘要:且听有着15年软件研发.架构经验的华为云MVP魏群娓娓道来,如何成为一名合格的解决方案架构师? 架构师,这是一个在技术人员,特别是软件开发人员眼中具有神圣色彩的岗位. 团队中有了架构师,就是有了 ...

  9. psql where里有自定义函数慢_阿里P8架构师谈:MySQL慢查询优化、索引优化、以及表等优化总结...

    MySQL优化概述 MySQL数据库常见的两个瓶颈是:CPU和I/O的瓶颈. CPU在饱和的时候一般发生在数据装入内存或从磁盘上读取数据时候. 磁盘I/O瓶颈发生在装入数据远大于内存容量的时候,如果应 ...

  10. 阿里P7架构师谈:MySQL慢查询优化、索引优化、以及表等优化总结

    MySQL优化概述 MySQL数据库常见的两个瓶颈是:CPU和I/O的瓶颈. CPU在饱和的时候一般发生在数据装入内存或从磁盘上读取数据时候. 磁盘I/O瓶颈发生在装入数据远大于内存容量的时候,如果应 ...

最新文章

  1. c++ stack 的使用
  2. linux 输出重定向_Linux--文件描述符和stdin,stdout,stderr
  3. HashMap,LinkedHashMap,TreeMap的有序性
  4. android 只输入数字与小数点_Android金额输入框只允许输入小数点后两位效果
  5. Zookeeper集群的搭建及遇到的问题
  6. dw按钮图片滚动js_轮播图--swiper插件/原生js/jQuery
  7. Spark RDD的默认分区数:(spark 2.1.0)
  8. Luogu P3953 逛公园
  9. python两个中文队列比较_具有两个优先级的优先级队列Python
  10. QT每日一练day15:QColorDialog颜色对话框
  11. Unable to round-trip http request to upstream: EOF问题
  12. ASP.NET AJAX应用
  13. 遇到INSTALL_FAILED_VERIFICATION_FAILURE怎么办
  14. 【韦东山嵌入式Linux】vi编辑器入门笔记
  15. 【微信小程序】开发、测试、上线全流程梳理总结
  16. 计算机信息管理员笔试面试题,网络管理员笔试题目
  17. linux非连续内存,(转)linux高端内存管理之非连续内存区(分配和释放)
  18. android使用Vitamio实现视频播放大小屏流畅切换
  19. 基于unity3D的趣味桌球游戏开发
  20. F. Equalize the Array【学习进度条2】

热门文章

  1. Android 音视频深入 十九 使用ijkplayer做个视频播放器(附源码下载)
  2. 删除xcode中的描述文件的路径
  3. CentOS 6.5编译安装MySQL5.7.7rc
  4. 查看apache的日志与状态
  5. C#中调用Windows API的要点 .
  6. C#正则表达式之字符替换!...
  7. codeforces D. Palindrome pairs 动态规划
  8. Illustrator 教程,如何在 Illustrator 中创建和编辑作品?
  9. 苹果mac视频音频格式转换软件:Permute
  10. 如何开始在 Mac 上使用快捷方式?