Atitit.软件架构高扩展性and兼容性原理与概论实践attilax总结

1. 什么是可扩展的应用程序?1

2. 松耦合(ioc)2

3. 接口的思考 2

4. 单一用途&模块化,小粒度化2

5. 组合(Composition),而不是继承(inheritance) 2

6. Ocp原则开闭原则2

7. Plugin系统2

8. 流程扩展工作流系统,流程自定义2

9. Ui扩展 html53

10. 数据独立性3

11. 脚本与hotdeploy3

12. 表处理扩展if else (数据与数据处理相互分离)3

13. 系统被扩展的几种形式(方法级别,模块级别)3

14. 常用软件扩展机制3

14.1. Ff的扩展机制》》》》插件体系4

14.2. 配置化4

14.3. dsl4

15. 面临的扩展性与兼容性问题4

15.1. 不同的项目与不同的实例启动4

15.2. 不同的项目与实例配置文件4

15.3. Web.xml怎么办??4

15.4. 跳转到同一功能spec的不同实现4

15.5. 不同项目的同一功能就实现可以放在同一上级模块package下5

16. 架构即未来:现代企业可扩展的Web架构、流程和组织(原书第2版)5

17. 高扩展性网站的50条原则(网站运营必备宝典)作者:[美]Martin L. AbbottMichael T. Fisher 著6

1. 什么是可扩展的应用程序?

一个可扩展的应用程序应该能够以某种方式实现增长,并且添加、删除、增强、重构某些组件,对于其他组件的影响微乎其微

当出现下面的这些情况时,说明元素已经具有可扩展性了:

· 该元素可以很容易地与其他元素进行互换,而不会破坏应用程序

· 该元素可以轻松重用于项目外部

· 该元素可以成功地进行单元测试

2. 松耦合(ioc)

soma.js中提供了一系列用于架构解耦和测试的工具,以及各种设计模式解决方案,比如依赖注入(dependency injection)、观察者模式(observer pattern)、中介者模式(mediator pattern)、外观模式(facade pattern)、命令模式(command pattern),面向对象(OOP)工具集,并提供了一个DOM操作模板引擎作为可选插件。

作者:: 绰号:老哇的爪子 ( 全名::Attilax Akbar Al Rapanui 阿提拉克斯 阿克巴 阿尔 拉帕努伊 )

汉字名:艾提拉(艾龙),   EMAIL:[email protected]

转载请注明来源: http://www.cnblogs.com/attilax/

3. 接口的思考

4. 单一用途&模块化,小粒度化

粒度更小,更容易扩展

5. 组合(Composition),而不是继承(inheritance)

6. Ocp原则开闭原则

7. Plugin系统

8. 流程扩展工作流系统,流程自定义

9. Ui扩展 html5

10. 数据独立性

每个功能使用不同的独立数据,这样可以提升扩展性。。比如订单处理。。接受订单,处理订单*update ,使用不同的表 ,就可以互相不影响的功能修改以及表结构修改。。

11. 脚本与hotdeploy

12. 表处理扩展if else (数据与数据处理相互分离)

13. 系统被扩展的几种形式(方法级别,模块级别)

4)运行时对象装配。

5)5)基于模块的运行时动态扩展。 到现在为止,我们讨论的都是比较细粒度的在技术上的扩展。想象一下,如果增加一些功能,就去继承各种各样的类,然后经过复杂的装配过程,才能完成一个功能的添加和改进。即使你新增加了类,改动了Spring的配置文件,实现新的装配,但仍然有一点,你需要编译整个项目。也就是说,前四种都没有达到模块级别的扩展。
      OSGi给出了解决方案,可以实现模块级别的动态扩展,而且是运行时的。所谓运行时模块的动态扩展,比如说你需要增加一些新的功能,你可以将新开发的类和文件按照Bundle进行组织,然后直接扔到运行时环境下,这些功能就可以用了。

6)6)基于中间语言。 框架通常定义了一些Hotspot(热点),在这些点上,可以进行扩展。平台,可扩展性是最强的,比如window 平台,你可以开发应用程序运行在上面。windows提供了几千个API,你可以使用他们来开发应用程序

由此推断,从技术上来说,要获得最大的可扩展性,就要通过一种或多种中间语言来进行扩展。比如现在流行的OpenSocial API和Facebook都是这个思路。这样说来,DSL的出现就是顺理成章的了,它是为了满足在某个业务领域的扩展而设计的

14. 常用软件扩展机制

14.1. Ff的扩展机制》》》》插件体系

14.2. 配置化

14.3. dsl

15. 面临的扩展性与兼容性问题

