为什么大多数大型网站不是用Java写的

国庆长假,老外在热烈的讨论这个话题,

原文地址: 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

### 推荐的Java IDE或开发工具 对于大学生而言,在学习和实践Java编程的过程中,选择一款合适的IDE可以显著提升效率并改善体验。以下是几个推荐选项及其特点: #### 1. **DrJava** DrJava 是专为初学者设计的一款轻量级 Java 集成开发环境。它的简单易用性和直观的用户界面使其成为入门阶段的理想选择。该工具具备诸如单元测试、代码编辑、查找/替换、自动补全、语法高亮等功能[^2]。此外,由于其支持跨平台特性(兼容 Linux、macOS 和 Windows),学生无论使用何种操作系统都可以轻松上手。 ```java // 示例:简单的 Hello World 程序可以用 DrJava运行 public class HelloWorld { public static void main(String[] args) { System.out.println("Hello, world!"); } } ``` #### 2. **Eclipse** Eclipse 是一个功能强大的开源 IDE,适用于各种规模的项目开发。尽管它可能对新手显得稍微复杂一点,但它拥有丰富的插件生态系统和支持广泛的第三方扩展能力,这使得随着技术成长的学生能够逐步探索更多高级特性和配置可能性。例如,可以通过安装 Mylyn 插件来帮助管理任务;或者利用 PyDev 扩展实现 Python 开发等多语言协作需求。 #### 3. **IntelliJ IDEA Community Edition** 虽然 IntelliJ IDEA Ultimate 版本主要面向商业用途,但免费版即社区版本已经足够满足大多数教育目的下的编码需求。这款产品以其卓越的智能感知能力和高效的重构手段著称,能极大地方便用户的日常操作流程[^4]。特别是当涉及到大型工程文件夹结构导航或是依赖注入框架如 Spring 的时候,这种优势会更加明显体现出来。 ```xml <!-- Maven pom.xml 文件片段 --> <dependencies> <dependency> <groupId>junit</groupId> <artifactId>junit</artifactId> <version>4.13.2</version> <scope>test</scope> </dependency> </dependencies> ``` #### 4. **NetBeans** 作为 Sun Microsystems 原始推出的官方解决方案之一,NetBeans 提供了一个全面而稳定的开发平台给开发者们用来创建桌面应用、Web 应用以及其他类型的软件作品。而且值得注意的是,自从 Oracle 收购之后继续维护更新至今,保持了良好的向前兼容性与现代化改进趋势[^3]。 --- ### 总结建议 如果目标群体主要是刚刚接触计算机科学基础概念的大一新生,则优先考虑像 DrJava 这样门槛较低的产品;而对于那些希望深入研究更复杂的主题比如数据库连接池设置或者是 RESTful API 设计的同学来说,不妨尝试一下 Eclipse 或者 IntelliJ IDEA CE 。最终决定应该综合考量个人偏好以及具体课程安排所提出的特殊要求等因素后再做定夺。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值