Reids(REmote DIrectory Server)开源存储系统

Redis通常被称为数据结构服务器,因为值value可以是字符串(String)、哈希(Map)、列表(list) 、集合(set)和有序集合(SortedSet)等类型。

Redis的特点:

Redis支持数据持久化,可以将内存中的数据保存到磁盘中,重启时可以再次加载进行使用。

Redis不仅仅支持简单的key-value类型的数据,同时还支持list、set、sortedset、hash、string等数据结构的存储。

Redis支持数据备份(master-slave模式的数据备份)

Redis优势:

性能极高:redis读的速度是110000次/s,写的速度是81000次/s。

丰富的数据类型:redis支持二进制案例的String、list、map、set、sortedset数据类型操作。

原子性:redis的所有操作都是原子性的,要么完全执行要么完全不执行。单个操作是原子性,多个操作也支持事物,即原子性。

丰富的特性:Redis还支持publish/subscribe,通知key过期等等特性。

扫描二维码关注公众号,回复: 5572665 查看本文章

什么是原子性,什么是原子性操作?

举个例子:

A想要从自己的帐户中转1000块钱到B的帐户里。那个从A开始转帐,到转帐结束的这一个过程,称之为一个事务。在这个事务里,要做如下操作:

  •  1. 从A的帐户中减去1000块钱。如果A的帐户原来有3000块钱,现在就变成2000块钱了。
  •  2. 在B的帐户里加1000块钱。如果B的帐户如果原来有2000块钱,现在则变成3000块钱了。

如果在A的帐户已经减去了1000块钱的时候,忽然发生了意外,比如停电什么的,导致转帐事务意外终止了,而此时B的帐户里还没有增加1000块钱。那么,我们称这个操作失败了,要进行回滚。回滚就是回到事务开始之前的状态,也就是回到A的帐户还没减1000块的状态,B的帐户的原来的状态。此时A的帐户仍然有3000块,B的帐户仍然有2000块。

我们把这种要么一起成功(A帐户成功减少1000,同时B帐户成功增加1000),要么一起失败(A帐户回到原来状态,B帐户也回到原来状态)的操作叫原子性操作。

如果把一个事务可看作是一个程序,它要么完整的被执行,要么完全不执行。这种特性就叫原子性。






猜你喜欢

转载自blog.csdn.net/weixin_39665076/article/details/79096368
今日推荐