您的位置:首页 > 数据库 > Redis

redis 学习指南

2015-07-22 16:01 746 查看
一、介绍

[align=left]Redis是一个开源的使用ANSI C语言编写、支持网络、可基于内存亦可持久化的日志型、一个高性能的key-value数据库。并提供多种语言的API。说到Key-Value数据库NoSQL数据库可以想到MongoDB。[/align]
[align=left]和Memcached类似,它支持存储的value类型相对更多,包括string(字符串)、list(链表)、set(集合)、zset(sorted set --有序集合)和hash(哈希类型)。这些数据类型都支持push/pop、add/remove及取交集并集和差集及更丰富的操作,而且这些操作都是原子性的。在此基础上,redis支持各种不同方式的排序。与memcached一样,为了保证效率,数据都是缓存在内存中。区别的是redis会周期性的把更新的数据写入磁盘或者把修改操作写入追加的记录文件,并且在此基础上实现了master-slave(主从)同步。[/align]

二、 基于windows 64bit安装

安装之前请务必确定你是Administrator管理员账号的windows用户!如果不是 Administrator用户,则可能需要以管理员身份运行. 或者参考 Windows
7 启用超级管理员administrator账户的N种方法
[align=left]在redis的下载页面有这样的一段话,说的意思是指redis项目未有提供对windows系统的支持,而Microsoft Open Tech提供了一个基于win64的redis实现。那就是说只支持64位系统了,32位的windows系统的同学就老老实实的换系统去吧。(*^__^*)[/align]
The Redis project does not officially support Windows. However, the Microsoft Open Tech group develops and maintains this Windows port targetingWin64.

[align=left]1、 下载与安装[/align]
[align=left]下载地址:https://github.com/MSOpenTech/redis/releases/download/win-2.8.19/redis-2.8.19.zip[/align]
[align=left]下载成功后解压可以看到如下文件[/align]



[align=left]Windows下的安装几乎没有什么过程,解压后就可以使用。简单介绍下着几个exe文件的用途:[/align]
[align=left]redis.windows.conf redis的配置文件[/align]
[align=left]redis-benchmark.exe 测试工具,测试redis的读写性能情况[/align]
[align=left]redis-check-aof.exe aof 修复检查日志[/align]
[align=left]redis-check-dump.exe dump 检查数据库文件[/align]
[align=left]redis-cli.exe redis客户端程序[/align]
[align=left]redis-server.exe redis服务器程序[/align]

三、
使用redis工具

[align=left]1、 redis-server 双击运行或者用dos命令打开都可以,成功运行后可以看到界面内容如下:[/align]



[align=left]会带有版本号、运行进程号、运行端口信息。并且会提醒使用redis.windows.conf配置文件。如果你启动失败的话,提醒内存问题。那就需要修改下配置文件的maxheap配置(默认情况下该配置没有赋值的,且没有开启),修改如下:[/align]
[align=left]# maxheap <bytes>[/align]
[align=left]maxheap 1024000000[/align]
[align=left]还有一种启动方式就是带指定redis.conf配置文件的启动方式,如下:[/align]



[align=left]当你想使用不同的配置文件来设置不同服务器参数的时候就需要这样,默认会使用根目录下的配置文件。[/align]
[align=left]redis-server /biran/conf/redis.conf 启动并加装指定配置文件[/align]
[align=left]redis-server - (read config from stdin) 使用标准输入读取配置为启动参数[/align]
[align=left]redis-server --test-memory 256 检测256MB内存[/align]
[align=left]redis-server –version 查版本号[/align]
[align=left]如果准备长期使用,则需要注册为系统服务.[/align]
[align=left]进入CMD,切换到redis所在目录:[/align]
[align=left]注册服务,可以保存为 service-install.bat 文件:[/align]
[align=left]redis-server.exe --service-install redis.windows.conf --loglevel verbose[/align]
[align=left]redis-server --service-start[/align]
[align=left]卸载服务, 可以保存为 uninstall-service.bat 文件:[/align]
[align=left]redis-server --service-stop[/align]
[align=left]redis-server --service-uninstall[/align]
[align=left]可以在注册服务时,通过 –service-name redisService1 参数直接指定服务名,适合安装多个实例的情况,卸载也是同样的道理.[/align]
[align=left]启动redis服务器时也可以直接指定配置文件,可以保存为 startup.bat 文件:[/align]
[align=left]redis-server.exe redis.windows.conf[/align]
[align=left]2、 redis.windows.conf各项配置参数介绍[/align]

