《软件架构设计之体会.ppt》由会员分享,可在线阅读,更多相关《软件架构设计之体会.ppt(39页珍藏版)》请在三一办公上搜索。
1、1,高级软件架构设计,2,目录,第一单元:软件生命周期与软件架构介绍2第二单元:技术架构视图面向对象程序设计原则与模式 24用GRASP模式指导设计27领域模型47面向对象设计的基本原则71第三单元:用UML辅助系统分析与设计103UML简介及常见疑难问题辨析104借鉴RUP的UML建模与分析117第四单元:设计模式与软件设计思想131设计模式132常用的软件架构风格及适用情况分析172SOA 及分层架构设计212第五单元:架构设计实践225,3,第一单元:软件生命周期与软件架构介绍,4,IT行业的人才结构与软件架构师的定位软件架构师应掌握的知识体系软件架构设计的特点、层次、分类软件架构的主要
2、理论、方向和趋势软件工厂,实现软件开发的产业化,5,软件架构师的定位,系统架构师的职责:一、理解系统的业务需求,制定系统的整体框架(包括:技术框架和业务框架)二、对系统框架相关技术和业务进行培训,指导开发人员开发。并解决系统开发、运行中出现的各种问题。系统架构师的目的:对系统的重用、扩展、安全、性能、伸缩性、简洁等做系统级的把握。系统架构师能力要求:一、系统架构相关的知识和经验。二、很强的自学能力、分析能力、解决问题的能力。三、写作、沟通表达、培训。,6,角色软件架构师Software Architect定义主导系统全局分析设计和实施、负责软件构架和关键技术决策的角色,7,职责领导与协调整个项
3、目中的技术活动(分析、设计和实施等)推动主要的技术决策,并最终表达为软件构架确定和文档化系统的相对构架而言意义重大的方面,包括系统的需求、设计、实施和部署等“视图”确定设计元素的分组以及这些主要分组之间的接口为技术决策提供规则,平衡各类涉众的不同关注点,化解技术风险,并保证相关决定被有效的传达和贯彻理解、评价并接收系统需求评价和确认软件架构的实现,8,专业技能技术全面、成熟练达、洞察力强、经验丰富,具备在缺乏完整信息、众多问题交织一团、模糊和矛盾的情况下,迅速抓住问题要害,并做出合理的关键决定的能力。具备战略性和前瞻性思维能力,善于把握全局,能够在更高抽象级别上进行思考。对项目开发涉及的所有问
4、题领域都有经验,包括彻底地理解项目需求,开展分析设计之类软件工程活动等。具备领导素质,以在各小组之间推进技术工作,并在项目压力下做出牢靠的关键决策。拥有优秀的沟通能力,用以进行说服、鼓励和指导等活动,并赢得项目成员的信任。,9,以目标导向和主动的方式来不带任何感情色彩地关注项目结果,构架师应当是项目背后的技术推动力,而非构想者或梦想家(追求完美)精通构架设计的理论、实践和工具,并掌握多种参考构架、主要的可重用构架机制和模式。具备系统设计员的所有技能,但涉及面更广、抽象级别更高。,10,软件架构师的知识体系,软件架构师作为整个软件系统结构的总设计师,其知识体系、技能和经验决定了软件系统的可靠性、
5、安全性、可维护性、可扩展性和可移植性等方面的性能。因此一个优秀的软件架构师必须具备相当丰富的知识、技能和经验。通过对比软件架构师和系统分析师在软件开发中的职责和角色,不难发现软件架构师与系统分析师所必需的知识体系也是不尽相同的,系统分析师的主要职责是在需求分析、开发管理、运行维护等方面,而软件架构师的重点工作是在架构与设计这两个关键环节上。因此在系统分析师必须具备的知识体系中对系统的构架与设计等方面知识体系的要求就相对低些;而软件架构师在需求分析、项目管理、运行维护等方面知识的要求也就相对低些。,11,成为一名合格的软件架构师必须具备的知识信息系统综合知识体系软件架构知识体系,12,?,MFC
6、,MSF,MOF,RUP,J2EE,Spring,SOA,JUnit,ORM,.NetMVC,UML,XML,Corba,MDA,MDD,Web-ServiceRSS,Web2.0,AJAX,Serverlet,HibernateIOC,AOPRuby On RailsRupBPELWorkflow EngineLBSOracleCMMIMQ,13,软件架构师在干什么?,思考、思考、再思考深入理解、准确把握建设的业务需求分析所有可见的问题、障碍、风险充分参考已有的成功方案,降低风险交流、讨论、博弈、质疑对构思中的方案不断提出质疑,避免漏洞广泛听取各层面的意见,开拓思路反复质疑、逐步完善已有的设
7、计构思在动手实现之前验证设计方案的正确性,14,软件架构师的知识结构,软件知识最好要有系统开发全过程经验。对 IT 建设生命周期各个环节有深入了解,包括:系统/模块逻辑设计、物理设计、代码开发、项目管理、测试、发布、运行维护等。深入掌握1-2种主流技术平台上开发系统的方法。了解多种应用系统的结构。了解架构设计领域的主要理论、流派、框架。,15,软件架构师的知识结构,业务知识深入了解系统建设的业务需求。了解系统的非功能需求和运行维护需求。了解企业 IT 公共设施、网络环境、外部系统。,16,软件架构师的思维方式,基于框架的思维架构设计的层次(Enterprise,Application,etc)
8、IT 的生命周期(What,Why,Where,How,When,etc)成功经验以及方法论的指导合理把握技术细节把握各个层次应有的内容合理忽略不应有的技术细节,17,软件架构师的思维方式,风险管理意识采用成功经验、避免不应有的风险多方位的开放思维多维度、多方向、包容性、避免排他性分析、质疑、抽象、归纳没有绝对好的架构设计,只有相对优秀的方案,18,信息系统综合知识体系,(1)计算机系统综合知识:包括计算机组成与体系结构、嵌入式系统和操作系统等方面的知识。(2)系统配置和方法:包括系统配置技术和系统性能等方面的知识。(3)典型系统应用:包括网络应用、数据库应用和多媒体系统等方面的知识。(4)系
9、统开发:包括程序设计语言、软件开发方法、需求分析和设计方法、测试评审方法、开发管理、应用系统构建、系统审计、外部资源使用和基于中间件的开发等方面的知识。(5)安全性和可靠性技术:包括数据安全与保密、防闯入和防病毒、容错技术、可靠性模型与分析技术、系统可靠性、安全规章和保护私有信息规则等方面的知识。,19,(6)标准化:包括标准化的基础知识、标准化分级、编码标准、数据交换标准、软件工程标准、信息安全标准、基于构件的软件标准和标准化组织机构等方面的知识。(7)信息化基础:包括政府信息化与电子政务、企业信息化与电子商务、信息化的有关的法律和规定等方面的知识。(8)数学和英语:至少具有大学以上的数学和
10、英语基础知识。,20,软件架构知识体系,(1)系统计划:包括项目的提出和可行性分析、系统方案的制定、评价和改进、新旧系统的分析与比较、现有软、硬件和数据资源的有效利用等。(2)软件架构设计:包括软件架构的概念、软件架构与设计、架构风格、特定领域的架构风格、基于架构的软件开发方法、架构评估、软件产品线和系统演化等。(3)设计模式:包括设计模式的概念、组成、分类和实现、模式和软件架构的关系等。(4)系统设计:包括处理流程设计、人机界面设计、文件与存储设计、数据库设计、网络应用系统的设计、系统运行环境的集成与设计、中间件与应用服务器、性能设计与性能评估等。(5)软件建模:包括定义问题与归结模型、结构
11、化系统建模与数据流图、面向对象系统建模、数据库建模和逆向工程等。,21,(6)分布式系统设计:包括分布式通信协议的设计、基于对象与web的分布式设计、基于消息和协同的分布式设计和异构分布式系统的互操作性设计等。(7)嵌入式系统设计:包括实施任务调度和多任务设计、中断处理和异常处理、嵌入式系统开发设计等。(8)系统可靠性分析与设计:包括系统故障模型和可靠性模型、系统的可靠性分析与可靠度计算、提高系统可靠性的措施、系统的故障对策和系统的备份与恢复等。(9)系统的安全性和保密性设计:包括系统的访问控制技术、数据的完整性、数据与文件的加密、通信的安全和系统的安全设计等。(10)复杂架构设计:包括操作系
12、统的架构、编译器的架构和大型基础库的架构等。,22,软件架构师的任职条件,根据软件架构师的职责和角色定位,以及知识体系,从实践的角度考虑,合格的软件架构师应该具有以下能力和经验:(1)具有8年以上的软件项目开发实际工作经验,其中至少有3年以上的代码编写工作经验,4年以上的基于面向对象和构件开发方法的软件产品设计经验。(2)具有5个以上大中型开发项目的总体规划、方案设计经验,有大中型应用系统开发和实施的成功案例。(3)对相关的技术标准有深刻的认识,对软件工程标准和规范有良好的把握。(4)对.Net或Java技术及整个解决方案有深刻的理解及熟练的应用,精通Web Service,熟练掌握流行的架构。,23,(5)对设计模式有深刻的理解,并能在此基础上设计出适合产品特性和质量属性的框架。(6)具有面向对象的分析、设计和开发能力,精通UML和XML,能熟练使用Rational Rose、PowerDesigner等工具进行设计。(7)具有良好的团队意识和协作精神,有较强的沟通能力和书面表达能力。(8)具有旺盛的精力和学习能力,能快速掌握新技术和新方法。,24,第二单元:技术架构视图面向对象程序设计原则与模式,25,26,27,用GRASP模式指导设计,28,29,30,31,32,33,34,35,36,37,38,39,