Redis

1. Redis是什么?

Redis是一个开放源代码(BSD许可)的内存中数据结构存储,用作数据库,缓存和消息代理。它支持数据结构,例如字符串,哈希,列表,集合,带范围查询的排序集合,位图,超日志,带有半径查询和流的地理空间索引。Redis具有内置的复制,Lua脚本,LRU驱逐,事务和不同级别的磁盘持久性,并通过Redis Sentinel和Redis Cluster自动分区提供了高可用性。

Redis是用C语言开发的一一个开源的高性能键值对( key-value )内存数据库。

它提供五种数据类型来存储值:字符串类型、散列类型、列表类型、集合类型、有序集合类型

它是一个NoSQL数据

Redis支持哪几种数据类型:String、List、Set、Sorted Set、hashes

2 Redis有那些优势?

(1) 速度快,因为数据存在内存中,类似于HashMap,HashMap的优势就是查找和操作的时间复杂度都是O(1) 
(2) 支持丰富数据类型,支持string,list,set,sorted set,hash 
(3) 支持事务,操作都是原子性,所谓的原子性就是对数据的更改要么全部执行,要么全部不执行 
(4) 丰富的特性:可用于缓存,消息,按key设置过期时间,过期后将会自动删除

3 Redis的特点?

Redis可以从磁盘重新将数据加载到内存中,这些可以通过配置文件对其进行配置,正因为这样,Redis才能实现持久化。

Redis支持主从模式,可以配置集群,这样更利于支撑起大型的项目,这也是Redis的一大亮点。

Redis的性能非常出色,每秒可以处理超过 10万次 读写操作,是已知性能最快的Key-Value DB

Redis的出色之处不仅仅是性能,Redis最大的魅力是支持保存多种数据结构,此外单 个 value 的最大限制是
1GB,不像 memcached只能保存1MB的数据,另外Redis 也可以对存入的Key-Value设置expire时间

 

4 什么是NoSQL数据库?

NoSQL ,即Not-0nly SQL (不仅仅是SQL ),泛指非关系型的数据库。

什么是关系型数据库?数据结构是一种有行有列的数据库

NoSQL数据库是为了解决高并发、融用、扩展、大数据存储问题而产生的数据库解决方案。

 

5 为什么redis需要把所有数据放到内存中?
Redis为了达到最快的读写速度将数据都读到内存中,并通过异步的方式将数据写入磁盘。所以redis具有快速和

数据持久化的特征。如果不将数据放在内存中,磁盘 I/O 速度为严重影响 redis 的性能。在内存越来越便宜的今天,
redis将会越来越受欢迎。如果设置了最大使用的内存,则数据已有记录数达到内存限值后不能继续插入新值。

 

NoSQL数据库分类

 ■ 键值(Key-Value)存储数据库

典型应用:内容缓存,主要用于处理大量数据的高访问负载。数据模型: 一系列键值对。

优势:快速查询劣势:存储的数据缺少结构化

 

列存储数据库

这部分数据库通常是用来应对分布式存储的海量数据。键仍然存在,但是它们的特点是指向了多个列。这些列是由列家族来安排的。
如:Cassandra, HBase, Riak

文档型数据库

文档型数据库的灵感是来自于Lotus Notes办公软件的,而且它同第一种键值存储相类似。该类型的数据模型是版本化的文档,半结构化的文档以特定的格式存储,比如JSON。文档型数据库可 以看作是键值数据库的升级版,允许之间嵌套键值。而且文档型数据库比键值数据库的查询效率更高。如:CouchDB, MongoDb. 国内也有文档型数据库SequoiaDB,已经开源。

■图形(Graph)数据库

图形结构的数据库同其他行列以及刚性结构的SQL数据库不同,它是使用灵活的图形模型,并且能够扩展到多个服务器上。NoSQL数据库没有标准的查询语言(SQL),因此进行数据库查询需要制定数据模型。许多NoSQL数据库都有REST式的数据接口或者查询API。如:Neo4J, InfoGrid, Infinite Graph。

 7 Redis安装配置

 

* 官网地址:http://redis.io/

 

* 中文官网地址:http://www.redis.cn/

 

* 下载地址:http://download.redis.io/releases/

 

1.解压

tar xzvf redis-4.0.8.tar.gz

2.安装

  yum install gcc-c++  

  cd redis-4.0.8

  make

  cd src

  make install PREFIX=/usr/local/redis

3.开启redis

  /usr/local/redis/bin/redis-server /usr/local/redis/etc/redis.conf 

4.常用命令  

  redis-server /usr/local/redis/etc/redis.conf //启动redis

  pkill redis  //停止redis

  卸载redis:

    rm -rf /usr/local/redis //删除安装目录

    rm -rf /usr/bin/redis-* //删除所有redis相关命令脚本

    rm -rf /root/download/redis-4.0.4 //删除redis解压文件夹


8.Redis的数据类型
Redis支持五种数据类型:string(字符串),hash(哈希),list(列表),set(集合)及zset(sorted set:有序集合)。

一、String(字符串)

  • string 是 redis 最基本的类型,你可以理解成与 Memcached 一模一样的类型,一个 key 对应一个 value。

  • string 类型是二进制安全的。意思是 redis 的 string 可以包含任何数据。比如jpg图片或者序列化的对象。

  • string 类型是 Redis 最基本的数据类型,string 类型的值最大能存储 512MB。

127.0.0.1:6379> SET name "yzl"
OK
127.0.0.1:6379> GET name
"yzl"

二、Hash(哈希)

  • Redis hash 是一个键值(key=>value)对集合。

  • Redis hash 是一个 string 类型的 field 和 value 的映射表,hash 特别适合用于存储对象。

  • 每个 hash 可以存储 232 -1 键值对(40多亿)

127.0.0.1:6379> HMSET myhash name "yzl" age "20"
OK
127.0.0.1:6379> HGET myhash name
"yzl"
127.0.0.1:6379> HGET myhash age
"20"

三、List(列表)

  • Redis 列表是简单的字符串列表,按照插入顺序排序。你可以添加一个元素到列表的头部(左边)或者尾部(右边)。
  • 列表最多可存储 232 - 1 元素 (4294967295, 每个列表可存储40多亿)。
  • 他的底层是一个链表
127.0.0.1:6379> LPUSH fruitlist apple
(integer) 1
127.0.0.1:6379> LPUSH fruitlist banana
(integer) 2
127.0.0.1:6379> LPUSH fruitlist orange
(integer) 3
127.0.0.1:6379> LRANGE fruitlist 1 2
1) "banana"
2) "apple"

四、Set(集合)

  • Redis的Set是string类型的无序集合。

  • 集合是通过哈希表实现的,所以添加,删除,查找的复杂度都是O(1)。

  • 集合中最大的成员数为 232 - 1(4294967295, 每个集合可存储40多亿个成员)。

sadd key member
添加一个 string 元素到 key 对应的 set 集合中,成功返回1,如果元素已经在集合中返回 0,如果 key 对应的 set 不存在则返回错误。

127.0.0.1:6379> sadd city beijing
(integer) 1
127.0.0.1:6379> sadd city hangzhou
(integer) 1
127.0.0.1:6379> sadd city shandong
(integer) 1
127.0.0.1:6379> sadd city guangzhou
(integer) 1
127.0.0.1:6379> sadd city beijing
(integer) 0
127.0.0.1:6379> smembers city
1) "shandong"
2) "guangzhou"
3) "hangzhou"
4) "beijing"

注意:以上实例中 beijing添加了两次,但根据集合内元素的唯一性,第二次插入的元素将被忽略。

五、zset(sorted set:有序集合)

  • zset 和 set 一样也是string类型元素的集合,且不允许重复的成员。
    不同的是每个元素都会关联一个double类型的分数。redis正是通过分数来为集合中的成员进行从小到大的排序。

  • zset的成员是唯一的,但分数(score)却可以重复。

zadd key score member
添加元素到集合,元素在集合中存在则更新对应score

127.0.0.1:6379> zadd price 3 pen
(integer) 1
127.0.0.1:6379> zadd price 5 apple
(integer) 1
127.0.0.1:6379> zadd price 50 dinner
(integer) 1
127.0.0.1:6379> zadd price 100 basketball
(integer) 1
127.0.0.1:6379> zrangebyscore price 10 200
1) "dinner"
2) "basketball"

 

posted @ 2020-01-31 12:19  晶晶很乖hello  阅读(140)  评论(0编辑  收藏  举报