Redis概述

  • Redis 一个内存数据库,通过 Key-Value 键值对的的方式存储数据。由于 Redis 的数据都存储在内存中,所以访问速度非常快,因此 Redis 大量用于缓存系统,存储热点数据,可以极大的提高网站的响应速度。
  • 优点

1.支持数据的持久化,通过配置可以将内存中的数据保存在磁盘中,Redis 重启以后再将数据加载到内存中;
2.支持列表,哈希,有序集合等数据结构,极大的扩展了 Redis 用途;
3.原子操作,Redis 的所有操作都是原子性的,这使得基于 Redis 实现分布式锁非常简单;
4.支持发布/订阅功能,数据过期功能;

NoSQL

1.什么是NoSQL?

NoSQL,指的是非关系型的数据库。NoSQL有时也称作Not Only SQL的缩写,是对不同于传统的关系型数据库的数据库管理系统的统称。
NoSQL用于超大规模数据的存储。(例如谷歌或Facebook每天为他们的用户收集万亿比特的数据)。这些类型的数据存储不需要固定的模式,无需多余操作就可以横向扩展。

2.为什么使用NoSQL ?

今天我们可以通过第三方平台(如:Google,Facebook等)可以很容易的访问和抓取数据。用户的个人信息,社交网络,地理位置,用户生成的数据和用户操作日志已经成倍的增加。我们如果要对这些用户数据进行挖掘,那SQL数据库已经不适合这些应用了, NoSQL数据库的发展也却能很好的处理这些大的数据。

  • NoSQL(NoSQL = Not Only SQL ),意即"不仅仅是SQL"。
    在现代的计算系统上每天网络上都会产生庞大的数据量。
    这些数据有很大一部分是由关系数据库管理系统(RDBMS)来处理。
  • 通过应用实践证明,关系模型是非常适合于客户服务器编程,远远超出预期的利益,今天它是结构化数据存储在网络和商务应用的主导技术。
  • NoSQL 是一项全新的数据库革命性运动,早期就有人提出,发展至2009年趋势越发高涨。NoSQL的拥护者们提倡运用非关系型的数据存储,相对于铺天盖地的关系型数据库运用,这一概念无疑是一种全新的思维的注入。

关系型数据库遵循ACID规则

事务在英文中是transaction,和现实世界中的交易很类似,它有如下四个特性:

1、A (Atomicity) 原子性

  • 事务里的所有操作要么全部做完,要么都不做,事务成功的条件是事务里的所有操作都成功,只要有一个操作失败,整个事务就失败,需要回滚。

比如银行转账,从A账户转100元至B账户,分为两个步骤:1)从A账户取100元;2)存入100元至B账户。这两步要么一起完成,要么一起不完成,如果只完成第一步,第二步失败,钱会莫名其妙少了100元。

2、C (Consistency) 一致性

  • 数据库要一直处于一致的状态,事务的运行不会改变数据库原本的一致性约束。

例如现有完整性约束a+b=10,如果一个事务改变了a,那么必须得改变b,使得事务结束后依然满足a+b=10,否则事务失败。

3、I (Isolation) 独立性

  • 所谓的独立性是指并发的事务之间不会互相影响,如果一个事务要访问的数据正在被另外一个事务修改,只要另外一个事务未提交,它所访问的数据就不受未提交事务的影响。

比如现有有个交易是从A账户转100元至B账户,在这个交易还未完成的情况下,如果此时B查询自己的账户,是看不到新增加的100元的。

4、D (Durability) 持久性
持久性是指一旦事务提交后,它所做的修改将会永久的保存在数据库上,即使出现宕机也不会丢失。

Redis常用命令

  • String类型

set 命令:设置一个键和值,键存在则只覆盖,返回ok
get 命令:获取一个键的值,返回值

127.0.0.1:6379> set name zhangsan
   OK
  127.0.0.1:6379> get name
  "zhangsan"

mset命令:批量设置键和值,成功则返回ok
mget通过键获取值

127.0.0.1:6379> mset a 1 b 2 c 3
OK
127.0.0.1:6379> mget a b c
1) "1"
2) "2"
3) "3"
  • hash类型
    设置一个哈希表的键和值

hset hash名 键 值
hget hash名 键

127.0.0.1:6379> hset user name tom
(integer) 1
127.0.0.1:6379> hget user name
"tom"

hmset命令: 批量设置
hmget命令

127.0.0.1:6379> hmset user name tom age 20 sex f
OK
127.0.0.1:6379> hmget user name age sex
1) "tom"
2) "20"
3) "f"
  • List列表(双向链表结构)

在list1头部压入一个字串
lpush list1 “world”
在list2尾部压入一个字串
rpush list2 “world”

lrange list 0 -1 ------获取list中内容
0:表示开头 -1表示结尾。

127.0.0.1:6379> lpush list "Heloo"
(integer) 9
127.0.0.1:6379> rpush list "hoop"
(integer) 10
127.0.0.1:6379> lrange list 0 -1
 1) "Heloo"
 2) "JavaWeb"
 3) "node1"
 4) "node0"
 5) "element1"
 6) "node0"
 7) "node1"
 8) "node2"
 9) "node3"
10) "hoop"
  • Set集合(string类型的无序集合,集合成员是唯一的)

向myset中添加一个元素
sadd myset “hello”
获取myset中的所有元素(结果是无序的)
smembers myset

127.0.0.1:6379> sadd myset "a"
(integer) 1
127.0.0.1:6379> sadd myset "b"
(integer) 1
127.0.0.1:6379> sadd myset "c"
(integer) 1
127.0.0.1:6379> smembers myset
1) "b"
2) "c"
3) "a"