[align=left]# 默认情况下,redis不是在后台模式运行的,如果需要在后台进程运行,把该项的值更改为yes,默认为no[/align]
[align=left]daemonize:是否以后台daemon方式运行[/align]
[align=left]# 如redis服务以后台进程运行的时候,Redis默认会把pid写入/run/redis.pid文件组,你可以配置到其他文件路径。[/align]
[align=left]# 当运行多个redis服务时,需要指定不同的pid文件和端口[/align]
[align=left]pidfile:pid文件位置[/align]
[align=left]# 指定redis监听端口,默认为6379[/align]
[align=left]# 如果端口设置为0,Redis就不会监听TCP套接字。[/align]
[align=left]port:监听的端口号[/align]
[align=left]# 指定redis只接收来自于该IP地址的请求,如果不进行设置,默认将处理所有请求,[/align]
[align=left]# 在生产环境中最好设置该项[/align]
[align=left]bind 127.0.0.1[/align]
[align=left]# 设置客户端连接时的超时时间,单位为秒。当客户端在这段时间内没有发出任何指令,那么关闭该连接[/align]
[align=left]# 默认值:0代表禁用,永不关闭[/align]
[align=left]timeout:请求超时时间[/align]
[align=left]# 指定用来监听连接的unxi套接字的路径。这个没有默认值,所以如果不指定的话,Redis就不会通过unix套接字来监听。[/align]
[align=left]# unixsocket /tmp/redis.sock[/align]
[align=left]# unixsocketperm 755[/align]
[align=left]# 指定日志记录级别[/align]
[align=left]# Redis总共支持四个级别:debug、verbose、notice、warning,默认为verbose[/align]
[align=left]# debug 记录很多信息,用于开发和测试[/align]
[align=left]# varbose 很多精简的有用信息,不像debug会记录那么多[/align]
[align=left]# notice 普通的verbose,常用于生产环境[/align]
[align=left]# warning 只有非常重要或者严重的信息会记录到日志[/align]
[align=left]loglevel:log信息级别[/align]
[align=left]# 配置log文件名称和全路径地址[/align]
[align=left]# 默认值为stdout,使用“标准输出”,默认后台模式会输出到/dev/null[/align]
[align=left]logfile:log文件位置[/align]
[align=left]# 可用数据库数,默认值为16,默认数据库存储在DB 0号ID库中,无特殊需求,建议仅设置一个数据库 databases 1[/align]
[align=left]# 查询数据库使用 SELECT <dbid>[/align]
[align=left]# dbid介于 0 到 'databases'-1 之间[/align]
[align=left]databases:开启数据库的数量[/align]
[align=left]save * *:保存快照的频率,第一个*表示多长时间,第三个*表示执行多少次写操作。在一定时间内执行一定数量的写操作时,自动保存快照。可设置多个条件。[/align]
[align=left]rdbcompression:是否使用压缩[/align]
[align=left]dbfilename:数据快照文件名(只是文件名,不包括目录)[/align]
[align=left]dir:数据快照的保存目录(这个是目录)[/align]
[align=left]appendonly:是否开启appendonlylog,开启的话每次写操作会记一条log,这会提高数据抗风险能力,但影响效率。[/align]
[align=left]appendfsync:appendonlylog如何同步到磁盘(三个选项,分别是每次写都强制调用fsync、每秒启用一次fsync、不调用fsync等待系统自己同步)[/align]
[align=left]########## REPLICATION 同步 ##########[/align]
[align=left]#[/align]
[align=left]# 主从同步。通过 slaveof 配置来实现Redis实例的备份。[/align]
[align=left]# 注意,这里是本地从远端复制数据。也就是说,本地可以有不同的数据库文件、绑定不同的IP、监听不同的端口。[/align]
[align=left]# 当本机为从服务时,设置主服务的IP及端口,在Redis启动时,它会自动从主服务进行数据同步[/align]
[align=left]# slaveof <masterip> <masterport>[/align]
[align=left]# 如果主服务master设置了密码(通过下面的 "requirepass" 选项来配置),slave服务连接master的密码,那么slave在开始同步之前必须进行身份验证,否则它的同步请求会被拒绝。[/align]
[align=left]#当本机为从服务时,设置主服务的连接密码[/align]
[align=left]# masterauth <master-password>[/align]
[align=left]# 当一个slave失去和master的连接,或者同步正在进行中,slave的行为有两种可能:[/align]
[align=left]# 1) 如果 slave-serve-stale-data 设置为 "yes" (默认值),slave会继续响应客户端请求,可能是正常数据,也可能是还没获得值的空数据。[/align]
[align=left]# 2) 如果 slave-serve-stale-data 设置为 "no",slave会回复"正在从master同步(SYNC with master in progress)"来处理各种请求,除了 INFO 和 SLAVEOF 命令。[/align]
[align=left]slave-serve-stale-data yes[/align]
[align=left]# slave根据指定的时间间隔向服务器发送ping请求。[/align]
[align=left]# 时间间隔可以通过 repl_ping_slave_period 来设置。[/align]
[align=left]# 默认10秒[/align]
[align=left]# repl-ping-slave-period 10[/align]
[align=left]# 下面的选项设置了大块数据I/O、向master请求数据和ping响应的过期时间。[/align]
[align=left]# 默认值60秒。[/align]
[align=left]# 一个很重要的事情是:确保这个值比 repl-ping-slave-period 大,否则master和slave之间的传输过期时间比预想的要短。[/align]
[align=left]# repl-timeout 60[/align]
[align=left]########## SECURITY 安全 ##########[/align]
[align=left]# 要求客户端在处理任何命令时都要验证身份和设置密码。[/align]
[align=left]# 如果你不相信请求者,这个功能很有用。[/align]
[align=left]# 为了向后兼容的话,这段应该注释掉。而且大多数人不需要身份验证(例如:它们运行在自己的服务器上。)[/align]
[align=left]# 警告:外部使用者可以每秒尝试150k的密码来试图破解密码,这意味着你需要一个高强度的密码,否则破解太容易了。[/align]
[align=left]# 设置连接密码[/align]
[align=left]# requirepass foobared[/align]
[align=left]# 命令重命名,可设置多个[/align]
[align=left]# 在共享环境下,可以为危险命令改变名字。比如,你可以为 CONFIG 改个其他不太容易猜到的名字,这样你自己仍然可以使用,而别人却没法知道它。[/align]
[align=left]# 例如:[/align]
[align=left]# rename-command CONFIG b840fc02d524045429941cc15f59e41cb7be6c52[/align]
[align=left]# rename-command info info_biran[/align]
[align=left]# rename-command set set_biran[/align]
[align=left]# 甚至也可以通过给命令赋值一个空字符串来完全禁用这条命令:[/align]
[align=left]# rename-command CONFIG ""[/align]
[align=left]########## LIMITS 限制 ##########[/align]
[align=left]# 设置最大同时连接客户端数量。[/align]
[align=left]# 默认没有限制,这个关系到Redis进程能够打开的文件描述符数量。[/align]
[align=left]# 特殊值"0"表示没有限制。[/align]
[align=left]# 一旦达到这个限制,Redis会关闭所有新连接并发送错误"达到最大用户数上限(max number of clients reached)"[/align]
[align=left]# maxclients 128[/align]
[align=left]# 不要用比设置的上限更多的内存。一旦内存使用达到上限,Redis会根据选定的回收策略(参见:maxmemmory-policy:内存策略设置)删除key。[/align]
[align=left]# 如果因为删除策略问题Redis无法删除key,或者策略设置为 "noeviction",Redis会回复需要更多内存的错误信息给命令。[/align]
[align=left]# 例如,SET,LPUSH等等。但是会继续合理响应只读命令,比如:GET。[/align]
[align=left]# 在使用Redis作为LRU缓存,或者为实例设置了硬性内存限制的时候(使用 "noeviction" 策略)的时候,这个选项还是满有用的。[/align]
[align=left]# 警告:当一堆slave连上达到内存上限的实例的时候,响应slave需要的输出缓存所需内存不计算在使用内存当中。[/align]
[align=left]# 这样当请求一个删除掉的key的时候就不会触发网络问题/重新同步的事件,然后slave就会收到一堆删除指令,直到数据库空了为止。[/align]
[align=left]# 简而言之,如果你有slave连上一个master的话,那建议你把master内存限制设小点儿,确保有足够的系统内存用作输出缓存。[/align]
[align=left]# (如果策略设置为"noeviction"的话就不无所谓了)[/align]
[align=left]# 设置最大内存,达到最大内存设置后,Redis会先尝试清除已到期或即将到期的Key,当此方法处理后,任到达最大内存设置,将无法再进行写入操作。[/align]
[align=left]# maxmemory 256000000分配256M内存[/align]
[align=left]# maxmemory <bytes>[/align]
[align=left]# 内存策略:如果达到内存限制了,Redis如何删除key。你可以在下面五个策略里面选:[/align]
[align=left]#[/align]
[align=left]# volatile-lru -> 根据LRU算法生成的过期时间来删除。[/align]
[align=left]# allkeys-lru -> 根据LRU算法删除任何key。[/align]
[align=left]# volatile-random -> 根据过期设置来随机删除key。[/align]
[align=left]# allkeys->random -> 无差别随机删。[/align]
[align=left]# volatile-ttl -> 根据最近过期时间来删除(辅以TTL)[/align]
[align=left]# noeviction -> 谁也不删,直接在写操作时返回错误。[/align]
[align=left]#[/align]
[align=left]# 注意:对所有策略来说,如果Redis找不到合适的可以删除的key都会在写操作时返回一个错误。[/align]
[align=left]#[/align]
[align=left]# 这里涉及的命令:set setnx setex append[/align]
[align=left]# incr decr rpush lpush rpushx lpushx linsert lset rpoplpush sadd[/align]
[align=left]# sinter sinterstore sunion sunionstore sdiff sdiffstore zadd zincrby[/align]
[align=left]# zunionstore zinterstore hset hsetnx hmset hincrby incrby decrby[/align]
[align=left]# getset mset msetnx exec sort[/align]
[align=left]#[/align]
[align=left]# 默认值如下:[/align]
[align=left]# maxmemory-policy volatile-lru[/align]
[align=left]# LRU和最小TTL算法的实现都不是很精确,但是很接近(为了省内存),所以你可以用样例做测试。[/align]
[align=left]# 例如:默认Redis会检查三个key然后取最旧的那个,你可以通过下面的配置项来设置样本的个数。[/align]
[align=left]# maxmemory-samples 3[/align]
[align=left]########## APPEND ONLY MODE 纯累加模式 ##########[/align]
[align=left]# 默认情况下,Redis是异步的把数据导出到磁盘上。因为redis本身同步数据文件是按上面save条件来同步的,所以有的数据会在一段时间内只存在于内存中,这种情况下,当Redis宕机的时候,最新的数据就丢了。[/align]
[align=left]# 如果不希望丢掉任何一条数据的话就该用纯累加模式:一旦开启这个模式,Redis会把每次写入的数据在接收后都写入 appendonly.aof 文件。[/align]
[align=left]# 每次启动时Redis都会把这个文件的数据读入内存里。[/align]
[align=left]#[/align]
[align=left]# 注意,异步导出的数据库文件和纯累加文件可以并存(此时需要把上面所有"save"设置都注释掉,关掉导出机制)。[/align]
[align=left]# 如果纯累加模式开启了,那么Redis会在启动时载入日志文件而忽略导出的 dump.rdb 文件。[/align]
[align=left]#[/align]
[align=left]# 重要:查看 BGREWRITEAOF 来了解当累加日志文件太大了之后,怎么在后台重新处理这个日志文件。[/align]
[align=left]# 设置:yes为纯累加模式[/align]
[align=left]appendonly no[/align]
[align=left]# 设置纯累加文件名字及保存路径,默认:"appendonly.aof"[/align]
[align=left]# appendfilename appendonly.aof[/align]
[align=left]# fsync() 请求操作系统马上把数据写到磁盘上,不要再等了。[/align]
[align=left]# 有些操作系统会真的把数据马上刷到磁盘上;有些则要磨蹭一下,但是会尽快去做。[/align]
[align=left]# Redis支持三种不同的模式:[/align]
[align=left]#[/align]
[align=left]# no:不要立刻刷,只有在操作系统需要刷的时候再刷。比较快。[/align]
[align=left]# always:每次写操作都立刻写入到aof文件。慢,但是最安全。[/align]
[align=left]# everysec:每秒写一次。折衷方案。[/align]
[align=left]# 默认的 "everysec" 通常来说能在速度和数据安全性之间取得比较好的平衡。[/align]
[align=left]# 如果你真的理解了这个意味着什么,那么设置"no"可以获得更好的性能表现(如果丢数据的话,则只能拿到一个不是很新的快照);[/align]
[align=left]# 或者相反的,你选择 "always" 来牺牲速度确保数据安全、完整。[/align]
[align=left]#[/align]
[align=left]# 如果不确定这些模式的使用,建议使用 "everysec"[/align]
[align=left]#[/align]
[align=left]# appendfsync always[/align]
[align=left]appendfsync everysec[/align]
[align=left]# appendfsync no[/align]
[align=left]# 如果AOF的同步策略设置成 "always" 或者 "everysec",那么后台的存储进程(后台存储或写入AOF日志)会产生很多磁盘I/O开销。[/align]
[align=left]# 某些Linux的配置下会使Redis因为 fsync() 而阻塞很久。[/align]
[align=left]# 注意,目前对这个情况还没有完美修正,甚至不同线程的 fsync() 会阻塞我们的 write(2) 请求。[/align]
[align=left]#[/align]
[align=left]# 为了缓解这个问题,可以用下面这个选项。它可以在 BGSAVE 或 BGREWRITEAOF 处理时阻止 fsync()。[/align]
[align=left]#[/align]
[align=left]# 这就意味着如果有子进程在进行保存操作,那么Redis就处于"不可同步"的状态。[/align]
[align=left]# 这实际上是说,在最差的情况下可能会丢掉30秒钟的日志数据。(默认Linux设定)[/align]
[align=left]#[/align]
[align=left]# 如果你有延迟的问题那就把这个设为 "yes",否则就保持 "no",这是保存持久数据的最安全的方式。[/align]
[align=left]no-appendfsync-on-rewrite no[/align]
[align=left]# 自动重写AOF文件[/align]
[align=left]# 如果AOF日志文件大到指定百分比,Redis能够通过 BGREWRITEAOF 自动重写AOF日志文件。[/align]
[align=left]#[/align]
[align=left]# 工作原理:Redis记住上次重写时AOF日志的大小(或者重启后没有写操作的话,那就直接用此时的AOF文件),[/align]
[align=left]# 基准尺寸和当前尺寸做比较。如果当前尺寸超过指定比例,就会触发重写操作。[/align]
[align=left]#[/align]
[align=left]# 你还需要指定被重写日志的最小尺寸,这样避免了达到约定百分比但尺寸仍然很小的情况还要重写。[/align]
[align=left]#[/align]
[align=left]# 指定百分比为0会禁用AOF自动重写特性。[/align]
[align=left]auto-aof-rewrite-percentage 100[/align]
[align=left]auto-aof-rewrite-min-size 64mb[/align]
[align=left]########## SLOW LOG 慢查询日志 ##########[/align]
[align=left]# Redis慢查询日志可以记录超过指定时间的查询。运行时间不包括各种I/O时间。[/align]
[align=left]# 例如:连接客户端,发送响应数据等。只计算命令运行的实际时间(这是唯一一种命令运行线程阻塞而无法同时为其他请求服务的场景)[/align]
[align=left]#[/align]
[align=left]# 你可以为慢查询日志配置两个参数:一个是超标时间,单位为微妙,记录超过个时间的命令。[/align]
[align=left]# 另一个是慢查询日志长度。当一个新的命令被写进日志的时候,最老的那个记录会被删掉。[/align]
[align=left]#[/align]
[align=left]# 下面的时间单位是微秒,所以1000000就是1秒。注意,负数时间会禁用慢查询日志,而0则会强制记录所有命令。[/align]
[align=left]slowlog-log-slower-than 10000[/align]
[align=left]# 这个长度没有限制。只要有足够的内存就行。你可以通过 SLOWLOG RESET 来释放内存。[/align]
[align=left]slowlog-max-len 128[/align]
[align=left]########## VIRTUAL MEMORY 虚拟内存 ##########[/align]
[align=left]### 警告!虚拟内存在Redis 2.4是反对的,因性能问题,2.4版本 VM机制彻底废弃,不建议使用此配置!!!!!!!!!!![/align]
[align=left]# 虚拟内存可以使Redis在内存不够的情况下仍然可以将所有数据序列保存在内存里。[/align]
[align=left]# 为了做到这一点,高频key会调到内存里,而低频key会转到交换文件里,就像操作系统使用内存页一样。[/align]
[align=left]# 要使用虚拟内存,只要把 "vm-enabled" 设置为 "yes",并根据需要设置下面三个虚拟内存参数就可以了。[/align]
[align=left]vm-enabled no[/align]
[align=left]# 这是交换文件的路径。估计你猜到了,交换文件不能在多个Redis实例之间共享,所以确保每个Redis实例使用一个独立交换文件。[/align]
[align=left]# 最好的保存交换文件(被随机访问)的介质是固态硬盘(SSD)。[/align]
[align=left]# *** 警告 *** 如果你使用共享主机,那么默认的交换文件放到 /tmp 下是不安全的。[/align]
[align=left]# 创建一个Redis用户可写的目录,并配置Redis在这里创建交换文件。[/align]
[align=left]vm-swap-file /tmp/redis.swap[/align]
[align=left]# "vm-max-memory" 配置虚拟内存可用的最大内存容量。[/align]
[align=left]# 如果交换文件还有空间的话,所有超标部分都会放到交换文件里。[/align]
[align=left]# "vm-max-memory" 设置为0表示系统会用掉所有可用内存,建议设置为剩余内存的60%-80%。[/align]
[align=left]# 将所有大于vm-max-memory的数据存入虚拟内存,无论vm-max-memory设置多小,所有索引数据都是内存存储的(Redis的索引数据就是keys),也就是说,当vm-max-memory设置为0的时候,其实是所有value都存在于磁盘。默认值为0。[/align]
[align=left]vm-max-memory 0[/align]
[align=left]# Redis交换文件是分成多个数据页的。[/align]
[align=left]# 一个可存储对象可以被保存在多个连续页里,但是一个数据页无法被多个对象共享。[/align]
[align=left]# 所以,如果你的数据页太大,那么小对象就会浪费掉很多空间。[/align]
[align=left]# 如果数据页太小,那用于存储的交换空间就会更少(假定你设置相同的数据页数量)[/align]
[align=left]# 如果你使用很多小对象,建议分页尺寸为64或32个字节。[/align]
[align=left]# 如果你使用很多大对象,那就用大一些的尺寸。[/align]
# 如果不确定,那就用默认值