15.1. 不同的项目与不同的实例启动

通过不同的bat启动文件来实现。。

可以通过启动脚本来设置不同的实例

15.2. 不同的项目与实例配置文件

参照mysql,通过制定配置文件来实现

15.3. Web.xml怎么办??

暂时没办法,可以通过jetty等可编程中间件来实现。。

15.4. 跳转到同一功能spec的不同实现

比如游戏和点播系统的用户中心,ui界面就不同。。

可以使用查表法。。使用js,根据项目的id来跳转不同的功能ui加载,项目id在启动脚本里面传入。。  同一项目的不同实例只能跳转到相同功能,如果需要不同,在加个实例id判断吧。。

Prjid,instan_id,fun_implet

15.5. 不同项目的同一功能就实现可以放在同一上级模块package下

重名问题,通过添加后缀_prj 来解决。。

如果项目很多,应该通过前缀来解决,这样好找。。

16. 架构即未来:现代企业可扩展的Web架构、流程和组织(原书第2版)

第一部分 可扩展性组织的人员配置

第1章 人员和领导力对扩展性的影响 …… 2

第2章 可扩展性技术组织的角色 …… 17

第3章 组织的设置 …… 41

第4章 领导力秘籍 …… 80

第5章 管理秘籍 …… 116

第6章 关系、思维和商业案例 …… 141

第二部分 构建可扩展的过程

第7章 过程是可扩展的关键 …… 154

第8章 管理故障和问题 …… 169

第9章 危机管理和升级 …… 189

第10章 生产环境的变更管理 …… 210

第11章 确定应用发展的预留空间 …… 233

第12章 确立架构原则 …… 248

第13章 联合架构设计和架构审查委员会 …… 267

第14章 敏捷架构设计 …… 284

第15章 聚焦核心竞争力:自建与外购 …… 296

第16章 确定风险 …… 310

第17章 性能与压力测试 …… 328

第18章 障碍条件与回滚 …… 351

第三部分 可扩展的架构方案

第19章 构建故障隔离的架构 …… 368

第20章 AKF扩展立方体介绍 …… 389

第21章 为扩展分割应用 …… 404

第22章 为扩展分割数据库 …… 426

第23章 为扩展而缓存 …… 452

第24章 为扩展而异步 …… 472

第四部分 其他的问题和挑战

第25章 海量数据 …… 492

第26章 云计算的突飞猛进 …… 517

第27章 云计算准备就绪 …… 550

第28章 应用监控 …… 564

第29章 规划数据中心 …… 581

第30章 纵观全局 …… 608

17. 高扩展性网站的50条原则(网站运营必备宝典)作者:[美]Martin L. AbbottMichael T. Fisher 著

第1章 化简方程 1

第2章 分布工作 23

第3章 横向扩展设计 35

第4章 使用正确的工具 51

第5章 不要重复工作 67

第6章 积极利用缓存 81

第7章 从错误中吸取教训 109

第8章 数据库原则 125

第9章 容错设计与故障控制 141

第10章 避免或分发状态 159

第11章 异步通信和消息总线 171

第12章 其他原则 183

第13章 原则回顾和优先级划分 203

参考资料

如何一步一步打造高可扩展性的应用程序?-CSDN.NET.html

软件可扩展性:来自星巴克的经验 - Java,java框架 - language - ITeye论坛.html

可扩展性(Extensibility)——构建灵活系统的思考 - me.think(everything.about(_software_)).serialize(this);__古路刀客 - ITeye技术网站.html

架构师不可不知的十大可扩展架构 - 51CTO.COM.html( imp ,还没看完)

atiend

时间: 2024-12-04 21:28:45

Atitit.软件架构高扩展性and兼容性原理与概论实践attilax总结的相关文章

【总结】初创公司用AWS搭建高扩展性架构

下载地址:完整mp4视频 演讲人:张侠 博士 1. 邱洋的理解 初创公司需要快.多.好.省的技术架构 快:针对业务需要可以快速获得资源与服务 多:拥有丰富的云服务可供选择,能不自己做就不自己做 好:强调扩展性和高可用,既不要在一开始被"钱"束缚住,又需要良好的用户体验(能用是最基本的用户需求) 省:可以弹性伸缩,并按需付费是最好的节省 无论是初创公司还是传统企业,很多架构思路是相通的: OS.前端.后端.数据库.框架等,根据自身需要选择.之后要做的就是在云中找到对应的服务功能. 云应用

如何做到MySQL高扩展性?

