0

0

Redis存储系统Pika架构设计的方法是什么

王林

王林

发布时间:2023-05-29 20:07:17

|

1742人浏览过

|

来源于亿速云

转载

pika 是 360 基础架构团队和 dba 团队联合研发的一款高效、稳定、简单可依赖的开源的 nosql 数据库产品。完全兼容 redis 协议,支持 5 种数据结构(string,hash,list,set,zset),数据持久化到 rocksdb,相比于 redis 内存的存储方式,能极大减少服务器资源的占用,增强了数据的可靠性。可以采用单机和集群两种模式部署。pika 项目 2015 年启动,随后在 github 上开源,现有 3700 stars,35个 contributors,社区有大量的线上业务使 pika。

对比 Redis

存储容量: Redis 存储到内存,硬件成本高,宕机恢复延迟高;Pika 借用 RocksDB 存储到磁盘,单台服务器所容纳的数据量是 Redis 的几十倍,宕机恢复速度快。

吞吐量: Redis QPS 更高,单台服务器百万级的 QPS;Pika QPS 相对较低,单服务器几十万,Redis 是 Pika 的 3~5 倍。

访问延迟: Redis 应该在 1ms 以内;Pika 延迟稍高,3ms 以内。

运维部署: Redis 支持单机主从和集群两种方式; Pika 也支持两种方式部署。

适用场景

如果业务场景数据量比较大(> 50GB),数据可靠性要求高,那么 Pika 可以解决您的问题。

场景1:大规模数据处理系统的中间结果存储

场景2:使用 Redis/Redis Cluster 做持久化存储的业务系统

场景3:大型分布式系统的元数据存储

塔可商城
塔可商城

塔可商城, 一个基于springboot+uniapp+vue3技术栈开发的开源跨平台小程序、管理后台,后端服务的项目,它内置提供了会员分销, 区域代理, 商品零售等功能的新零售电商系统。强大弹性的架构设计,简洁的代码,最新的技术栈,全方面适合不同需求的前端,后端,架构的同学,同时更是企业开发需求的不二选择。 项目结构通过项目结构,你将清楚明白你即将入手的是一个怎么样的项目,你可能需要什么,如何

下载

架构设计

Pika 可以通过配置文件中的 instance-mode 配置项,设置为 classic 和 sharding,来选择运行经典模式(Classic)还是分布式模式(Sharding)的 Pika。

  • 经典模式架构

Redis存储系统Pika架构设计的方法是什么

经典模式(Classic): 即1主N从同步模式,1 个主实例存储所有的数据,N 个从实例完全镜像同步主实例的数据,每个实例支持多个 DBs。Pika 的配置项 databases 允许您设置可以创建的最大 DB 数量,默认从 0 开始。DB 在 Pika 上的物理存在形式是一个文件目录。

  • 分布式模式架构

Redis存储系统Pika架构设计的方法是什么

分布式模式(Sharding): Sharding 模式下,将用户存储的数据集合称为 Table,每个 Table 切分成多个分片,每个分片称为 Slot,对于某一个 KEY 的数据由哈希算法计算决定属于哪个 Slot。将所有 Slots 及其副本按照一定策略分散到所有的 Pika 实例中,每个 Pika 实例有一部分主 Slot 和一部分从 Slot。在 Sharding 模式下,Slot 被用来分主从,而不再使用 Pika 实例。Slot 在 Pika 上的物理存在形式是一个文件目录。

相关专题

更多
什么是分布式
什么是分布式

分布式是一种计算和数据处理的方式,将计算任务或数据分散到多个计算机或节点中进行处理。本专题为大家提供分布式相关的文章、下载、课程内容,供大家免费下载体验。

322

2023.08.11

分布式和微服务的区别
分布式和微服务的区别

分布式和微服务的区别在定义和概念、设计思想、粒度和复杂性、服务边界和自治性、技术栈和部署方式等。本专题为大家提供分布式和微服务相关的文章、下载、课程内容,供大家免费下载体验。

231

2023.10.07

string转int
string转int

在编程中,我们经常会遇到需要将字符串(str)转换为整数(int)的情况。这可能是因为我们需要对字符串进行数值计算,或者需要将用户输入的字符串转换为整数进行处理。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

315

2023.08.02

treenode的用法
treenode的用法

​在计算机编程领域,TreeNode是一种常见的数据结构,通常用于构建树形结构。在不同的编程语言中,TreeNode可能有不同的实现方式和用法,通常用于表示树的节点信息。更多关于treenode相关问题详情请看本专题下面的文章。php中文网欢迎大家前来学习。

533

2023.12.01

C++ 高效算法与数据结构
C++ 高效算法与数据结构

本专题讲解 C++ 中常用算法与数据结构的实现与优化,涵盖排序算法(快速排序、归并排序)、查找算法、图算法、动态规划、贪心算法等,并结合实际案例分析如何选择最优算法来提高程序效率。通过深入理解数据结构(链表、树、堆、哈希表等),帮助开发者提升 在复杂应用中的算法设计与性能优化能力。

17

2025.12.22

深入理解算法:高效算法与数据结构专题
深入理解算法:高效算法与数据结构专题

本专题专注于算法与数据结构的核心概念,适合想深入理解并提升编程能力的开发者。专题内容包括常见数据结构的实现与应用,如数组、链表、栈、队列、哈希表、树、图等;以及高效的排序算法、搜索算法、动态规划等经典算法。通过详细的讲解与复杂度分析,帮助开发者不仅能熟练运用这些基础知识,还能在实际编程中优化性能,提高代码的执行效率。本专题适合准备面试的开发者,也适合希望提高算法思维的编程爱好者。

13

2026.01.06

页面置换算法
页面置换算法

页面置换算法是操作系统中用来决定在内存中哪些页面应该被换出以便为新的页面提供空间的算法。本专题为大家提供页面置换算法的相关文章,大家可以免费体验。

399

2023.08.14

常用的数据库软件
常用的数据库软件

常用的数据库软件有MySQL、Oracle、SQL Server、PostgreSQL、MongoDB、Redis、Cassandra、Hadoop、Spark和Amazon DynamoDB。更多关于数据库软件的内容详情请看本专题下面的文章。php中文网欢迎大家前来学习。

967

2023.11.02

c++主流开发框架汇总
c++主流开发框架汇总

本专题整合了c++开发框架推荐,阅读专题下面的文章了解更多详细内容。

97

2026.01.09

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

相关下载

更多

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
进程与SOCKET
进程与SOCKET

共6课时 | 0.3万人学习

Redis+MySQL数据库面试教程
Redis+MySQL数据库面试教程

共72课时 | 6.3万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号