[align=left]vm-page-size 32[/align]
[align=left]# 交换文件里数据页总数。[/align]
[align=left]# 根据内存中分页表(已用/未用的数据页分布情况),磁盘上每8个数据页会消耗内存里1个字节。[/align]
[align=left]# 交换区容量 = vm-page-size * vm-pages[/align]
[align=left]# 根据默认的32字节的数据页尺寸和134217728的数据页数来算,Redis的数据页文件会占4GB,而内存里的分页表会消耗16MB内存。[/align]
[align=left]# 为你的应验程序设置最小且够用的数字比较好,下面这个默认值在大多数情况下都是偏大的。[/align]
[align=left]vm-pages 134217728[/align]
[align=left]# 同时可运行的虚拟内存I/O线程数,即访问swap文件的线程数。[/align]
[align=left]# 这些线程可以完成从交换文件进行数据读写的操作,也可以处理数据在内存与磁盘间的交互和编码/解码处理。[/align]
[align=left]# 多一些线程可以一定程度上提高处理效率,虽然I/O操作本身依赖于物理设备的限制,不会因为更多的线程而提高单次读写操作的效率。[/align]
[align=left]# 特殊值0会关闭线程级I/O,并会开启阻塞虚拟内存机制。[/align]
[align=left]# 设置最好不要超过机器的核数,如果设置为0,那么所有对swap文件的操作都是串行的.可能会造成比较长时间的延迟,但是对数据完整性有很好的保证.[/align]
[align=left]vm-max-threads 4[/align]
[align=left]########## ADVANCED CONFIG 高级配置 ##########[/align]
[align=left]# 当有大量数据时,适合用哈希编码(这会需要更多的内存),元素数量上限不能超过给定限制。[/align]
[align=left]# Redis Hash是value内部为一个HashMap,如果该Map的成员数比较少,则会采用类似一维线性的紧凑格式来存储该Map, 即省去了大量指针的内存开销,如下2个条件任意一个条件超过设置值都会转换成真正的HashMap,[/align]
[align=left]# 当value这个Map内部不超过多少个成员时会采用线性紧凑格式存储,默认是64,即value内部有64个以下的成员就是使用线性紧凑存储,超过该值自动转成真正的HashMap。[/align]
[align=left]hash-max-zipmap-entries 512[/align]
[align=left]# 当 value这个Map内部的每个成员值长度不超过多少字节就会采用线性紧凑存储来节省空间。[/align]
[align=left]hash-max-zipmap-value 64[/align]
[align=left]# 与hash-max-zipmap-entries哈希相类似,数据元素较少的情况下,可以用另一种方式来编码从而节省大量空间。[/align]
[align=left]# list数据类型多少节点以下会采用去指针的紧凑存储格式[/align]
[align=left]list-max-ziplist-entries 512[/align]
[align=left]# list数据类型节点值大小小于多少字节会采用紧凑存储格式[/align]
[align=left]list-max-ziplist-value 64[/align]
[align=left]# 还有这样一种特殊编码的情况:数据全是64位无符号整型数字构成的字符串。[/align]
[align=left]# 下面这个配置项就是用来限制这种情况下使用这种编码的最大上限的。[/align]
[align=left]set-max-intset-entries 512[/align]
[align=left]# 与第一、第二种情况相似,有序序列也可以用一种特别的编码方式来处理,可节省大量空间。[/align]
[align=left]# 这种编码只适合长度和元素都符合下面限制的有序序列:[/align]
[align=left]zset-max-ziplist-entries 128[/align]
[align=left]zset-max-ziplist-value 64[/align]
[align=left]# 哈希刷新,每100个CPU毫秒会拿出1个毫秒来刷新Redis的主哈希表(顶级键值映射表)。[/align]
[align=left]# redis所用的哈希表实现(见dict.c)采用延迟哈希刷新机制:你对一个哈希表操作越多,哈希刷新操作就越频繁;[/align]
[align=left]# 反之,如果服务器非常不活跃那么也就是用点内存保存哈希表而已。[/align]
[align=left]# 默认是每秒钟进行10次哈希表刷新,用来刷新字典,然后尽快释放内存。[/align]
[align=left]# 建议:[/align]
[align=left]# 如果你对延迟比较在意的话就用 "activerehashing no",每个请求延迟2毫秒不太好嘛。[/align]
[align=left]# 如果你不太在意延迟而希望尽快释放内存的话就设置 "activerehashing yes"。[/align]
[align=left]activerehashing yes[/align]
[align=left]########## INCLUDES 包含 ##########[/align]
[align=left]# 包含一个或多个其他配置文件。[/align]
[align=left]# 这在你有标准配置模板但是每个redis服务器又需要个性设置的时候很有用。[/align]
[align=left]# 包含文件特性允许你引人其他配置文件,所以好好利用吧。[/align]
[align=left]# include /path/to/local.conf[/align]
[align=left]# include /path/to/other.conf[/align]
[align=left]修改配置后,如果配置文件涉及到中文内容记得将文件存为UTF-8编码。[/align]

