欢迎来到淘文阁 - 分享文档赚钱的网站! | 帮助中心 好文档才是您的得力助手!
淘文阁 - 分享文档赚钱的网站
全部分类
  • 研究报告>
  • 管理文献>
  • 标准材料>
  • 技术资料>
  • 教育专区>
  • 应用文书>
  • 生活休闲>
  • 考试试题>
  • pptx模板>
  • 工商注册>
  • 期刊短文>
  • 图片设计>
  • ImageVerifierCode 换一换

    Redis详解与常见问题解决方案.docx

    • 资源ID:52769274       资源大小:75.55KB        全文页数:8页
    • 资源格式: DOCX        下载积分:20金币
    快捷下载 游客一键下载
    会员登录下载
    微信登录下载
    三方登录下载: 微信开放平台登录   QQ登录  
    二维码
    微信扫一扫登录
    下载资源需要20金币
    邮箱/手机:
    温馨提示:
    快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。
    如填写123,账号就是123,密码也是123。
    支付方式: 支付宝    微信支付   
    验证码:   换一换

     
    账号:
    密码:
    验证码:   换一换
      忘记密码?
        
    友情提示
    2、PDF文件下载后,可能会被浏览器默认打开,此种情况可以点击浏览器菜单,保存网页到桌面,就可以正常下载了。
    3、本站不支持迅雷下载,请使用电脑自带的IE浏览器,或者360浏览器、谷歌浏览器下载即可。
    4、本站资源下载后的文档和图纸-无水印,预览文档经过压缩,下载后原文更清晰。
    5、试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。

    Redis详解与常见问题解决方案.docx

    Redis简介redis是一个key-value存储系统。和Memcached类似,它支持存储的value类型相对更多,包括string(字符串)、list(链表)、set(集合)、zset(sortedset -有序集合)和hash(哈希类型)。这些数据类型都支持push/pop、add/remove及取交集并集和差集及更丰富的操作,而且这些操作都是原子性的。在此基础上,redis支持各种不同方式的排序。与memcached一样,为了保证效率,数据都是缓存在内存中。区别的是redis会周期性的把更新的数据写入磁盘或者把修改操作写入追加的记录文件,并且在此基础上实现了master-slave(主从)同步。安装:安装Redis官方网站:http:/redis.io/官方下载:http:/redis.io/download 可以根据需要下载不同版本windows版:下载安装包:解压启动Redis解压redis64-2.8.17版本后,找到redis.windows.conf,修改配置文件内容,内容如下。支持数据结构redis提供五种数据类型:String,hash,list,set及zset(sortedset)。Redis配置文件主要参数配置1、指定Redis监听端口,默认端口为6379。port 63792、绑定的主机地址bind 127.0.0.13、当客户端闲置多长时间后关闭连接,如果指定为0,表示关闭该功能timeout 3004、指定日志记录级别,Redis总共支持四个级别:debug、verbose、notice、warning,默认为verbose。loglevel verbose5、日志记录方式,默认为标准输出,如果配置Redis为守护进程方式运行,而这里又配置为日志记录方式为标准输出,则日志将会发送给/dev/null。logfile stdout6、设置数据库的数量,默认数据库为0,可以使用SELECT <dbid>命令在连接上指定数据库id。databases 167、指定在多长时间内,有多少次更新操作,就将数据同步到数据文件,可以多个条件配合。save <seconds><changes>8、Redis默认配置文件中提供了三个条件:save 900 1save 300 10save 60 10000分别表示900秒(15分钟)内有1个更改,300秒(5分钟)内有10个更改以及60秒内有10000个更改。9、指定存储至本地数据库时是否压缩数据,默认为yes,Redis采用LZF压缩,如果为了节省CPU时间,可以关闭该选项,但会导致数据库文件变的巨大。rdbcompression yes10、指定本地数据库文件名,默认值为dump.rdb。dbfilename dump.rdb11、 指定本地数据库存放目录。dir ./12、设置当本机为slave服务时,设置master服务的IP地址及端口,在Redis启动时,它会自动从master进行数据同步。slaveof <masterip><masterport>13、当master服务设置了密码保护时,slave服务连接master的密码。masterauth <master-password>14、设置Redis连接密码,如果配置了连接密码,客户端在连接Redis时需要通过AUTH <password>命令提供密码,默认关闭。requirepass foobared15、设置同一时间最大客户端连接数,默认无限制,Redis可以同时打开的客户端连接数为Redis进程可以打开的最大文件描述符数,如果设置 maxclients 0,表示不作限制。当客户端连接数到达限制时,Redis会关闭新的连接并向客户端返回max number of clientsreached错误信息。maxclients 12816、指定Redis最大内存限制,Redis在启动时会把数据加载到内存中,达到最大内存后,Redis会先尝试清除已到期或即将到期的Key,当此方法处理 后,仍然到达最大内存设置,将无法再进行写入操作,但仍然可以进行读取操作。Redis新的vm机制,会把Key存放内存,Value会存放在swap区。maxmemory <bytes>17、指定是否在每次更新操作后进行日志记录,Redis在默认情况下是异步的把数据写入磁盘,如果不开启,可能会在断电时导致一段时间内的数据丢失。因为 redis本身同步数据文件是按上面save条件来同步的,所以有的数据会在一段时间内只存在于内存中。默认为no。appendonly no18、指定更新日志文件名,默认为appendonly.aofappendfilename appendonly.aof19、指定更新日志条件,共有3个可选值: no:表示等操作系统进行数据缓存同步到磁盘(快) always:表示每次更新操作后手动调用fsync()将数据写到磁盘(慢,安全) everysec:表示每秒同步一次(折衷,默认值)appendfsync everysec20、 设置在向客户端应答时,是否把较小的包合并为一个包发送,默认为开启glueoutputbuf yes21、指定在超过一定的数量或者最大的元素超过某一临界值时,采用一种特殊的哈希算法。hash-max-zipmap-entries 64hash-max-zipmap-value 51222、指定是否激活重置哈希,默认为开启(后面在介绍Redis的哈希算法时具体介绍)。activerehashing yes23、slave根据指定的时间间隔向服务器发送ping请求。时间间隔可以通过 repl_ping_slave_period 来设置。默认10秒repl-ping-slave-period1024、当一个slave失去和master的连接,或者同步正在进行中,slave的行为有两种可能:(1) 如果 slave-serve-stale-data 设置为 "yes" (默认值),slave会继续响应客户端请求,可能是正常数据,也可能是还没获得值的空数据。(2) 如果 slave-serve-stale-data 设置为 "no",slave会回复"正在从master同步(SYNCwith master in progress)"来处理各种请求,除了 INFO 和 SLAVEOF 命令。slave-serve-stale-datayes25、Redis主从配置redis支持master-slave的主从配置,配置方法是在从机的配置文件中指定slaveof参数为主机的ip和port即可。slaveof 192.168.1.23 637926、 指定包含其它的配置文件,可以在同一主机上多个Redis实例之间使用同一份配置文件,而同时各个实例又拥有自己的特定配置文件。include /path/to/local.confinclude /path/to/other.confRedis中常见异常处理以及内存CPU优化Redis常出现问题总结:1、当出现修改-maxheap and -heapdir在启动这两个版本时都会创建一个 RedisQFork.dat文件,我不确定 RedisQFork 文件是否变小一点, 但我确定, 你可以通过设置Redis启动参数 heapdir 来调整这个文件的位置。我在 redis.windows.conf文件中搜索"heapdir",然后在默认注释掉的内容下面添加一行,指定Redis内存映射文件(memory mapped file)存放的路径:2、redis常见异常处理123# heapdir指定内存映射文件路径名,不能是文件名# heapdir <directory path(absoluteorrelative)>heapdir D:/temp/redis_heapdir/具体文件和目录就请你根据自己的磁盘进行指定啦. 我的症状和情况是这样的, 16GB内存,Windows版64bit的Redis,启动Redis后就在C盘的C:WindowsServiceProfilesNetworkServiceAppDataLocalRedis目录下面生成一个16GB大小的 RedisQFork_8792.dat 文件(8792是本次启动的进程PID, 关闭redis 则此文件自动被删除). 本来当初为了省钱只上了64GB的固态硬盘,结果16G一吃下来,C盘就只有16GB空余空间,自从设置到D盘,重启以后,感觉强迫症就好多了。3、常见异常处理如果你遇到 .SocketTimeoutException: Readtimed out exception的异常信息请尝试在构造JedisPool的时候设置自己的超时值. JedisPool默认的超时时间是2秒(单位毫秒)pool = new JedisPool(config, ip,port,RedisConfig.getTimeout();4、Redis中CPU使用效率优化将no-appendfsync-on-rewrite的配置设为yes可以缓解这个问题,设置为yes表示rewrite期间对新写操作不fsync,暂时存在内存中,等rewrite完成后再写入。最好是不开启Master的AOF备份功能。Redis也可以关闭自动持久化,注释掉这些save配置,或者save “”如果后台保存到磁盘发生错误,将停止写操作。stop-writes-on-bgsave-error yes。使用LZF压缩rdb文件,这会耗CPU, 但是可以减少磁盘占用。rdbcompression yes保存rdb和加载rdb文件的时候检验,可以防止错误,但是要付出约10%的性能,可以关闭他,提高性能。rdbchecksum yes5、当出现以下错误时:VirtualAlloc/COWAlloc fail! Out Of Memory allocating 42bytes!修改:maxmemory maxheap Redis客户端常用命令get keyset  key valueclearexists  keydel keydbsizelpush  key valueinfo allinfomonitorhgetall  keyredis 127.0.0.1:6379> info  #查看server版本内存使用连接等信息redis 127.0.0.1:6379> client list  #获取客户连接列表redis 127.0.0.1:6379> client kill 127.0.0.1:33441 #终止某个客户端连接redis 127.0.0.1:6379> dbsize #当前保存key的数量redis 127.0.0.1:6379> save #立即保存数据到硬盘redis 127.0.0.1:6379> bgsave #异步保存数据到硬盘redis 127.0.0.1:6379> flushdb #当前库中移除所有keyredis 127.0.0.1:6379> flushall #移除所有key从所有库中redis 127.0.0.1:6379> lastsave #获取上次成功保存到硬盘的时间戳redis 127.0.0.1:6379> monitor #实时监测服务器接收到的请求redis 127.0.0.1:6379> slowlog len #查询慢查询日志条数redis 127.0.0.1:6379> slowlog get #返回所有的慢查询日志,最大值取决于slowlog-max-len配置redis 127.0.0.1:6379> slowlog get 2 #打印两条慢查询日志redis 127.0.0.1:6379> slowlog reset #清空慢查询日志信息原文来自:申博官网 http:/www.l-宅男福利:http:/www.zhainan.hk

    注意事项

    本文(Redis详解与常见问题解决方案.docx)为本站会员(飞****2)主动上传,淘文阁 - 分享文档赚钱的网站仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知淘文阁 - 分享文档赚钱的网站(点击联系客服),我们立即给予删除!

    温馨提示:如果因为网速或其他原因下载失败请重新下载,重复下载不扣分。




    关于淘文阁 - 版权申诉 - 用户使用规则 - 积分规则 - 联系我们

    本站为文档C TO C交易模式,本站只提供存储空间、用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。本站仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知淘文阁网,我们立即给予删除!客服QQ:136780468 微信:18945177775 电话:18904686070

    工信部备案号:黑ICP备15003705号 © 2020-2023 www.taowenge.com 淘文阁 

    收起
    展开