【Redis】安装配置及数据类型

Redis安装配置及数据类型



Redis,一个开源的使用ANSI C语言编写、支持网络、可基于内存亦可以持久化的日志型、Key-Value数据库,并提供多种语言的API;

Redis像是一个HashMap,但它不在JVM中运行,而是以一个独立进程的形式运行。

​ 数据的存取速度比数据库(Mysql)快,一般会被当作缓存使用,所以常用的数据可以考虑放在这里以提高性能

Redis安装

Window安装

window安装地址

下载到的Redis支持32bit和64bit。根据自己实际情况选择,将64bit的内容cp到自定义盘符安装目录取名redis。 如 G:\redis。
1、打开运行根目录下的 redis-server.exe ,运行窗口保持打开状态,不要关了。

想方便的话,可以将redis的路径加入到系统的环境变量之中,就省得输路径了

在这里插入图片描述
2、再打开目录下的redis-cli.exe,或者执行命令: redis-cli.exe -h 127.0.0.1 -p 6379
在这里插入图片描述

Redis配置

Redis的配置文件位于Redis安装目录中,文件名为redis.conf

通过CONFIG命令查看和设置配置项

1、查看配置

命令格式:

redis 127.0.0.1:6379> CONFIG GET CONFIG_SETTING_NAME

例:

redis 127.0.0.1:6379> CONFIG GET loglevel

1) "loglevel"
2) "notice"

使用符号 * 获取所有配置项

2、修改配置

命令格式:

redis 127.0.0.1:6379> CONFIG SET CONFIG_SETTING_NAME NEW_CONFIG_VALUE

例:

redis 127.0.0.1:6379> CONFIG SET loglevel "notice"
OK
redis 127.0.0.1:6379> CONFIG GET loglevel

1) "loglevel"
2) "notice"

3、配置项参数说明

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

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

    pidfile /var/run/redis.pid
    
  2. port:指定reids监听端口,默认端口为6379 。

  3. bind:绑定的主机地址,默认127.0.0.1

  4. timeout:客户端闲置多长时间关闭连接,若为0,表示关闭该功能

  5. loglevel:日志记录级别。

    redis总共支持四个级别:debug、verbose、notice、warning,默认为verbose

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

  7. save <seconds> <changes> :表示在多长时间内 (以s为单位) 有几次更新操作,将数据同步到数据文件。

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

    • save 900 1
    • save 300 10
    • save 60 10000
  8. rdbcompression:指定存储到本地数据库时是否压缩数据,默认为yes。

    redis采用LZF压缩,如果为了节省CPU时间,可以关闭该选项,但会导致数据库文件大小变得很大

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

  10. dir:指定本地数据库存放目录

  11. slaveof <masterip> <masterport>:

    设置当本机为slav服务时,设置master服务的ip地址以及端口,在redis启动时候,会自动从master进行数据同步

  12. masterauth <master-password>:当master服务设置了密码保护时候,slav服务连接master的密码。

  13. requirepass foobared:

    设置redis连接密码,如果设置了连接密码,客户端在连接redis时候需要通过AUTH <password> 命令提供密码,默认no

  14. maxclients 128:

    设置同一时间最大客户端连接数,默认无限制。

    Redis可以同时打开的客户端连接数为Redis进程可以打开的最大文件描述符数,如果设置 maxclients 0,表示不作限制

    当客户端连接数到达限制时,Redis会关闭新的连接并向客户端返回max number of clients reached错误信息

  15. maxmemory <bytes>:指定Redis最大内存限制

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

    Redis新的vm机制,会把Key存放内存,Value会存放在swap区

  16. appendonly no :指定是否在每次更新操作后进行日志记录,默认为no

    Redis在默认情况下是异步的把数据写入磁盘,如果不开启,可能会在断电时导致一段时间内的数据丢失。

    因为 redis本身同步数据文件是按上面save条件来同步的,所以有的数据会在一段时间内只存在于内存中。

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

  18. appendfsync everysec:指定更新日志条件。

    共有三个可选值:

    • no:表示等操作系统进行数据缓存同步到磁盘(快)
    • always:表示每次更新操作后手动调用fsync()将数据写到磁盘(慢,安全)
    • everysec:表示每秒同步一次(折中,默认)
  19. vm-enabled no:指定是否启用虚拟内存机制,默认值为no

    VM机制将数据进行分页存放,由Redis将访问量较少的页即冷数据swap到磁盘上,访问多的页面由磁盘自动换出到内存中

  20. vm-swap-file /tmp/redis.swap:虚拟内存文件路径,默认为/tmp/redis.swap,多个redis实例不可共享。

  21. vm-max-memory 0 :将所有大于vm-max-memory的数据存入虚拟内存中,默认为0。

    Redis的所有索引数据(即keys)都是存储在内存当中的,无论vm-max-memory设置为何值。

    当vm-max-memory设置为0 时,其实便是所有value都存在于磁盘。

  22. vm-page-size 32:指定swap文件中page的大小,默认为32bytes。

    Redis的swap文件分成了很多的page,一个对象可以保存在多个page上面,但一个page上不能被多个对象共享。

    vm-page-size是要根据存储的 数据大小来设定的,如果存储很多小对象,page大小最好设置为32或者64bytes;如果存储很大大对象,则可以使用更大的page,如果不 确定,就使用默认值

  23. vm-pages 134217728:指定swap文件中的page数量,默认大小为 227即134217728。

  24. vm-max-threads 4:设置访问swap文件的线程数,默认值为4。

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

  25. glueoutputbuf yes:设置在想客户端应答时,是否把较小的包合并为一个包发送,默认为开启。

  26. hash-max-zipmap-entries 64:指定在超过一定的数量时,采用一种特殊的哈希算法

  27. hash-max-zipmap-value 512:指定在最大的元素超过某一临界值时,采用一种特殊的哈希算法

  28. activerehashing yes:指定是否激活重置哈希,默认为yes

  29. include /path/to/local.conf :指定包含其他的配置文件,可以在同一主机上多个redis实例之间使用同一份配置文件,同时各个实例也拥有自己特定的配置文件。