[align=left]3、 redis-cli 客户端使用[/align]
[align=left]测试服务器启动连接情况[/align]
[align=left]127.0.0.1:6379> ping[/align]
[align=left]PONG[/align]
[align=left]查看服务器级别信息(测试服务器)[/align]
[align=left]127.0.0.1:6379> info[/align]
[align=left]# Server[/align]
[align=left]redis_version:2.8.19[/align]
[align=left]redis_git_sha1:00000000[/align]
[align=left]redis_git_dirty:0[/align]
[align=left]redis_build_id:9968db13395be4aa[/align]
[align=left]redis_mode:standalone[/align]
[align=left]os:Windows[/align]
[align=left]arch_bits:64[/align]
[align=left]multiplexing_api:winsock_IOCP[/align]
[align=left]gcc_version:0.0.0[/align]
[align=left]process_id:9204[/align]
[align=left]run_id:fc4a126eaed1572b6855c9af511d3451eb358c85[/align]
[align=left]tcp_port:6379[/align]
[align=left]uptime_in_seconds:2365[/align]
[align=left]uptime_in_days:0[/align]
[align=left]hz:10[/align]
[align=left]lru_clock:3087964[/align]
[align=left]config_file:G:\software\redis\redis.windows.conf[/align]
[align=left]# Clients[/align]
[align=left]connected_clients:1[/align]
[align=left]client_longest_output_list:0[/align]
[align=left]client_biggest_input_buf:0[/align]
[align=left]blocked_clients:0[/align]
[align=left]# Memory[/align]
[align=left]used_memory:11568456[/align]
[align=left]used_memory_human:11.03M[/align]
[align=left]used_memory_rss:11534800[/align]
[align=left]used_memory_peak:11568456[/align]
[align=left]used_memory_peak_human:11.03M[/align]
[align=left]used_memory_lua:35840[/align]
[align=left]mem_fragmentation_ratio:1.00[/align]
[align=left]mem_allocator:dlmalloc-2.8[/align]
[align=left]# Persistence[/align]
[align=left]loading:0[/align]
[align=left]rdb_changes_since_last_save:0[/align]
[align=left]rdb_bgsave_in_progress:0[/align]
[align=left]rdb_last_save_time:1429148959[/align]
rdb_last_bgsave_status

