zoukankan      html  css  js  c++  java
  • Redis简单介绍与安装

    Redis是一个开源,高级的键值存储和一个适用的解决方案,用于构建高性能,可扩展的Web应用程序。

    Redis有三个主要特点,使它优越于其它键值数据存储系统 -

    1) Redis将其数据库完全保存在内存中,仅使用磁盘进行持久化。
    2) 与其它键值数据存储相比,Redis有一组相对丰富的数据类型。
    3) Redis可以将数据复制到任意数量的从机中。
    

    一、Redis优点

    1) 异常快 - Redis非常快,每秒可执行大约110000次的设置(SET)操作,每秒大约可执行81000次的读取/获取(GET)操作。
    2) 支持丰富的数据类型 - Redis支持开发人员常用的大多数数据类型,例如列表,集合,排序集和散列等等。这使得Redis很容易被用来解决各种问题,因为我们知道哪些问题可以更好使用地哪些数据类型来处理解决。
    3) 操作具有原子性 - 所有Redis操作都是原子操作,这确保如果两个客户端并发访问,Redis服务器能接收更新的值。
    4) 多实用工具 - Redis是一个多实用工具,可用于多种用例,如:缓存,消息队列(Redis本地支持发布/订阅),应用程序中的任何短期数据,例如,web应用程序中的会话,网页命中计数等。
    

    二、Redis与其他键值存储系统

    1) Redis是键值数据库系统的不同进化路线,它的值可以包含更复杂的数据类型,可在这些数据类型上定义原子操作。
    2) Redis是一个内存数据库,但在磁盘数据库上是持久的,因此它代表了一个不同的权衡,在这种情况下,在不能大于存储器(内存)的数据集的限制下实现非常高的写和读速度。
    3) 内存数据库的另一个优点是,它与磁盘上的相同数据结构相比,复杂数据结构在内存中存储表示更容易操作。 因此,Redis可以做很少的内部复杂性。
    

    三、Redis数据类型(支持5种数据类型。)

    1.字符串

    Redis中的字符串是一个字节序列。Redis中的字符串是二进制安全的,这意味着它们的长度不由任何特殊的终止字符决定。因此,可以在一个字符串中存储高达512兆字节的任何内容。
    -字符串值的最大长度为 512MB。
    

    2.散列/哈希

    Redis散列/哈希(Hashes)是键值对的集合。Redis散列/哈希是字符串字段和字符串值之间的映射。因此,它们用于表示对象。
    -每个散列/哈希可以存储多达2^32 - 1个健-值对(超过40亿个)。
    

    3.列表

    Redis列表只是字符串列表,按插入顺序排序。我们可以向Redis列表的头部或尾部添加元素。
    -列表的最大长度为2^32 - 1个元素(4294967295,每个列表可容纳超过40亿个元素)。
    

    4.集合

    Redis集合是字符串的无序集合。在Redis中,我们可以添加,删除和测试成员存在的时间O(1)复杂性。
    -一个集合中的最大成员数量为2^32 - 1(即4294967295,每个集合中元素数量可达40亿个)个。
    

    5.可排序集合

    Redis可排序集合类似于Redis集合,是不重复的字符集合。 不同之处在于,排序集合的每个成员都与分数相关联,这个分数用于按最小分数到最大分数来排序的排序集合。虽然成员是唯一的,但分数值可以重复。
    

    四、安装

    本次测试环境是一台ip为192.168.2.11的虚拟机

    1.下载文件 https://redis.io/download

    2.解压安装

    tar xzf  redis-3.2.0.tar.gz
    cd redis-3.2.0
    make
    make install PREFIX=/usr/redis  #设置安装路径
    
    安装成功后,如图:
    

    3.启动redis服务端

    cp ~/redis-3.2.0/redis.conf /usr/redis/   #将配置文件复制到安装指定的目录
    cd /usr/redis
    bin/redis-server ./redis.conf  #启动服务, redis启动默认为前台模式,因此可以看到如下图效果:
    

    五、开机自启

    1.修改redis.conf文件

    daemonize yes        #设置为后台启动模式
    pidfile /var/run/redis_6379.pid
    

    2.修改redis_init_script文件

    cd ~/redis-3.2.0/utils #redis解压的目录
    vim redis_init_script
    
    在# as it does use of the /proc filesystem.下一行修改:    
    # chkconfig: 2345 90 10
    # descrption: Redis is a per....
    REDISPORT=6379
    EXEC=/usr/redis/bin/redis-server
    CLIEXEC=/usr/redis/bin/redis-cli
    PIDFILE=/var/run/redis_${REDISPORT}.pid
    CONF="/usr/redis/redis.conf"
    
    上边两行#的注释必须要添加,否则脚本无法添加到自启动任务列表中。
    

    3.设置redis开启和关闭命令

    cp redis_init_script /etc/init.d/redis
    chmod +x /etc/init.d/redis
    
    service redis start
    service redis stop 
    

    如果执行service redis stop出现如下图的结果:
    

    1)修改redis.conf中
        bind ip #非127.0.0.1,而是系统中指定的ip,通过ifconfig查询
        本次测试配置是 bind 192.168.2.11
    

    2)修改/etc/init.d/redis
        将$CLIEXEC -p $REDISPORT shutdown修改成
        $CLIEXEC -h 192.168.2.11 -p $REDISPORT shutdown
    

    4.添加自启动服务

    chkconfig redis on    #设置自启动
    chkconfig --list  #查看自启动列表
    

    六、补充

    如果redis设置了密码,则redis脚本(原名redis_init_script)中的
    $CLIEXEC -h 192.168.2.11 -p $REDISPORT shutdown需要改成
    $CLIEXEC -h 192.168.2.11 -p $REDISPORT -a "密码" shutdown
  • 相关阅读:
    工作五年,后面四年重复着第一年的活儿?
    ECMAScript 6 扫盲
    当前端也拥有 Server 的能力
    简述 OAuth 2.0 的运作流程
    近几年前端技术盘点以及 2016 年技术发展方向
    NodeJS的代码调试和性能调优
    新应用上线 Snippet
    这两天说到的苹果软件中毒是个什么情况?
    网站的SEO以及它和站长工具的之间秘密
    博客搬家通知
  • 原文地址:https://www.cnblogs.com/moonlightL/p/7364107.html
Copyright © 2011-2022 走看看