zoukankan      html  css  js  c++  java
  • linux下如何安装配置redis及主从配置

    redis是一种非关系型数据存储工具,这区别于传统的关系型数据库(像MySQL等),类似于memcache,并且其内部集成了对list(链表)、set(集合)的操作,可以很方便快速的处理数据(像插入、删除list取交集 并集 差集等),这极大的减轻了底层数据库的压力,并且给用户更快的响应速度。

    redis的优点:支持主从备份,操作指令丰富,支持异步的数据持久化

    一丶使用

    将 redis 安装到 /usr/local/webserver/redis

    1.下载安装包

    wget http://redis.googlecode.com/files/redis-2.2.15.tar.gz
    tar zxvf redis-2.2.15.tar.gz
    cd redis-2.2.15
    make
    mkdir -p /usr/local/webserver/redis/conf
    mkdir -p /usr/local/webserver/redis/run
    mkdir -p /usr/local/webserver/redis/db
    cp redis.conf /usr/local/webserver/redis/conf/
    cd src
    2.将 src 目录下所有可执行文件复制到安装目录
    cp redis-benchmark redis-check-aof redis-check-dump redis-cli redis-server mkreleasehdr.sh
    /usr/local/webserver/redis/
    3.修改配置文件 
    ------- vi /usr/local/webserver/redis/conf/redis.conf --------
    daemonize yes --yes启用守护进程
    pidfile /usr/local/webserver/redis/run/redis.pid --Redis以守护进程方式运行时把pid写入文件
    dir /usr/local/webserver/redis/db --数据存放的目录
    --------------------------------------------------------------
    4.创建启动和停止服务脚本
    ------- vi /usr/local/webserver/redis/start.sh ---------
    #!/bin/bash
    /usr/local/webserver/redis/redis-server /usr/local/webserver/redis/conf/redis.conf
    ------- vi /usr/local/webserver/redis/stop.sh ---------
    #!/bin/bash
    kill `cat /usr/local/webserver/redis/run/redis.pid`
    chmod a+x /usr/local/webserver/redis/start.sh /usr/local/webserver/redis/stop.sh
    5.启动 redis 服务 
    /usr/local/webserver/redis/start.sh
    验证证服务是否成功:
    netstat -nlpt | grep 6379
    6.启动客户端验证
    /usr/local/webserver/redis/redis-cli
    >set key1 val1
    >get key1
    二. M/S主从集群配置

    1台Master和一台Slave
    Master IP:127.0.0.1 PORT:6379
    Slave1 IP:127.0.0.1 PORT:63791
    2.复制slave目录,方便管理

    cp -r /usr/local/webserver/redis /usr/local/webserver/redis-slave1
    3.修改slave的配置文件和服务脚本
    -- vi /usr/local/webserver/redis-slave1/conf/redis.conf --
    port 63791
    pidfile /usr/local/webserver/redis-slave1/run/redis.pid
    dir /usr/local/webserver/redis-slave1/db
    slaveof 127.0.0.1 6379
    ----------------------------------------------------------

    -- vi /usr/local/webserver/redis-slave1/start.sh --
    #!/bin/bash
    /usr/local/webserver/redis-slave1/redis-server /usr/local/webserver/redis-slave1/conf/redis.conf
    ---------------------------------------------------

    ------- vi /usr/local/webserver/redis-slave1/stop.sh ---------
    #!/bin/bash
    kill `cat /usr/local/webserver/redis-slave1/run/redis.pid`
    --------------------------------------------------------
    4.启动M/S服务
    /usr/local/webserver/redis/start.sh
    /usr/local/webserver/redis-slave1/start.sh
    验证服务是否正常
    netstat -nlpt | grep redis-server
    5.验证redis是否有效
    /usr/local/webserver/redis/redis-cli [默认连接端口:6379 的 Master服务]
    >set key1 val1
    >quit

    /usr/local/webserver/redis/redis-cli -p 63791 [连接 Slave1 服务]
    >get key1
    “val1″ (数据成功同步了)
    多个slave同理配置

    三丶介绍

    1. 服务说明

    redis-server.exe 服务程序
       redis.conf redis配置文件
       redis-cli.exe 命令行客户端,测试用
       redis-check-dump.exe 本地数据库检查
       redis-check-aof.exe 更新日志检查
       redis-benchmark.exe 性能测试,用以模拟同时由N个客户端发送M个 SETs/GETs 查询 (类似于 Apache的 ab 工具)

    1. Redis默认不是以守护进程的方式运行,可以通过该配置项修改,使用yes启用守护进程

        daemonize no

    2. 当Redis以守护进程方式运行时,Redis默认会把pid写入/var/run/redis.pid文件,可以通过pidfile指定

        pidfile /var/run/redis.pid

    3. 指定Redis监听端口,默认端口为6379,作者在自己的一篇博文中解释了为什么选用6379作为默认端口,因为6379在手机按键上MERZ对应的号码,而MERZ取自意大利歌女Alessia Merz的名字

        port 6379

    4. 绑定的主机地址

        bind 127.0.0.1

    5.当 客户端闲置多长时间后关闭连接,如果指定为0,表示关闭该功能

        timeout 300

    6. 指定日志记录级别,Redis总共支持四个级别:debug、verbose、notice、warning,默认为verbose

        loglevel verbose

    7. 日志记录方式,默认为标准输出,如果配置Redis为守护进程方式运行,而这里又配置为日志记录方式为标准输出,则日志将会发送给/dev/null

        logfile stdout

    8. 设置数据库的数量,默认数据库为0,可以使用SELECT <dbid>命令在连接上指定数据库id

        databases 16

    9. 指定在多长时间内,有多少次更新操作,就将数据同步到数据文件,可以多个条件配合

        save <seconds> <changes>

        Redis默认配置文件中提供了三个条件:

        save 900 1

        save 300 10

        save 60 10000

        分别表示900秒(15分钟)内有1个更改,300秒(5分钟)内有10个更改以及60秒内有10000个更改。

    10. 指定存储至本地数据库时是否压缩数据,默认为yes,Redis采用LZF压缩,如果为了节省CPU时间,可以关闭该选项,但会导致数据库文件变的巨大

        rdbcompression yes

    11. 指定本地数据库文件名,默认值为dump.rdb

        dbfilename dump.rdb

    12. 指定本地数据库存放目录

        dir ./

    13. 设置当本机为slav服务时,设置master服务的IP地址及端口,在Redis启动时,它会自动从master进行数据同步

        slaveof <masterip> <masterport>

    14. 当master服务设置了密码保护时,slav服务连接master的密码

        masterauth <master-password>

    15. 设置Redis连接密码,如果配置了连接密码,客户端在连接Redis时需要通过AUTH <password>命令提供密码,默认关闭

        requirepass foobared

    16. 设置同一时间最大客户端连接数,默认无限制,Redis可以同时打开的客户端连接数为Redis进程可以打开的最大文件描述符数,如果设置 maxclients 0,表示不作限制。当客户端连接数到达限制时,Redis会关闭新的连接并向客户端返回max number of  clients reached错误信息

        maxclients 128

    17. 指定Redis最大内存限制,Redis在启动时会把数据加载到内存中,达到最大内存后,Redis会先尝试清除已到期或即将到期的Key,当此方法处理 后,仍然到达最大内存设置,将无法再进行写入操作,但仍然可以进行读取操作。Redis新的vm机制,会把Key存放内存,Value会存放在swap区

        maxmemory <bytes>

    18. 指定是否在每次更新操作后进行日志记录,Redis在默认情况下是异步的把数据写入磁盘,如果不开启,可能会在断电时导致一段时间内的数据丢失。因为 redis本身同步数据文件是按上面save条件来同步的,所以有的数据会在一段时间内只存在于内存中。默认为no

        appendonly no

    19. 指定更新日志文件名,默认为appendonly.aof

         appendfilename appendonly.aof

    20. 指定更新日志条件,共有3个可选值: 
        no:表示等操作系统进行数据缓存同步到磁盘(快) 
        always:表示每次更新操作后手动调用fsync()将数据写到磁盘(慢,安全) 
        everysec:表示每秒同步一次(折衷,默认值)

        appendfsync everysec

    21. 指定是否启用虚拟内存机制,默认值为no,简单的介绍一下,VM机制将数据分页存放,由Redis将访问量较少的页即冷数据swap到磁盘上,访问多的页面由磁盘自动换出到内存中(在后面的文章我会仔细分析Redis的VM机制)

         vm-enabled no

    22. 虚拟内存文件路径,默认值为/tmp/redis.swap,不可多个Redis实例共享

         vm-swap-file /tmp/redis.swap

    23. 将所有大于vm-max-memory的数据存入虚拟内存,无论vm-max-memory设置多小,所有索引数据都是内存存储的(Redis的索引数据 就是keys),也就是说,当vm-max-memory设置为0的时候,其实是所有value都存在于磁盘。默认值为0

         vm-max-memory 0

    24. Redis swap文件分成了很多的page,一个对象可以保存在多个page上面,但一个page上不能被多个对象共享,vm-page-size是要根据存储的 数据大小来设定的,作者建议如果存储很多小对象,page大小最好设置为32或者64bytes;如果存储很大大对象,则可以使用更大的page,如果不 确定,就使用默认值

         vm-page-size 32

    25. 设置swap文件中的page数量,由于页表(一种表示页面空闲或使用的bitmap)是在放在内存中的,,在磁盘上每8个pages将消耗1byte的内存。

         vm-pages 134217728

    26. 设置访问swap文件的线程数,最好不要超过机器的核数,如果设置为0,那么所有对swap文件的操作都是串行的,可能会造成比较长时间的延迟。默认值为4

         vm-max-threads 4

    27. 设置在向客户端应答时,是否把较小的包合并为一个包发送,默认为开启

        glueoutputbuf yes

    28. 指定在超过一定的数量或者最大的元素超过某一临界值时,采用一种特殊的哈希算法

        hash-max-zipmap-entries 64

        hash-max-zipmap-value 512

    29. 指定是否激活重置哈希,默认为开启(后面在介绍Redis的哈希算法时具体介绍)

        activerehashing yes

    30. 指定包含其它的配置文件,可以在同一主机上多个Redis实例之间使用同一份配置文件,而同时各个实例又拥有自己的特定配置文件

        include /path/to/local.conf

    3.工具

    对集合写入测试
      100000 requests completed in 2.38 seconds
    100000个请求在2.38秒内完成
      60 parallel clients
    每次请求有60个并发客户端
      3 bytes payload
    每次写入3个字节的数据
      keep alive: 1
    保持一个连接,一台服务器来处理这些请求
    所有请求在62毫秒内完成
    42105.26 requests per second
    每秒处理42105.26次请求
    连接控制
    QUIT 关闭连接
    AUTH (仅限启用时)简单的密码验证

    适合全体类型的命令
    EXISTS key判断一个键是否存在;存在返回 1;否则返回0;
    DEL key删除某个key,或是一系列key;DEL key1 key2 key3 key4
    TYPE key 返回某个key元素的数据类型( none:不存在,string:字符,list,set,zset,hash)
    KEYS pattern 返回匹配的key列表(KEYS foo*:查找foo开头的keys)
    RANDOMKEY随机获得一个已经存在的key,如果当前数据库为空,则返回空字符串
    RENAME oldnamenewname更改key的名字,新键如果存在将被覆盖
    RENAMENX oldnamenewname 更改key的名字,如果名字存在则更改失败
    DBSIZE返回当前数据库的key的总数
    EXPIRE设置某个key的过期时间(秒),(EXPIRE bruce1000:设置bruce这个key1000秒后系统自动删除)注意:如果在还没有过期的时候,对值进行了改变,那么那个值会被清除。
    TTL查找某个key还有多长时间过期,返回时间秒
    SELECT index选择数据库
    MOVE key dbindex将指定键从当前数据库移到目标数据库 dbindex。成功返回1;否则返回0(源数据库不存在key或目标数据库已存在同名key);
    FLUSHDB清空当前数据库中的所有键
    FLUSHALL清空所有数据库中的所有键

    处理字符串的命令
    SET key value给一个键设置字符串值。SET keyname datalength data (SET bruce 10paitoubing:保存key为burce,字符串长度为10的一个字符串paitoubing到数据库),data最大不可超过1G。
    GET key获取某个key的value值。如key不存在,则返回字符串“nil”;如key的值不为字符串类型,则返回一个错误。
    GETSET keyvalue可以理解成获得的key的值然后SET这个值,更加方便的操作 (SET bruce 10paitoubing,这个时候需要修改bruce变成1234567890并获取这个以前的数据paitoubing,GETSETbruce 10 1234567890)
    MGET key1 key2 … keyN一次性返回多个键的值
    SETNX key valueSETNX与SET的区别是SET可以创建与更新key的value,而SETNX是如果key不存在,则创建key与value数据
    MSET key1 value1 key2value2 … keyN valueN 在一次原子操作下一次性设置多个键和值
    MSETNX key1 value1 key2value2 … keyN valueN在一次原子操作下一次性设置多个键和值(目标键不存在情况下,如果有一个以上的key已存在,则失败)
    INCR key 自增键值
    INCRBY key integer令键值自增指定数值
    DECR key 自减键值
    DECRBY key integer令键值自减指定数值

    处理 lists 的命令
    RPUSH key value 从 List尾部添加一个元素(如序列不存在,则先创建,如已存在同名Key而非序列,则返回错误)
    LPUSH key value 从 List头部添加一个元素
    LLEN key 返回一个 List的长度
    LRANGE key startend从自定的范围内返回序列的元素 (LRANGE testlist 0 2;返回序列testlist前0 1 2元素)
    LTRIM key startend修剪某个范围之外的数据 (LTRIM testlist 0 2;保留0 1 2元素,其余的删除)
    LINDEX keyindex返回某个位置的序列值(LINDEX testlist 0;返回序列testlist位置为0的元素)
    LSET key indexvalue更新某个位置元素的值
    LREM key count value 从List的头部(count正数)或尾部(count负数)删除一定数量(count)匹配value的元素,返回删除的元素数量。
    LPOP key 弹出 List的第一个元素
    RPOP key 弹出 List的最后一个元素
    RPOPLPUSH srckey dstkey弹出 _srckey_ 中最后一个元素并将其压入 _dstkey_头部,key不存在或序列为空则返回“nil”

    处理集合(sets)的命令(有索引无序序列)
    SADD keymember增加元素到SETS序列,如果元素(membe)不存在则添加成功 1,否则失败 0;(SADD testlist 3 one)
    SREM key member删除SETS序列的某个元素,如果元素不存在则失败0,否则成功 1(SREM testlist 3 N one)
    SPOP key从集合中随机弹出一个成员
    SMOVE srckey dstkeymember 把一个SETS序列的某个元素 移动到 另外一个SETS序列 (SMOVE testlist test 3 two;从序列testlist移动元素two到 test中,testlist中将不存在two元素)
    SCARD key统计某个SETS的序列的元素数量
    SISMEMBER key member获知指定成员是否存在于集合中
    SINTER key1 key2 … keyN 返回 key1, key2, …, keyN 中的交集
    SINTERSTORE dstkey key1key2 … keyN 将 key1, key2, …, keyN 中的交集存入 dstkey
    SUNION key1 key2 … keyN返回 key1, key2, …, keyN 的并集
    SUNIONSTORE dstkey key1key2 … keyN 将 key1, key2, …, keyN 的并集存入 dstkey
    SDIFF key1 key2 … keyN依据 key2, …, keyN 求 key1 的差集。官方例子:
    key1 = x,a,b,c
    key2 = c
    key3 = a,d
    SDIFF key1,key2,key3=> x,b
    SDIFFSTORE dstkey key1key2 … keyN 依据 key2, …, keyN 求 key1 的差集并存入 dstkey
    SMEMBERS key返回某个序列的所有元素
    SRANDMEMBER key随机返回某个序列的元素

    处理有序集合(sorted sets)的命令 (zsets)
    ZADD key score member添加指定成员到有序集合中,如果目标存在则更新score(分值,排序用)
    ZREM key member从有序集合删除指定成员
    ZINCRBY key incrementmember 如果成员存在则将其增加_increment_,否则将设置一个score为_increment_的成员
    ZRANGE key start end返回升序排序后的指定范围的成员
    ZREVRANGE key start end返回降序排序后的指定范围的成员
    ZRANGEBYSCORE key minmax 返回所有符合score >= min和score <=max的成员 ZCARD key 返回有序集合的元素数量 ZSCORE key element 返回指定成员的SCORE值ZREMRANGEBYSCORE key min max 删除符合 score >= min 和score <= max 条件的所有成员

    排序(List, Set, Sorted Set)
    SORT key BY patternLIMIT start end GET pattern ASC|DESC ALPHA 按照指定模式排序集合或List

    SORT mylist DESC

    SORT mylist LIMIT 0 10ALPHA DESC
    按首字符排序

    SORT mylist BY weight_*STORE resultkey
    将返回的结果存放于resultkey序列(List)

    持久控制
    SAVE 同步保存数据到磁盘
    BGSAVE 异步保存数据到磁盘
    LASTSAVE返回上次成功保存到磁盘的Unix时间戳
    SHUTDOWN 同步保存到服务器并关闭Redis 服务器(SAVE+QUIT)
    BGREWRITEAOF当日志文件过长时重写日志文件

    远程控制命令
    INFO提供服务器的信息和统计信息
    MONITOR实时输出所有收到的请求
    SLAVEOF 修改复制选项

  • 相关阅读:
    如何 Xcode 开发工具里安装一个空的项目末模板
    推荐完成项目要使用的常用工具
    仿照 QQ 的 cell 的左滑删除、置顶、标记未读效果
    API接口文档的撰写
    UI:动画
    UI:多线程 、用GCD创建线程
    UI:UICollectionView
    开发中的一些零碎知识点
    UI:数据库练习、滤镜效果
    UI:地图和定位
  • 原文地址:https://www.cnblogs.com/yechanglv/p/6941888.html
Copyright © 2011-2022 走看看