Redis详解与常见问题解决方案_第1页
Redis详解与常见问题解决方案_第2页
Redis详解与常见问题解决方案_第3页
Redis详解与常见问题解决方案_第4页
Redis详解与常见问题解决方案_第5页
已阅读5页,还剩3页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

经典word整理文档,仅参考,双击此处可删除页眉页脚。本资料属于网络整理,如有侵权,请联系删除,谢谢!redis是一个key-value存储系统。和Memcached类似,它支持存储的value类型相对更多,包括string(字符串、list(链表)、set(集合、zset(sortedset--有序集合和hash(哈希类型)。这些数据类型都支持push/popadd/remove及取交集并集和差集及更丰富的操作,而且这些操作都是原子性的。在此基础上,redis支持各种不同方式的排序。与memcached一样,为了保证效率,数据都是缓存在内存中。区别的是redis会周期性的把更新的数据写入磁盘或者把修改操作写入追加的记录文件,并且在此基础上实现了master-slave(主从同步。官方网站:http://redis.io/解压redis64-2.8.17版本后,找到redis.windows.conf,修改配置文件内容,内容如下。支持数据结构redis提供五种数据类型:String,hash,,set及zset(sortedset)。Redis配置文件主要参数配置1、指定Redis监听端口,默认端口为6379。port63792、绑定的主机地址bind3、当客户端闲置多长时间后关闭连接,如果指定为0,表示关闭该功能timeout3004、指定日志记录级别,Redis总共支持四个级别:debug、verbose、notice、,默认为verbose。loglevelverbose5、日志记录方式,默认为标准输出,如果配置Redis为守护进程方式运行,而这里又配置为日志记录方式为标准输出,则日志将会发送给/dev/null。6、设置数据库的数量,默认数据库为0,可以使用SELECT命令在连接上指定数据库id。7、指定在多长时间内,有多少次更新操作,就将数据同步到数据文件,可以多个条件配合。save<seconds><changes>8、Redis默认配置文件中提供了三个条件:save9001save30010save6010000分别表示900秒(15分钟)内有1个更改,300秒(5分钟)内有10个更改以及60秒内有10000个更改。9Redis采用LZF压缩,如果为了节省CPU时间,可以关闭该选项,但会导致数据库文件变的巨大。rdbcompressionyes10、指定本地数据库文件名,默认值为dump.rdb。dbfilenamedump.rdb11、指定本地数据库存放目录。dir./12、设置当本机为slave服务时,设置master服务的IP地址及端口,在Redis启动时,它会自动从master进行数据同步。slaveof<masterip><masterport>13、当master服务设置了密码保护时,slave服务连接master的密码。masterauth<master-password>14、设置Redis连接密码,如果配置了连接密码,客户端在连接Redis时需要通过AUTH<password>命令提供密码,默认关闭。requirepassfoobared15、设置同一时间最大客户端连接数,默认无限制,Redis可以同时打开的客户端连接数为Redismaxclients,表示不作限制。当客户端连接数到达限制时,Redis会关闭新的连接并向客户端返回maxnumberofclientsreached错误信息。maxclients12816、指定Redis最大内存限制,Redis在启动时会把数据加载到内存中,达到最Redis会先尝试清除已到期或即将到期的Key,当此方法处理后,仍Redis新的vm机制,会把Key存放内存,Value会存放在swap区。maxmemory<bytes>17Redis在默认情况下是异步的把redis本身同步数据文件是按上面save间内只存在于内存中。默认为no。appendonlyno18、指定更新日志文件名,默认为appendonly.aofappendfilenameappendonly.aof19、指定更新日志条件,共有3个可选值:no:表示等操作系统进行数据缓存同步到磁盘(快):表示每次更新操作后手动调用fsync()将数据写到磁盘(慢,安全)20、设置在向客户端应答时,是否把较小的包合并为一个包发送,默认为开启glueoutputbufyes21、指定在超过一定的数量或者最大的元素超过某一临界值时,采用一种特殊的哈希算法。hash-max-zipmap-entries64hash-max-zipmap-value51222、指定是否激活重置哈希,默认为开启(后面在介绍Redis的哈希算法时具23、slave根据指定的时间间隔向服务器发送ping请求。时间间隔可以通过repl_ping_slave_period来设置。默认10秒repl-ping-slave-period1024slave失去和masterslave的行为有(1)如果slave-serve-stale-data设置为"yes"默认值slave会继续响应客户(2)如果slave-serve-stale-data设置为,slave会回复"正在从master同步(SYNCwithmasterin来处理各种请求,除了INFO和SLAVEOF命令。slave-serve-stale-datayes25、Redis主从配置redis支持master-slave的主从配置,配置方法是在从机的配置文件中指定slaveof参数为主机的ip和port即可。slaveof3637926、指定包含其它的配置文件,可以在同一主机上多个Redis实例之间使用同include/path/to/local.conf1、当出现修改--maxheapand--heapdir在启动这两个版本时都会创建一个RedisQFork.dat文件,我不确定RedisQFork文件是否变小一点,但我确定,你可以通过设置Redis启动参数heapdir来调整这个文件的位置。我在redis.windows.conf文件中搜索"heapdir",然后在默认注释掉的内容下面添加一行,指定Redis内存映射文件(memorymappedfile)存放的路径:2、redis常见异常处理1#heapdir指定内存映射文件路径名,不能是文件名2#heapdir<directorypath(absoluteorrelative)>3heapdirD:/temp/redis_heapdir/具体文件和目录就请你根据自己的磁盘进行指定啦.我的症状和情况是这样的,16GB内存,Windows版64bit的Redis,启动Redis后就在C盘的C:\Windows\ServiceProfiles\NetworkService\AppData\Local\Redis目录下面生成一个16GB大小的RedisQFork_8792.dat文件(8792是本次启动的进程PID,关闭redis则此文件自动被删除).本来当初为了省钱只上了64GB,结果16G一吃下来,C盘就只有16GB,自从设置到D盘,重启以后,感觉强迫症就好多了。3、常见异常处理如果你遇到.SocketTimeoutException:Readtimedoutexception的异常信息请尝试在构造JedisPool的时候设置自己的超时值.JedisPool默认的超时时间是2秒单位毫秒)pool=newJedisPool(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-erroryes。使用LZF压缩rdb,这会耗CPU,但是可以减少磁盘占用。rdbcompressionyes保存rdb和加载rdb文件的时候检验,可以防止错误,但是要付出约10%的性能,可以关闭他,提高性能。rdbchecksumyes5、当出现以下错误时:VirtualAlloc/COWAllocfail!OutOfMemoryallocating42bytes!修改:maxmemory1024000000maxheap1024000000Redis客户端常用命令getkeysetkeyvalueclearexistskeydelkeydbsizelpushkeyvalueinfoallinfomonitorhgetallkeyredis:6379>info#查看server版本内存使用连接等信息redis:6379>clientlist#获取客户连接列表redis:6379>clientkill:33441#终止某个客户端连接redis:6379>dbsize#当前保存key的数量redis:6379>save#立即保存数据到硬盘redis:6379>bgsave#异步保存数据到硬盘redis:6379>flushdb#当前库中移除所有keyredis:6379>flushall#移除所有key从所有库中redis:6379>lastsave#获取上次成功保存到硬盘的时间戳redis:6379>monitor

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论