k
[align=left]rdb_last_bgsave_time_sec:-1[/align]
[align=left]rdb_current_bgsave_time_sec:-1[/align]
[align=left]aof_enabled:0[/align]
[align=left]添加数据[/align]
[align=left]127.0.0.1:6379> set user hoojo[/align]
[align=left]OK[/align]
[align=left]127.0.0.1:6379> get user[/align]
[align=left]"hoojo"[/align]
[align=left]查看所有的key信息[/align]
[align=left]127.0.0.1:6379> keys *[/align]
[align=left]1) "key:000000000308"[/align]
[align=left]2) "key:000000000900"[/align]
[align=left]3) "key:__rand_int__"[/align]
[align=left]4) "key:000000000809"[/align]
[align=left]5) "key:000000000164"[/align]
[align=left]6) "key:000000000887"[/align]
[align=left]基本参数介绍[/align]
[align=left]-h[/align]
[align=left]设置检测主机IP地址,默认为127.0.0.1[/align]
[align=left]-p[/align]
[align=left]设置检测主机的端口号,默认为6379[/align]
[align=left]-s<socket>[/align]
[align=left]服务器套接字(压倒主机和端口)[/align]
[align=left]-a[/align]
[align=left]连接到Master服务器时使用的密码[/align]
[align=left]-r[/align]
[align=left]执行指定的N次命令[/align]
[align=left]-i[/align]
[align=left]执行命令后等待N秒,如–i 0.1 info(执行后等0.1秒)[/align]
[align=left]-n[/align]
[align=left]指定连接N号ID数据库,如 –n 3(连接3号数据库)[/align]
[align=left]-x[/align]
[align=left]从控制台输入的信息中读取最后一个参数[/align]
[align=left]-d[/align]
[align=left]定义多个定界符为默认输出格式(默认: \n)[/align]
[align=left]--raw[/align]
[align=left]使用原数据格式返回输出内容[/align]
[align=left]--latency[/align]
[align=left]进入一个不断延时采样的特殊模式[/align]
[align=left]--slave[/align]
[align=left]模拟一个从服务器到主服务器的命令显示反馈[/align]
[align=left]--pipe[/align]
[align=left]使用管道协议模式[/align]
[align=left]--bigkeys[/align]
[align=left]监听显示数据量大的key值,--bigkeys -i 0.1[/align]
[align=left]--help[/align]
[align=left]显示命令行帮助信息[/align]
[align=left]--version[/align]
[align=left]显示版本号[/align]
[align=left]4、 redis-benchmark 性能测试工具[/align]
[align=left]默认双击打开是按照默认的测试参数进行测试。[/align]