Redis的数据类型

Redis中有5种数据类型:

  • String 字符串
  • List 列表
  • Hash 字典
  • Set 集合
  • Sorted Set 有序集合

不同的数据类型,有不同的命令方式。

String 相关命令

set (key) (value)			设置key = value
append (key) (value2)		在key对应的value尾部追加value2
get	(key)					获取key对应的value
incr (key)				将key对应的value加1
incrby (key) (value1)		将key对应的value加上value1
ttl (key)					获取key到期的剩余时间
rename (key) (key_new)		对key重命名

SET key value                   设置key=value
GET key                         或者键key对应的值
GETRANGE key start end          得到字符串的子字符串存放在一个键
GETSET key value                设置键的字符串值,并返回旧值
GETBIT key offset               返回存储在键位值的字符串值的偏移
MGET key1 [key2..]              得到所有的给定键的值
SETBIT key offset value         设置或清除该位在存储在键的字符串值偏移
SETEX key seconds value         键到期时设置值
SETNX key value                 设置键的值,只有当该键不存在
SETRANGE key offset value       覆盖字符串的一部分从指定键的偏移
STRLEN key                      得到存储在键的值的长度
MSET key value [key value...]   设置多个键和多个值
MSETNX key value [key value...] 设置多个键多个值,只有在当没有按键的存在时
PSETEX key milliseconds value   设置键的毫秒值和到期时间
INCR key                        增加键的整数值一次
INCRBY key increment            由给定的数量递增键的整数值
INCRBYFLOAT key increment       由给定的数量递增键的浮点值
DECR key                        递减键一次的整数值
DECRBY key decrement            由给定数目递减键的整数值
APPEND key value                追加值到一个键
DEL key                         如果存在删除键
DUMP key                        返回存储在指定键的值的序列化版本
EXISTS key                      此命令检查该键是否存在
EXPIRE key seconds              指定键的过期时间
EXPIREAT key timestamp          指定的键过期时间。在这里,时间是在Unix时间戳格式
PEXPIRE key milliseconds        设置键以毫秒为单位到期
PEXPIREAT key milliseconds-timestamp        设置键在Unix时间戳指定为毫秒到期
KEYS pattern                    查找与指定模式匹配的所有键
MOVE key db                     移动键到另一个数据库
PERSIST key                     移除过期的键
PTTL key                        以毫秒为单位获取剩余时间的到期键。
TTL key                         获取键到期的剩余时间。
RANDOMKEY                       从Redis返回随机键
RENAME key newkey               更改键的名称
RENAMENX key newkey             重命名键,如果新的键不存在
TYPE key                        返回存储在键的数据类型的值。

List 列表

lpush (listkey) (value)			给listkey列表添加(一个或多个)元素(在前面添加)
rpush (listkey) (value)			给listkey列表添加(一个或多个)元素(在后面添加)
llen (listkey)					获取listkey的长度
lrange (listkey) (start) (end)	从start位置至end位置获取其中的元素

BLPOP key1 [key2 ] timeout 取出并获取列表中的第一个元素,或阻塞,直到有可用
BRPOP key1 [key2 ] timeout 取出并获取列表中的最后一个元素,或阻塞,直到有可用
BRPOPLPUSH source destination timeout 从列表中弹出一个值,它推到另一个列表并返回它;或阻塞,直到有可用
LINDEX key index 从一个列表其索引获取对应的元素
LINSERT key BEFORE|AFTER pivot value 在列表中的其他元素之后或之前插入一个元素
LLEN key 获取列表的长度
LPOP key 获取并取出列表中的第一个元素
LPUSH key value1 [value2] 在前面加上一个或多个值的列表
LPUSHX key value 在前面加上一个值列表,仅当列表中存在
LRANGE key start stop 从一个列表获取各种元素
LREM key count value 从列表中删除元素
LSET key index value 在列表中的索引设置一个元素的值
LTRIM key start stop 修剪列表到指定的范围内
RPOP key 取出并获取列表中的最后一个元素
RPOPLPUSH source destination 删除最后一个元素的列表,将其附加到另一个列表并返回它
RPUSH key value1 [value2] 添加一个或多个值到列表
RPUSHX key value 添加一个值列表,仅当列表中存在

