第1单元:软件架构文档和架构视图-如何有效描述架构蓝图
内容一:软件架构的视图
软件架构的视图原理
软件架构视图的意义, 软件架构师的多维思考
逻辑视图、开发视图、部署视图、运行视图、场景视图,数据视图 ,实现视图
如何和怎样绘制软件架构视图
UML建模工具在架构视图的应用
典型案例分析:结合多个电信,金融行业项目案例,分析真实项目软件架构视图
内容二: 软件架构的文档编写
软件架构文档的意义
软件架构模板(根据实际项目情况选择合适内容)
软件架构文档的结构(避免出现不必要的重复和缺少关键信息)
软件架构文档必须包含的内容(通过多个项目,分析不同系统包含系统内容不同)
文档的后期管理(使文档保持更新)
软件架构文档的评审
典型案例分析:结合多个电信项目案例,进行分析和评审软件架构文档
典型案例分析:结合多个电信项目案例,进行分析和评审软件架构文档
第2单元:软件架构设计关注点(哪些因素驱动架构设计,是架构开始设计之前必须知道的?)和架构最佳策略
内容一:软件架构设计关注点(软件架构师在架构设计之前必须考虑的要素)
架构设计的关注是什么
软件架构的驱动因素(改变传统以功能实现和新技术为驱动的策略)
软件质量需求对架构的影响(质量属性场景定义和对应架构策略)
软件功能需求对架构的影响(分析功能需求变化点和进化点)
软件约束条件与架构的影响(业务,运行环境,开发团队,实现技术等约束)
如何使功能性需求,非功能性需求和平台细节在架构中能保持分离,从而改善可维护性和可扩展性
处理功能需求,非功能性需求,平台细节.制定架构目标
典型案例分析:结合项目,因为分析驱动因素的错误,导致项目不能如期验收的失败案例
内容二:软件架构最佳策略
重新认识系统质量属性,如何定义质量属性和相应的架构策略
系统架构的可扩展性设计策略
系统架构的可靠性设计策略
系统架构的高性能设计策略
系统架构的可维护性设计策略
系统架构的易用性设计策略
系统架构质量属性和架构模式的应用
通过分析案例,了解基本架构策略如何应用
第3单元:软件架构设计过程
内容一、软件架构设计过程
软件架构设计过程方法论(步骤和相应的成果)
软件系统边界和外部系统接口的定义
大型软件系统的划分子系统原则
子系统功能模块的分解
子系统间的通信接口的设计
如何应对系统内部紧耦合、高内聚
软件系统关键质量属性树和可行性分析
软件系统部署架构(分布式/数据分布/通信/安全)
软件系统部署容量评估(主机/中间件/数据库等资源容量评估)
应用系统的类型和架构风格
架构模式在实际项目的应用
软件架构立方体图(软件架构的分层,分区和基础服务)
软件架构通用机制的分析(如何处理基础设施扩展和具体有什么方法做基础设施扩展, 掌握如何分离这些基础设施用例)
使用质量场景属性进行迭代架构设计
软件架构各层的架构策略(针对企业应用分层,每层的架构策略)
软件系统线程架构策略(结合Apache HTTP Server分析线程和进程的架构)
数据架构(数据模型/数据分布/数据存取,以及核心数据流)
用例视图(抽取典型,有分险和客户最关心用例进行分析,结合架构进行设计)
实现视图(架构,设计和开发,实现原则和指南)
完成架构文档,对架构文档进行评估
典型案例分析:结合3G增值服务项目,分析物理架构设计
第4单元:软件架构应用
内容一、架构设计的评估和验证
软件架构的验证(软件架构风险验证)
软件架构的验证方法和指标(基于问题检查表和质量属性树)
软件架构的验证注意事项
软件架构的评估方式
软件详细设计和实现时期,架构师的职责和架构的监控
典型案例分析:结合项目实例,分析如何进行验证架构和架构设计的后期重构技巧
内容二、架构设计重构和复用
软件架构重构概述
软件架构常见的坏症状
软件架构的重构手段
软件架构的复用
结合某著名公司全球架构师团队架构实例,分析架构重构和架构复用技巧
第二篇: 软件架构分层架构和每层核心策略
第5单元:软件架构核心策略
内容一:领域模型层架构
领域模型架构策略
领域模型建模(关联,属性)
多个系统数据模型不一致和领域模型的同步
公共数据模型(CDM)
领域模型分析模式(模型的选择会影响最终产生系统的灵活性和可重用性)
根据电信计费系统和网络资源管理案例分析领域模型的架构
内容二:业务逻辑层
业务逻辑架构模式(事务脚本/领域模型/服务层模式)
业务流程架构策略
基于容器的业务逻辑架构(EJB和轻量级,以及容器提供的基础服务)
面向方面的业务架构和AOP技术在业务逻辑架构的应用
状态管理架构策略(有状态和无状态服务,以及对可扩展性的影响)
业务逻辑的分布式架构策略(远程或本地/同步或异步)
并发和同步架构模式(Half-Sync/Half-Async和Leader/Followers和Active Object和Monitor Object)
基于中间件的业务逻辑架构(Corba/Tuxedo/MQSeries/J2EE/.net)
典型案例分析:结合某银行交易系统分析业务逻辑架构
内容三:数据存取(持久性)层架构
数据存取架构策略(对象和关系数据库的映射)
对象关系阻抗/ORM技术/数据映射SQLMapper
缓存技术在存取层的应用/缓存数据和数据库数据一致性
分布式数据存取策略(读写分离/分布数据/异构数据存取)
数据同步和一致性策略
数据访问层的性能考虑
事务管理(本地事务和分布式事务,以及事务补偿)
数据锁管理(悲观锁和乐观锁)
典型案例分析:结合零售行业POS项目分析数据访问层的架构设计
内容四:数据架构
数据架构概述
数据建模原则和优化策略
数据复制和同步策略
数据一致性和分布式事务
大数据量数据库可扩展性(水平和垂直扩展,读写分离)以及单表记录过大拆分策略
数据库集群规划
分布式数据存取策略(跨多个库, 可能数据库异构类型)
数据备份与恢复
数据库性能规划
数据安全策略
与遗留系统的数据库兼容性考虑
结合电信,金融,零售POS项目实例分析,系统数据架构设计策略
内容五:系统基础服务组件架构
系统基础服务组件架构策略
系统通用服务层与业务逻辑分离
系统必备13种基础服务架构(异常处理/事务管理/缓存/工作流/校验/通信/安全/日志/定时触发/状态/消息通信/系统监控/配置管理)
业务通用服务架构实现策略
结合多个项目实例分析,架构师如何萃取基础服务组件和怎样设计实现
第6单元:软件应用类型和参考架构(不同应用类型,必须采用不同架构风格)
内容一:软件应用类型和参考架构
联机交易类架构
Web应用系统/大规模高并发Web2.0互联网系统
Client/Server系统(银行交易系统)
连接分析分析系统(移动经营分析系统)
大规模实时并发系统(电信计费系统)
Portal系统(个性化和页面集成系统 )
EAI企业集成系统(基于大规模消息集成系统)
基于WAP系统(多渠道/多种手机接入系统)
后台批处理系统(高并发后台批处理类型 银行后台系统)
基于SOA架构系统
结合多个项目案例分析每种应用类型的架构风格特点,主要架构挑战和相应对策
第三篇:大型高可用高并发分布式系统架构设计与实践
第7单元 大型分布式架构设计最佳实践
内容一:大型分布式架构核心概念
无状态化设计;
冗余设计;
负载均衡设计;
分级管理设计;
纯异步调用(状态机等方式)设计;
调用合理超时设计;
服务降级设计;
幂等设计;
我们的实践案例;
内容二:大型分布式系统服务降级设计与实践
服务限流降级概念;
服务限流降级使用业务场景;
服务限流降级设计环节;
服务限流降级之原则篇、架构篇、框架篇、业务篇;
移动时代服务限流降级如何打造;
我们的实践案例;
内容三:大型分布式系统缓存设计与实践
互联网使用缓存类型有哪些?各自作用是什么?
分布式缓存冗余如何设计?
高可用架构缓存一致性如何保证?
高可用架构缓存高性能如何保证?
我们的实践案例;
缓存系统在大型网站架构中发挥的作用
单机缓存系统自研与选型
Memcached与Redis的异同及应用场景
深入剖析Redis技术
Redis主要数据结构剖析
Redis性能优化及配置优化
Redis复制机制与持久化机制
Redis缺陷与陷阱
分布式缓存技术剖析
扩展Redis集群,如何实现集群弹性伸缩,无缝扩容
Redis Cluster官方集群扩展方案及缺陷
业界主流Redis集群方案剖析
内容四:大型分布式系统性能优化
系统性能优化的模式都有哪些;
系统性能优化常用的步骤是什么;
系统性能优化的环节都能哪些;
我们的实践案例;
内容五:分布式系统数据库架构设计与实践
数据库架构设计基本概念;
高可用性设计与实践;
高并发设计与实践;
读性能设计与实践;
一致性设计与实践;
扩展性设计与实践;
我们的实践案例;
内容六:分布式系统数据库架构设计与实践
数据库架构设计基本概念;
高可用性设计与实践;
第四篇:微服务架构
第8单元 微服务架构
内容一:微服务架构诞生—为什么出现微服务架构
单块架构及其面临的挑战
分层应用架构
单块架构特点
单块架构面临的挑战
通过某传统ERP系统为案例分析上线后问题
内容二:微服务架构与SOA架构
SOA的基本概念
SOA方法学和其他方法学的比较
面向服务的分析和设计概述
SOA概念层次
SOA参考架构
SOA基础架构设施
ESB基础概念和职责
协议驱动和API驱动的ESB
BPM概念和SOA
业务流程建模和基于服务的BPM
软件体系结构的演变和面向服务的设计原则
通过多个SOA架构案例分析
内容三:微服务架构
为什么需要微服务架构
如何解决传统应用架构的问题
微服务架构是什么
微服务架构概念
微服务架构参考架构模式
通过分析多个微服务架构案例,了解微服务架构的参考模式
内容四:微服务架构开发实现---SpringBoot
Spring Boot概述
运用Spring Boot
Groovy与Spring Boot CLI
在Spring Boot中使用Grails
深入Actuator
部署Spring Boot应用程序
Spring Boot 的数据访问
Spring Boot 企业级开发
Spring Boot 开发部署与测试
多个基于SpringBoot实际项目的架构分析(为何这样设计/优点/缺点/当初的考虑)
内容五:微服务架构与云架构--Spring Cloud平台
云计算平台架构
为什么选择Spring Cloud
Spring Cloud
服务治理:Spring Cloud Eureka
客户端负载均衡:Spring Cloud Ribbon
服务容错保护:Spring Cloud Hystrix
声明式服务调用:Spring Cloud Feign
分布式配置中心:Spring Cloud Config
消息总线:Spring Cloud Bus
多个基于SpringBoot和SpringCloud云架构,谈微服务和云架构
内容六:微服务注册
为什么要服务注册
服务注册实现方式
使用NetflixEureka/SpringCloud实现服务注册
使用NetflixRibbon/SpringCloud实现客户端负载均衡
内容七:微服务发现
为什么要服务发现
服务发现的实现方式
第五篇: 架构师与架构职责
第9单元: 软件架构师成长
内容一、软件架构师成长
软件架构师职责
软件架构师与项目经理,产品经理,需求分析师不同
软件架构师技能模型
软件架构师如何成长
中国特色的架构师(目前国内很多架构师是身兼多职) |