[align=left]输入如上命令后会看到如下信息,表明同时并发10个连接,总共100次操作。通俗易懂的说就是10个用户同时操作,总共每人操作10次的意思。[/align]
[align=left]100 requests completed in 0.01 seconds (100个请求完成于0.01秒)[/align]
[align=left]10 parallel clients (10个客户端并发)[/align]
[align=left]3 bytes payload (每次写入3个字节)[/align]
[align=left]keep alive: 1 (保存一个链接数)[/align]
[align=left]100.00% <= 1 milliseconds (100%的操作小于1秒完成)[/align]
[align=left]16666.67 requests per second (每秒完成16666.67次查询)[/align]
[align=left]命令参数说明[/align]
[align=left]redis-benchmark [-h <host>] [-p <port>] [-c <clients>] [-n <requests]> [-k <boolean>][/align]
[align=left]-h <hostname> 主机名 (默认 127.0.0.1)[/align]
[align=left]-p <port> 主机端口 (默认 6379)[/align]
[align=left]-s <socket> 主机套接字 (覆盖主机和端口)[/align]
[align=left]-c <clients> 并发连接的数量 (默认 50)[/align]
[align=left]-n <requests> 请求总数 (默认 10000)[/align]
[align=left]-d <size> SET/GET数据的字节大小(默认 2)[/align]
[align=left]-k <boolean> 1=keep alive 0=reconnect (默认 1)[/align]
[align=left]-r <keyspacelen> SET/GET/INCR使用随机产生的key, SADD使用随机值使用这个选项 get/set keys时会用mykey_rand:000000012456代替常量key, <keyspacelen>参数决定了随机数产生的最大值,比如,设置参数为10,那么产生的随机数范围是rand:000000000000 -rand:000000000009[/align]
[align=left]-P <numreq> Pipeline请求的数量. 默认 1 (不使用pipeline).[/align]
[align=left]-q 展示query/sec值[/align]
[align=left]--csv 以CSV格式输出[/align]
[align=left]-l 本地循环. 一直运行测试[/align]
[align=left]-t <tests> 在运行逗号分割列表的测试. 测试的名字与产生输出的名字一样。[/align]
[align=left]-I 空闲模式. 打开 N 个空闲连接,然后等待.[/align]
[align=left]运行示例[/align]
[align=left]对指定服务器、端口进行20个同时并发操作,总共操作100000次[/align]
[align=left]redis-benchmark -h 192.168.1.136 -p 6379 -n 100000 -c 20[/align]
[align=left]测试set写入操作1000000次,随机数范围在100000000[/align]
[align=left]redis-benchmark -t set -n 1000000 -r 100000000[/align]
[align=left]测试ping、set、get操作100000次,结果输出用csv格式[/align]
[align=left]redis-benchmark -t ping,set,get -n 100000 –-csv[/align]
[align=left]redis-benchmark -r 10000 -n 10000 lpush mylist ele:rand:000000000000[/align]
[align=left]5、 redis-check-aof 基本用法[/align]
[align=left]检查本地日志信息,加--fix参数为修复log文件[/align]
[align=left]redis-check-aof.exe log.aof[/align]