Hash字典,哈希表

hset person (key) (value)		设置person哈希表中的key键对应值为value
hgetall person					显示person哈希表中所有的key和value
hkeys person					显示person哈希表中所有的keys
hvals person					


HDEL key field[field...] 删除对象的一个或几个属性域,不存在的属性将被忽略
HEXISTS key field 查看对象是否存在该属性域
HGET key field 获取对象中该field属性域的值
HGETALL key 获取对象的所有属性域和值
HINCRBY key field value 将该对象中指定域的值增加给定的value,原子自增操作,只能是integer的属性值可以使用
HINCRBYFLOAT key field increment 将该对象中指定域的值增加给定的浮点数
HKEYS key 获取对象的所有属性字段
HVALS key 获取对象的所有属性值
HLEN key 获取对象的所有属性字段的总数
HMGET key field[field...] 获取对象的一个或多个指定字段的值
HSET key field value 设置对象指定字段的值
HMSET key field value [field value ...] 同时设置对象中一个或多个字段的值
HSETNX key field value 只在对象不存在指定的字段时才设置字段的值
HSTRLEN key field 返回对象指定field的value的字符串长度,如果该对象或者field不存在,返回0.
HSCAN key cursor [MATCH pattern] [COUNT count] 类似SCAN命令

Set集合

SADD key member [member ...] 	添加一个或者多个元素到集合(set)里
SCARD key 						获取集合里面的元素数量
SDIFF key [key ...] 			获得队列不存在的元素
SDIFFSTORE destination key [key ...] 获得队列不存在的元素,并存储在一个关键的结果集
SINTER key [key ...] 			获得两个集合的交集
SINTERSTORE destination key [key ...] 获得两个集合的交集,并存储在一个集合中
SISMEMBER key member 			确定一个给定的值是一个集合的成员
SMEMBERS key 					获取集合里面的所有key
SMOVE source destination member 移动集合里面的一个key到另一个集合
SPOP key [count] 				获取并删除一个集合里面的元素
SRANDMEMBER key [count] 		从集合里面随机获取一个元素
SREM key member [member ...] 	从集合里删除一个或多个元素,不存在的元素会被忽略
SUNION key [key ...] 			添加多个set元素
SUNIONSTORE destination key [key ...] 合并set元素,并将结果存入新的set里面
SSCAN key cursor [MATCH pattern] [COUNT count] 迭代set里面的元素

Sorted Set有序集合

 
ZADD key score1 member1 [score2 member2] 
							添加一个或多个成员到有序集合,或者如果它已经存在更新其分数
ZCARD key 					得到的有序集合成员的数量
ZCOUNT key min max 			计算一个有序集合成员与给定值范围内的分数
ZINCRBY key increment member 在有序集合增加成员的分数
ZINTERSTORE destination numkeys key [key ...] 
							多重交叉排序集合,并存储生成一个新的键有序集合。
ZLEXCOUNT key min max 		计算一个给定的字典范围之间的有序集合成员的数量
ZRANGE key start stop [WITHSCORES] 由索引返回一个成员范围的有序集合(从低到高)
ZRANGEBYLEX key min max [LIMIT offset count]返回一个成员范围的有序集合(由字典范围)
ZRANGEBYSCORE key min max [WITHSCORES] [LIMIT] 
							返回有序集key中,所有 score 值介于 min 和 max 之间(包括等于 min 或 max )的成员,有序集成员按 score 值递增(从小到大)次序排列
ZRANK key member 			确定成员的索引中有序集合
ZREM key member [member ...] 从有序集合中删除一个或多个成员,不存在的成员将被忽略
ZREMRANGEBYLEX key min max 	删除所有成员在给定的字典范围之间的有序集合
ZREMRANGEBYRANK key start stop 在给定的索引之内删除所有成员的有序集合
ZREMRANGEBYSCORE key min max 在给定的分数之内删除所有成员的有序集合
ZREVRANGE key start stop [WITHSCORES] 
							返回一个成员范围的有序集合,通过索引,以分数排序,从高分到低分
ZREVRANGEBYSCORE key max min [WITHSCORES] 
							返回一个成员范围的有序集合,以socre排序从高到低
ZREVRANK key member 		确定一个有序集合成员的索引,以分数排序,从高分到低分
ZSCORE key member 			获取给定成员相关联的分数在一个有序集合
ZUNIONSTORE destination numkeys key [key ...] 
							添加多个集排序,所得排序集合存储在一个新的键
ZSCAN key cursor [MATCH pattern] [COUNT count] 增量迭代排序元素集和相关的分数
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值