Skip to content

pika 介绍

Yin Shucheng edited this page Aug 8, 2016 · 9 revisions

pika是什么?

pika 是DBA和基础架构组联合开发的类Redis 存储系统,所以完全支持Redis协议,用户不需要修改任何代码,就可以将服务迁移至pika。 同时DBA团队还提供了迁移工具, 所以户不会感知这个迁移的过程,迁移是平滑的。

跟Redis相比, pika的优势和劣势分别在哪?

pika相对于redis,最大的不同就是pika是持久化存储,数据存在磁盘上,而redis是内存存储,由此不同也给pika带来了相对于redis的优势和劣势

优势:

容量大:Pika没有Redis的内存限制, 最大使用空间等于磁盘空间的大小 加载db速度快:Pika 在写入的时候, 数据是落盘的, 所以即使节点挂了, 不需要rbd或者oplog,pika 重启不用加载所有数据到内存就能恢复之前的数据, 不需要进行回放数据操作。 备份速度快:Pika备份的速度大致等同于cp的速度(拷贝数据文件后还有一个快照的恢复过程,会花费一些时间),这样在对于百G大库的备份是快捷的,更快的备份速度更好的解决了主从的全同步问题

劣势:

由于Pika是基于内存和文件来存放数据, 所以性能肯定比Redis低一些, 但是我们一般使用SSD盘来存放数据, 尽可能跟上Redis的性能。

pika适合的场景是什么?

从以上的对比可以看出, 如果你的业务场景的数据比较大,Redis 很难支撑, 比如大于50G,或者你的数据很重要,不允许断电丢失,那么使用Pika 就可以解决你的问题。 而在实际使用中,pika的性能大约是Redis的50%。

pika目前正在使用吗?

目前pika在线上部署并运行了20多个巨型(承载数据与redis相比)集群 粗略的统计如下: 当前每天承载的总请求量超过100亿 当前承载的数据总量约3 TB

从redis迁移到pika需要经过几个步骤?

开发需要做的: 开发不需要做任何事,不用改代码、不用替换driver(pika使用原生redis的driver),什么都不用动,看dba干活就好 dba需要做的:

  1. dba迁移redis数据到pika
  2. dba将redis的数据实时同步到pika,确保redis与pika的数据始终一致
  3. dba切换lvs后端ip,由pika替换redis

迁移过程中需要停业务/业务会受到影响吗?

然而不会

迁移是无缝且温和的吗?

那当然

Clone this wiki locally