为什么大多数大型网站不是用Java写的
来源:互联网 发布:统计员数据的表格 编辑:程序博客网 时间:2024/05/16 05:10
国庆长假,老外在热烈的讨论这个话题,
原文地址: http://natishalom.typepad.com/nati_shaloms_blog/2007/10/why-most-scalab.html
我摘录部分观点如下:
Most of these sites are using LAMP as the core runtime stack
Some develop their own file system (Google, GFS)
Some are using caching to solve the database bottleneck (memcached and the like)
--
introducing similar solutions for addressing the scalability challenges: 在解决伸缩性方面的尝试:
On the Data Tier we see the following:
1. Adding a caching layer to take advantage of memory resources
availability and reduce I/O overhead
2. Moving from a database-centric approach to partitioning, aka shards
注:shards是google贡献给hibernate的一个项目,他是hibernate的一个扩展,可以
透明的实现数据的分布存储。至于如何分布存储由你自己定义策略,例如典型的
RoundRobinShardSelectionStrategy
On the Business Logic Tier:
3. Adding parallelization semantics to the application tier (e.g.,
MapReduce)
注:MapReduce是Google开发的C++编程工具,用于大规模数据集(大于1TB)的并行运算。MapReduce通过把对数据集的大规模操作分发给网络上的每个节点实现可靠性;每个节点会周期性的把完成的工作和状态的更新报告回来。MapReduce会生成大量的临时文件,为了提高效率,它利用Google文件系统来管理和访问这些文件。
4. Moving to scale-out application models to achieve linear scalability
注:
scaling:the ability of an application to address growth in throughput,
usage, and capacity
有两种策略:scale out 和 scale up
scale up vs scale out 的区别在于:
1 Reliance on hardware versus reliance on software
2 Equation with "first-class" hardware versus "commodity" hardware
3 Massive versus incremental capacity increases
4 Centralized versus partitioned application architectures
简单的说就是一个靠提升单个硬件的配置,另一个靠用低端配置实现集群
5. Moving away from the classic two-phase commit and XA for transaction
processing (See: Lessons from Pat Helland: Life Beyond Distributed
Transactions)
注: 不使用传统的分布式事务处理,例如EJB的事务,使用新的基于space的中间件平台 Space Based Architecture (SBA) and GigaSpaces XAP
Trackback: http://tb.blog.csdn.net/TrackBack.aspx?PostId=1814706
- 为什么大多数大型网站不是用Java写的
- 为什么大多数大型网站不是用Java写的
- 为什么大多数大型网站不是用Java写的
- 为什么大多数大型网站不是用Java写的
- 为什么大多数大型网站不是用Java写的
- 为什么大多数大型网站不是用Java写的
- 为什么大多数大型网站不是用Java写的
- 为什么大多数大型网站不是用Java写的
- 为什么大多数大型网站不是用Java写的
- 为什么大多数大型网站不是用Java写的
- 为什么大多数大型网站不是用Java写的
- 为什么大多数大型网站不是用Java写的
- 为什么大多数大型网站不是用Java写的
- 为什么大多数大型网站不是用Java写的
- 为什么大多数大型网站不是用Java写的
- 为什么大多数大型网站不是用Java写的
- 为什么大多数大型网站不是用Java写的
- 为什么大多数大型网站不是用Java写的
- PHP+MySQL安全方案整理
- 利用locale来格式化时间字符串
- 浅谈MVC框架中View层的优雅设计及实例
- web应用中使用缓存提升性能的8种武器
- 软件工程师好了歌
- 为什么大多数大型网站不是用Java写的
- 用VB+MySQL比用PHP+Access还要愚蠢
- 重新开博!近期专题——虚拟团队管理
- 计算庄家的持仓量
- 开源管理新体验-《EasyJF开源团队章程》发布
- 一个不错的介绍企业应用集成和ESB的PPT
- 免费的Scrum 和 XP 最佳实践的电子书下载
- 关于数据建模(面向ER)和领域模型建模(面向OO)在企业应用中的作用的讨论
- 使用了两年Rails之后,让我重新用回PHP的7个原因