[align=left]6、 redis-check-dump 检查数据库文件[/align]
[align=left]redis-check-dump.exe dump.rdb 会输出该文件大小、使用情况。[/align]

四、影响Redis性能的因素

[align=left]* 网络带宽和延迟。在执行基准测试前使用ping快速检测客户端和服务器端的延迟是一个良好的做法。对于带宽,比较好的做法是估计Gbits/s 的吞吐量和网络的理论带宽值比较。在很多实际的情况,Redis的吞吐量在网络之前会受限于CPU。[/align]
[align=left]* CPU也会是一个重要因素。由于单线程的,Redis受益于快速的含有巨大缓存的CPU。[/align]
[align=left]* 内存的速度和容量对于小的对象影响不大。但对于大于10KB的对象,可能对需要注意。通常购买昂贵的快速内存模块并不是真正的很有效。[/align]
[align=left]* Redis在虚拟机上运行慢。虚拟化对很多普通操作来说代价太高了,Redis并没有增加多少开销在所需的系统调用和网络中断上。[/align]
[align=left]* 客户端和服务器在一台机器运行,对于基准测试TCP/IP回送和UNIX域套接字都可以使用。取决于平台,但UNIX域套接字比TCP/IP回送增加50%的吞吐量。[/align]
[align=left]* 当大量使用 pipelining时,UNIX域套接字获得的性能好处会减少。[/align]
[align=left]* 当以太网访问Redis时,在数据大小小于以太网数据包的大小(大约1500字节)时,聚集命令使用 pipelining会非常有效。[/align]
[align=left]* 在多CPU套接字服务器,Redis的表现变得依赖于NUMA配置和处理位置。[/align]
[align=left]* 在高端配置,客户端连接的数量也是一个重要的因素。基于epool/kqueue模型,Redis的事件循环是相当可伸缩的。[/align]
[align=left]* 在高端的配置,通过调优NIC(s)配置和相关中断可能取得高吞吐量。[/align]
[align=left]* 根据平台,Redis编译可以使用不同的内存分配器,这可能有不同的行为在原始速度,内部和外部的碎片方面[/align]
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: