zoukankan      html  css  js  c++  java
  • 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"
  • 相关阅读:
    Hystrix熔断原理
    FeignClient Hystrix超时重试降级
    Windows上Docker Toolbox修改镜像源
    Windows10家庭版安装docker
    Class类文件结构--访问标志
    MySQL常见的七种锁详细介绍()
    maven setting.xml 阿里云镜像 没有一句废话
    mysql 批量操作,已存在则修改,不存在则insert,同时判断空选择性写入字段
    hdu5730
    3月部分题目简要题解
  • 原文地址:https://www.cnblogs.com/jingjinggood/p/12221780.html
Copyright © 2011-2022 走看看