课时的内容主要包含 MySQL 架构设计方法论.MySQL 高并发及其关注要点.MySQL 扩展的原因及其基本方法.万亿级数据量的应对技巧等内容. 高并发及其关注要点 近年来,随着互联网.移动互联网的飞速发展,业务系统的互动性日益增强,用户规模不断攀升,电商.游戏.直播.在线教育.短视频等一系列新兴移动端应用如雨后春笋般涌现出来,这些应用 “高并发.低延迟” 的需求对传统数据库的性能提出了新的要求和挑战,并且数据规模也井喷式增长.高并发是互联网分布式系统架构设计中必须考虑的因素之一,通常是指通过

构建高扩展性网站

如何构建高扩展性网站?     阅读目录 主要内容 化简方程 分布工作 横向扩展设计 使用正确的工具 不要做重复的工作 积极利用缓存 从错误中吸取教训 数据库原则 容错设计与故障控制 避免或分发状态 异步通信和消息总线 其他原则 参考 本篇通过阅读<高扩展性网站的50条原则>,总结出以下内容. 一方面博主没有实际的架构经验,另一方面知识面也不够宽阔,所以只能系统的总结书中的要点,并根据自己的理解做些归纳. 主要内容 本书从多个方面围绕高扩展性提出了50条建议,一个高扩展性的网站会随着业务的发展

jetbrick,新一代 Java 模板引擎,具有高性能和高扩展性

新一代 Java 模板引擎,具有高性能和高扩展性. <!-- Jetbrick Template Engineer --> <dependency> <groupId>com.github.subchen</groupId> <artifactId>jetbrick-template-springmvc</artifactId> <version>2.0.10</version> </dependency

高扩展性网站的50条原则

<高扩展性网站的50条原则>,利用一天半的时间快速浏览总结的电子书,对网站的建设有一个原则性的把握,书中提到的大部分原则现在已成为互联网行业的共识,但并不妨碍我们重新整理分类,从全局层面把控高扩展性网站的建设思路,文中的每一条尽管高度凝练,但都值得细细品味.完成于2015年6月11日11:02:19. (一)化简方程 不要过度设计:基于成本的考虑,只设计能满足要求的系统即可,过于理想化的设计不利于系统的维护与成本控制: 设计时考虑扩展性:设计20倍的容量,实现3倍的容量,部署1.5倍的容量,即

【转】如何构建高扩展性网站?

本篇通过阅读<高扩展性网站的50条原则>,总结出以下内容. 一方面博主没有实际的架构经验,另一方面知识面也不够宽阔,所以只能系统的总结书中的要点,并根据自己的理解做些归纳. 主要内容 本书从多个方面围绕高扩展性提出了50条建议,一个高扩展性的网站会随着业务的发展.用户的增加,自由的扩展架构,从而轻松的应付网站的快速发展.下面看看本书的具体内容: 化简方程 1 不要过度的设计 过度的设计相当于给系统增加了复杂度与维护的成本.而这些过度的设计,在正常的使用中,却没有太大的作用.往往是设计者自己认为

优秀开源项目之三:高性能、高并发、高扩展性和可读性的网络服务器架构State Threads

译文在后面. State Threads for Internet Applications Introduction State Threads is an application library which provides a foundation for writing fast and highly scalable Internet Applications on UNIX-like platforms. It combines the simplicity of the multi

Atitit.html css &#160;浏览器原理理论概论导论attilax总结

Atitit.html css  浏览器原理理论概论导论attilax总结 1.1. 浏览器是怎样工作的:渲染引擎,HTML解析(连载二)1 2. 5.1.1 DOM标准 1011 3. <WebKit技术内幕>(朱永盛...)[简介_书评_在线阅读] - .html2 4. HTML5与CSS3权威指南(第3版 上册)2 5. HTML5权威指南[非常全面详实的网页设计参考书]3 6. 深入理解Android:WebKit卷4 1.1. 浏览器是怎样工作的:渲染引擎,HTML解析(连载二)

.NET 通用高扩展性的细粒度权限管理架构(webApi/Mvc)

一. 权限场景分析: 1. 系统具有角色概念, 部门概念, 且都具有相应不同的权限 2. 用户具有多个角色, 多个部门等关系, 并且能给单个用户指派独有的权限 3. 具有细粒度权限控制到资源的RBAC, 能控制页面, 控制菜单, 控制逻辑, 控制单个操作, 控制到单一数据; 且具有一定的可扩展性 4. 适用于webapi/ mvc / wcf / webservice  混合项目中 5. 设置权限和验证权限易用性高 二. 数据库表设计 1. 角色表 2. 部门表 3. 用户表 4. 菜单表 5.