互联网时代的软件革命——SaaS架构设计

ITPUB个人空间 sv7H2]3q,qbX 预购买地址:http://www.china-pub.com/129900
【书名】互联网时代的软件革命——SaaS架构设计
【作者】叶伟  等编著
【ISBN】978-7-121-07736-4
【出版社】电子工业出版社
【出版日期】2008年12月
【宣传语】
 国内第一本完整介绍SaaS应用设计的书籍。
具有丰富SaaS实践经验的一线架构师的经验总结。
用创业故事贯穿全书,以一种活泼的风格来描述SaaS应用逐步成熟的过程。
【内容简介】
本书是国内第一本完整介绍SaaS应用开发的书籍,聚集于架构设计。内容是互联网领域具有丰富实践经验的8位一线架构师,对于多年SaaS实践经验的总结。对于SaaS领域的业务、设计、开发人员,具有很高的指导价值。
本 书首先从SaaS的商业价值分析开始,讨论SaaS应用与其它应用最大的差异特征:多租户。SaaS应用架构是否成熟正是对多租户的三个重要特性的衡量: 高性能、可配置性和伸缩性。本书将对SaaS应用成熟度的4个模型一一描述,并通过郭靖和杨康两个大学生的创业故事来描述SaaS应用逐步成熟到百万级以 上租户时,应用软件的架构设计演变过程。
同时,本书还针对云计算、OpenAPI、离线应用、安全以及开放平台等SaaS相关的主题进行了深入的阐述。
【前言】
SaaS 源于一种简单的思想:软件即服务!但SaaS的出现彻底改变了人们对软件的观念,使用软件的人从产品消费者转换为服务消费者,而开发软件的人从产品提供者 转换为服务提供者。当然,SaaS带来的改变不仅仅体现在商业模式上,也带来了软件开发中的思路和技术的许多改变。这些都是整个软件界需要探讨和思考的问 题。
当今的软件界已 没有谁敢小觑SaaS软件,因为有一大批的如国外的Salesforce和国内的阿里软件这样的公司在这个领域取得了辉煌战绩,而Google和 Microsoft以及国内的用友和金蝶等知名企业也纷纷加入SaaS大战之中。事实上,当前的软件行业正面临一场新的变革,导火索就是SaaS软件。
尽管有不少人对SaaS还缺乏了解,甚至对SaaS持怀疑态度;尽管SaaS本身也还存在这样或那样的缺陷,但SaaS软件发展的速度向世人证明了:软件行业从第二产业的生产制造业向第三产业的现代服务业进行大转换的潮流不可阻挡。
本 书也正是在软件行业这样的大背景下推出的。这是国内第一本系统地介绍SaaS的理论和概念,以及SaaS软件的架构和实现技术的专业书籍。写作本书的目的 主要是为了向软件界的朋友们分享有关理解和运用SaaS理论与技术的思想和经验。同时,本书的推出也希望能起到抛砖引玉的效果,让更多的朋友参与到 SaaS理论和技术的探讨中,共同完善和发展SaaS的理论和技术,促进软件行业不断进步。
本书读者
        由于本书所涵盖的内容较宽,适合阅读本书的读者群还是相当广泛的。当然本书主要还是为软件行业的开发人员准备的专业书籍,重点关注的是SaaS软件的架构设计与技术方案,而并非老少皆宜的初级读物。
如果你是软件或互联网公司的老板或高层管理人员,建议你应该看看本书的一些内容。你可以重点了解SaaS的理论知识和基本概念,SaaS软件的优势和缺点,以及SaaS所带来的稳健商业模式。当然,我们更建议你将本书推荐给你们的技术开发人员,他们往往能从技术上给予更多的评点。
如 果你是IT企业的CTO或者技术负责人,本书将能为你提供较为全面的SaaS技术信息。特别是对于那些正打算转型到SaaS软件开发的技术公司,本书是不 可多得的重要参考指南。书中所讲的很多内容都是业界关于SaaS的技术情报和行动计划,我们相信这些内容一定对你的技术决策有很大帮助。
如果你是软件公司的架构师,正在规划本企业SaaS产品的架构设计,本书就是专门为你量身定做的。SaaS软件的架构设计与传统软件有很大不同,对于从传统软件设计转过来的架构师们正需要这方面的参考和指导,而本书的重点就是讲述SaaS软件的架构设计的。
如果你是一名程序员,是时候关注SaaS软件的开发方法了。尽管对于基层程序员来说编写代码的工作没有多大改变,但了解整个SaaS软件的架构原理之后,对编写高质量的代码一定有很大的帮助。SaaS软件所需要的多用户、高并发和大容量特性,也要求程序员编写更高质量和更稳定的代码。
如果你是一位即将毕业或打算从事软件开发的新手,将能从本书中获知当前软件产业发展的最新动向和技术。其实,对于新手来说,先把握方向和目标是非常重要的,这样可以将有限的精力投到正确的学习和实践中,紧跟软件行业的发展潮流。我们可以肯定地说,未来软件的发展趋势一定是SaaS!
本书作者
         本书是由阿里软件公司主持编写的,阿里软件是国内最知名的SaaS软件运营商之一。本书的作者都是阿里软件研究院的研究人员,在SaaS软件理论和技术方 面有丰富经验。他们有些是SaaS理论权威专家,有些是SaaS软件的资深软件架构师,有些是阿里软件重大项目的技术带头人。他们分别是:
叶  伟 —— 阿里软件研发中心总监
赵  进 —— 阿里软件首席架构师
曾  义 —— 阿里软件研究院技术部经理
叶  军 —— 阿里软件研究院资深架构师
莫建祥 —— 阿里软件服务器首席架构师
闻  波 —— 阿里软件研究院资深架构师
黄晓龙 —— 阿里软件研发中心资深架构师
龙  良 —— 阿里软件研发中心资深架构师
李  战 —— 阿里软件研究院资深架构师
         联系方式
         本书开辟了专门的博客,欢迎广大读者和我们交流和沟通。我们的博客地址是:
         http://blog.csdn.net/AlisoftRD/category/476332.aspx
【目录】
第1篇  SaaS商业模式
第1章  SaaS的前世今生    2
1.1  什么是SaaS    3
1.1.1  SaaS的产生    3
1.1.2  SaaS基本概念    6
1.1.3  SaaS与ASP的异同    8
1.2  SaaS软件的优势    9
1.2.1  给用户的优势    10
1.2.2  给软件商的优势    14
1.3  SaaS的缺点及解决办法    16
1.3.1  依赖互联网    16
1.3.2  数据安全性    17
1.3.3  数据保密性    19
1.4  SaaS成功案例    20
1.4.1  Salesforce.com    20
1.4.2  Google.com    22
1.4.3  Alisoft.com    24
1.4.4  其他SaaS案例    26
1.5  小结    29
第2篇  SaaS应用架构
第2章  SaaS成熟度模型    32
2.1  SaaS的规模效应    33
2.2  SaaS成熟度模型分级    36
2.2.1  Level 1:定制开发    36
2.2.2  Level 2:可配置    37
2.2.3  Level 3:高性能的多租户架构    39
2.2.4  Level 4:可伸缩性的多租户架构    41
2.3  如何选择合适的SaaS成熟度模型    43
2.3.1  产品所面向的客户群的特征与需求    43
2.3.2  产品的租户数量级别    44
2.3.3  团队的开发能力与愿意付出的开发/改造成本    45
2.4  SaaS软件的成熟度模型的渐进步骤    46
2.5  小结    47
第3章  构建Multi-Tenant应用    48
3.1  第一阶段:做项目    49
3.1.1  发现商机    49
3.1.2 “4+1”视图    50
3.1.3  项目托管    58
3.2  第二阶段:做产品    59
3.2.1  共享设备    59
3.2.2  创业之旅    61
3.2.3  可配置化    62
3.3  第三阶段:多租户    63
3.3.1  成长的烦恼    63
3.3.2  如何转化成SaaS多租户模式    65
3.3.3  SaaS多租户设计    70
3.3.4  SaaS多租户模式的威力    72
3.4  小结    73
第4章  高性能的Multi-Tenant最佳实践    74
4.1  数据库层性能优化    75
4.1.1  建立合适的索引    76
4.1.2  消除大数据表连接    77
4.1.3  避免复杂SQL    78
4.2  应用层性能优化    78
4.2.1  Cache    79
4.2.2  统计和报表计算    82
4.2.3  基于Tenant的索引搜索    84
4.2.4  异步操作    85
4.3  Web层性能优化    87
4.3.1  Web开发的性能优化策略    88
4.3.2  Http服务器的性能优化策略    91
4.4  性能监控    93
4.5  优化的效果    95
4.6  小结    95
第5章  Multi-Tenant应用的可配置性    98
5.1  数据可配置    100
5.1.1  定制字段    101
5.1.2  预分配字段    102
5.1.3  名称值对    104
5.1.4  方案比较    106
5.2  功能可配置    107
5.2.1  原子功能划分    108
5.2.2  功能包设计    110
5.2.3  功能使用校验    115
5.3  界面可配置    116
5.3.1  系统菜单可配置    116
5.3.2  页面元素可配置    118
5.4  流程可配置    119
5.5  配置元数据管理    119
5.5.1  配置元数据    120
5.5.2  租户配置数据    123
5.5.3  配置元数据服务    124
5.6  可配置系统运行    125
5.6.1  系统菜单框架    127
5.6.2  功能页面容器    127
5.6.3  扩展数据引擎    128
5.6.4  功能引擎    128
5.7  小结    128
第6章  可伸缩的SaaS应用架构    129
6.1  伸缩性(Scalable)的概念    131
6.2  应用服务器层的水平扩展    132
6.2.1  基于Session复制的水平扩展方式    133
6.2.2  基于Session Sticky的水平扩展方式    136
6.2.3  基于Cache的集中式Session实现水平扩展    137
6.2.4  三种水平扩展方式的比较    138
6.3  数据库层的水平扩展    138
6.3.1  数据库的垂直切分    139
6.3.2  数据库的读写分离技术    140
6.3.3  数据库的水平切分    141
6.3.4  三种数据库层的水平扩展方案对比    144
6.4  小结    145
第7章  SaaS系统安全    148
7.1  应用安全    150
7.1.1  身份认证    150
7.1.2  权限管理    153
7.1.3  日志记录    156
7.1.4  应用监控    157
7.2  数据安全    158
7.2.1  数据隔离    158
7.2.2  数据库连接安全    159
7.2.3  敏感数据加密    160
7.2.4  数据量监控    164
7.3  网络安全    165
7.3.1  安全传输    165
7.3.2  网络攻击防范    167
7.3.3  网络监控    168
7.4  小结    168
第8章  离线应用    170
8.1  系统分析    171
8.1.1  离线应用的4大核心问题    172
8.1.2  离线应用架构    173
8.1.3  相关技术背景    175
8.2  本地使用    176
8.2.1  网络状态检测    176
8.2.2  离线页面支持    178
8.3  本地存储    178
8.3.1  本地数据库支持    178
8.3.2  本地数据存储    179
8.4  数据同步    180
8.4.1  增量数据处理    180
8.4.2  多用户冲突    183
8.5  数据传输    184
8.6  离线应用开发工具介绍    186
8.6.1  本地数据库    187
8.6.2  本地服务    187
8.6.3  工作者线程池    189
8.6.4  Gears待发展的内容    192
8.7  小结    192
第3篇  SaaS基础架构——云计算
第9章  分布式文件存储    194
9.1  大文件的分布式存储    195
9.1.1  GFS    195
9.1.2  HDFS    196
9.2  小文件的分布式存储    202
9.2.1  ADFS(Alibaba Distributed File System)    202
9.2.2  小文件存储的另外方案介绍    207
9.3  小结    208
第10章  分布式数据库    210
10.1  基于列的结构化分布式数据库    211
10.1.1  HBase数据库数据结构    211
10.1.2  HBase系统架构    214
10.1.3  HBase实践    215
10.2  基于代理的分布式数据库    217
10.3  基于列的分布式关系数据库    237
10.4  小结    241
第11章  分布式Cache    242
11.1  单层的分布式Cache    243
11.2  多层的分布式Cache    245
11.3  改进的多层分布式Cache    245
11.4  小结    246
第12章  分布式计算    248
12.1  MapReduce分布式计算框架    249
12.2  文件下载的分布式计算    252
12.2.1  中心索引方式    253
12.2.2  分布式的结构化方式    254
12.2.3  改进模型    256
12.3  小结    258
第4篇  开放的SaaS平台
第13章  不Open API    260
13.1  Open API的商业价值分析    263
13.1.1  Open API的出现、起源与现状    264
13.1.2  Google Maps API带来开放潮流    265
13.1.3  Mashup在Open API的时代    266
13.1.4  Open API的分类    268
13.1.5  Open API的系统架构与运营    276
13.2  Open API相关产品    279
13.3  Open API的实现技术    282
13.3.1  远程接口技术    282
13.3.2  远程接口设计最佳实践    289
13.4  Open API与API托管平台    290
13.5  服务集成平台设计与实现    293
13.6  小结    297
第14章  开放的SaaS平台    298
14.1  PaaS    299
14.1.1  插件模式    301
14.1.2  七巧板模式    303
14.1.3  云计算模式    304
14.1.4  服务托管模式    310
14.2  互联提升价值    311
14.2.1  拓展软件的能力:聚合互联网资源    313
14.2.2  应用互联的价值链    313
14.2.3  基础设施提供    316
14.2.4  互联需开放平台    316
14.3  软件互联平台    317
14.3.1  软件大市场    318
14.3.2  软件生态圈    319
14.4  小结    323
第15章  结束语    324
15.1  SaaS发展趋势    325
15.1.1  SaaS平台化    325
15.1.2  SaaS产业链    326
15.1.3  SaaS移动化    327
15.1.4  服务即软件    328
15.2  软件行业的未来    330
15.2.1  通过互联网使用软件的用户越来越多    330
15.2.2  软件和服务的界限会越来越模糊    330
15.2.3  软件和服务会越来越个性化    331
15.2.4  软件产业大融合    331
参考资料    333

你可能感兴趣的:(互联网时代的软件革命——SaaS架构设计)