人人网技术演进:从Resin到Nuclear

需积分: 9 1 下载量 73 浏览量 更新于2024-08-16 收藏 1.35MB PPT 举报
"Rose的发展-人人网架构" 这篇摘要主要介绍了人人网的技术架构发展历程,以及其核心组件Rose(可能指的是Nuclear Rose)的功能、特性和工作原理。从2006年开始,人人网的架构经历了从单一到分布式,再到高度可扩展和容错性的演变。 在2006年,人人网的架构基于Resin Pro服务器和MySQL InnoDB主从结构,采用单个Storage服务器配合Squid缓存。随着时间的推移,架构逐渐演进: 2007年,人人网引入了LVS+Resin的Web集群,大量使用Memcached进行缓存,建立了基于ICE的中间层,进行了MySQL的垂直分区,并部署了简单的分布式Storage和Lucene搜索引擎。 2008年,随着开放API和SOA(面向服务的架构)的实施,人人网进一步采用了MySQL的水平分区,增强了监控和安全性,并引入了DFS(分布式文件系统)如龙存。 2009至2010年,架构更加成熟,通过SOA实现紧耦合到松耦合的转变,采用Graceful Degradation策略,从MySQL转向NoSQL数据库,以适应更高的扩展性和灾难恢复需求。同时,多数据中心的建立确保了系统的可扩展性和灾备能力。 核心组件Rose(Nuclear)是一个分布式键值存储系统,其特性包括: 1. 数据自动复制到多个节点,确保高可用性。 2. 数据自动分区到不同的节点,支持水平扩展。 3. 支持无限的存储容量。 4. 遵循CAP理论,提供了多种一致性选项,如DISCARD、MIN、QUORUM、DISCARD_QUORUM、ALL,以达到最终一致性。 5. 构建于NIO、Netty、Protocol Buffers和Spring等技术之上,具有丰富的数据模型,支持列表型键值对和弱结构化的查询。 6. 使用HashRing算法进行分区,当添加新节点时,能够动态调整数据分布,保持负载均衡。 人人网的架构发展展示了互联网企业如何应对日益增长的用户需求和业务挑战,通过不断的技术迭代和创新,构建出一个高性能、高可用、可扩展的系统。Rose(Nuclear)作为其核心存储系统,体现了现代分布式系统的设计理念,能够有效地处理大规模的数据存储和访问。