Redis学习笔记 - 01:入门

概述

REmote DIctionary Server(Redis) 是一个由Salvatore Sanfilippo写的key-value存储系统。

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

它通常被称为数据结构服务器,因为值(value)可以是 字符串(String), 哈希(Map), 列表(list), 集合(sets) 和 有序集合(sorted sets)等类型。

Redis 与其他 key - value 缓存产品有以下三个特点:

  1. Redis 支持数据的持久化,可以将内存中的数据保存在磁盘中,重启的时候可以再次加载进行使用。
  2. Redis 不仅仅支持简单的 key-value 类型的数据,同时还提供 list,set,zset,hash 等数据结构的存储。
  3. Redis 支持数据的备份,即 master-slave 模式的数据备份。

安装

下载,提取和编译Redis:

wget http://download.redis.io/releases/redis-5.0.3.tar.gz
tar xzf redis-5.0.3.tar.gz
cd redis-5.0.3
make
#现在编译的二进制文件在src目录中可用

配置

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

参数说明

redis.conf 配置项说明如下:

  • Redis 默认不是以守护进程的方式运行,可以通过该配置项修改,使用yes启用守护进程
  •     daemonize no
  • 当 Redis 以守护进程方式运行时,Redis 默认会把 pid 写入 /var/run/redis.pid 文件,可以通过 pidfile 指定
  •     pidfile /var/run/redis.pid
  • 指定 Redis 监听端口,默认端口为 6379,作者在自己的一篇博文中解释了为什么选用6379作为默认端口,因为6379在手机按键上 MERZ 对应的号码,而 MERZ 取自意大利歌女 Alessia Merz 的名字
  •     port 6379
  • 绑定的主机地址
  •     bind 127.0.0.1
  • 当客户端闲置多长时间后关闭连接,如果指定为0,表示关闭该功能
  •     timeout 300
  • 指定日志记录级别,Redis总共支持四个级别:debug、verbose、notice、warning,默认为verbose
  •     loglevel verbose
  • 日志记录方式,默认为标准输出,如果配置 Redis 为守护进程方式运行,而这里又配置为日志记录方式为标准输出,则日志将会发送给 /dev/null
  •     logfile stdout
  • 设置数据库的数量,默认数据库为0,可以使用 SELECT <dbid>命令在连接上指定数据库id
  •     databases 16
  • 指定在多长时间内,有多少次更新操作,就将数据同步到数据文件,可以多个条件配合
  •     save <seconds> <changes>
  •     Redis 默认配置文件中提供了三个条件:
  •     save 900 1
  •     save 300 10
  •     save 60 10000
  •     分别表示900秒(15分钟)内有1个更改,300秒(5分钟)内有10个更改以及60秒内有10000个更改。
  • 指定存储至本地数据库时是否压缩数据,默认为yes,Redis采用LZF压缩,如果为了节省CPU时间,可以关闭该选项,但会导致数据库文件变的巨大
  •     rdbcompression yes
  • 指定本地数据库文件名,默认值为dump.rdb
  •     dbfilename dump.rdb
  • 指定本地数据库存放目录
  •     dir ./
  • 设置当本机为slav服务时,设置master服务的IP地址及端口,在Redis启动时,它会自动从master进行数据同步
  •     slaveof <masterip> <masterport>
  • 当master服务设置了密码保护时,slav服务连接master的密码
  •     masterauth <master-password>
  • 设置Redis连接密码,如果配置了连接密码,客户端在连接Redis时需要通过AUTH <password>命令提供密码,默认关闭
  •     requirepass foobared
  • 设置同一时间最大客户端连接数,默认无限制,Redis可以同时打开的客户端连接数为Redis进程可以打开的最大文件描述符数,如果设置 maxclients 0,表示不作限制。当客户端连接数到达限制时,Redis会关闭新的连接并向客户端返回max number of clients reached错误信息
  •     maxclients 128
  • 指定 Redis 最大内存限制,Redis 在启动时会把数据加载到内存中,达到最大内存后,Redis 会先尝试清除已到期或即将到期的 Key,当此方法处理 后,仍然到达最大内存设置,将无法再进行写入操作,但仍然可以进行读取操作。Redis 新的vm(virtual memory)机制,会把 Key 存放内存,Value 会存放在 swap 区
  •     maxmemory <bytes>
  • 指定是否在每次更新操作后进行日志记录,Redis在默认情况下是异步的把数据写入磁盘,如果不开启,可能会在断电时导致一段时间内的数据丢失。因为 Redis本身同步数据文件是按上面 save 条件来同步的,所以有的数据会在一段时间内只存在于内存中。默认为 no
  •     appendonly no
  • 指定更新日志文件名,默认为 appendonly.aof
  •      appendfilename appendonly.aof
  • 指定更新日志条件,共有3个可选值:
  1. no:表示等操作系统进行数据缓存同步到磁盘(快) 
  2. always:表示每次更新操作后手动调用 fsync() 将数据写到磁盘(慢,安全)
  3. everysec:表示每秒同步一次(折衷,默认值)
  •     appendfsync everysec
  • 指定是否启用虚拟内存机制,默认值为 no,简单的介绍一下,VM 机制将数据分页存放,由 Redis 将访问量较少的页即冷数据 swap 到磁盘上,访问多的页面由磁盘自动换出到内存中(在后面的文章我会仔细分析 Redis 的 VM 机制)
  •      vm-enabled no
  • 虚拟内存文件路径,默认值为 /tmp/redis.swap,不可多个 Redis 实例共享
  •      vm-swap-file /tmp/redis.swap
  • 将所有大于 vm-max-memory 的数据存入虚拟内存,无论 vm-max-memory 设置多小,所有索引数据都是内存存储的(Redis的索引数据 就是 keys),也就是说,当 vm-max-memory 设置为0的时候,其实是所有 value 都存在于磁盘。默认值为0
  •      vm-max-memory 0
  • Redis swap 文件分成了很多的 page,一个对象可以保存在多个 page上面,但一个 page 上不能被多个对象共享,vm-page-size 是要根据存储的数据大小来设定的,作者建议如果存储很多小对象,page 大小最好设置为32或者64bytes;如果存储很大大对象,则可以使用更大的page,如果不确定,就使用默认值
  •      vm-page-size 32
  • 设置 swap 文件中的 page 数量,由于页表(一种表示页面空闲或使用的bitmap)是在放在内存中的,在磁盘上每8个 pages 将消耗1byte的内存。
  •      vm-pages 134217728
  • 设置访问 swap 文件的线程数,最好不要超过机器的核数,如果设置为0,那么所有对 swap 文件的操作都是串行的,可能会造成比较长时间的延迟。默认值为4
  •      vm-max-threads 4
  • 设置在向客户端应答时,是否把较小的包合并为一个包发送,默认为开启
  •     glueoutputbuf yes
  • 指定在超过一定的数量或者最大的元素超过某一临界值时,采用一种特殊的哈希算法
  •     hash-max-zipmap-entries 64
  •     hash-max-zipmap-value 512
  • 指定是否激活重置哈希,默认为开启(后面在介绍 Redis 的哈希算法时具体介绍)
  •     activerehashing yes
  • 指定包含其它的配置文件,可以在同一主机上多个 Redis 实例之间使用同一份配置文件,而同时各个实例又拥有自己的特定配置文件
  •     include /path/to/local.conf

也可以通过 CONFIG 命令查看或设置配置项。

语法

redis 127.0.0.1:6379> CONFIG GET CONFIG_SETTING_NAME

实例1

redis 127.0.0.1:6379> CONFIG GET loglevel
 
1) "loglevel"
2) "notice"

实例2

#支持通配符 *
redis 127.0.0.1:6379> CONFIG GET *
 
  1) "dbfilename"
  2) "dump.rdb"
  3) "requirepass"
  4) ""
  5) "masterauth"
  6) ""
  7) "unixsocket"
  8) ""
  9) "logfile"
 10) ""
 11) "pidfile"
 12) "/var/run/redis.pid"
 13) "maxmemory"
 14) "0"
 15) "maxmemory-samples"
 16) "3"
 17) "timeout"
 18) "0"
 19) "tcp-keepalive"
 20) "0"
 21) "auto-aof-rewrite-percentage"
 22) "100"
 23) "auto-aof-rewrite-min-size"
 24) "67108864"
 25) "hash-max-ziplist-entries"
 26) "512"
 27) "hash-max-ziplist-value"
 28) "64"
 29) "list-max-ziplist-entries"
 30) "512"
 31) "list-max-ziplist-value"
 32) "64"
 33) "set-max-intset-entries"
 34) "512"
 35) "zset-max-ziplist-entries"
 36) "128"
 37) "zset-max-ziplist-value"
 38) "64"
 39) "hll-sparse-max-bytes"
 40) "3000"
 41) "lua-time-limit"
 42) "5000"
 43) "slowlog-log-slower-than"
 44) "10000"
 45) "latency-monitor-threshold"
 46) "0"
 47) "slowlog-max-len"
 48) "128"
 49) "port"
 50) "6379"
 51) "tcp-backlog"
 52) "511"
 53) "databases"
 54) "16"
 55) "repl-ping-slave-period"
 56) "10"
 57) "repl-timeout"
 58) "60"
 59) "repl-backlog-size"
 60) "1048576"
 61) "repl-backlog-ttl"
 62) "3600"
 63) "maxclients"
 64) "4064"
 65) "watchdog-period"
 66) "0"
 67) "slave-priority"
 68) "100"
 69) "min-slaves-to-write"
 70) "0"
 71) "min-slaves-max-lag"
 72) "10"
 73) "hz"
 74) "10"
 75) "no-appendfsync-on-rewrite"
 76) "no"
 77) "slave-serve-stale-data"
 78) "yes"
 79) "slave-read-only"
 80) "yes"
 81) "stop-writes-on-bgsave-error"
 82) "yes"
 83) "daemonize"
 84) "no"
 85) "rdbcompression"
 86) "yes"
 87) "rdbchecksum"
 88) "yes"
 89) "activerehashing"
 90) "yes"
 91) "repl-disable-tcp-nodelay"
 92) "no"
 93) "aof-rewrite-incremental-fsync"
 94) "yes"
 95) "appendonly"
 96) "no"
 97) "dir"
 98) "/home/deepak/Downloads/redis-2.8.13/src"
 99) "maxmemory-policy"
100) "volatile-lru"
101) "appendfsync"
102) "everysec"
103) "save"
104) "3600 1 300 100 60 10000"
105) "loglevel"
106) "notice"
107) "client-output-buffer-limit"
108) "normal 0 0 0 slave 268435456 67108864 60 pubsub 33554432 8388608 60"
109) "unixsocketperm"
110) "0"
111) "slaveof"
112) ""
113) "notify-keyspace-events"
114) ""
115) "bind"
116) ""

CONFIG SET 命令基本语法: 

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"

运行

#运行Redis:
src/redis-server

服务默认绑定在 localhost:6379 

Redis 支持五种数据类型:string(字符串),hash(哈希),list(列表),set(集合)及zset(sorted set有序集合)。

String(字符串)
string 是 Redis 最基本的类型,你可以理解成与 Memcached 一模一样的类型,一个 key 对应一个 value。
string 类型是二进制安全的。意思是 Redis 的 string 可以包含任何数据。比如 jpg 图片或者序列化的对象 。
string 类型是 Redis 最基本的数据类型,一个键最大能存储512MB。 

应用场景可以是一对一的的信息记录,如【人名-身份证号】

#实例
redis 127.0.0.1:6379> SET name "redis.net.cn"
OK
redis 127.0.0.1:6379> GET name
"redis.net.cn"


在以上实例中我们使用了 Redis 的 SET 和 GET 命令。键为 name,对应的值为 redis.net.cn。
注意:一个键最大能存储 512MB。
Hash(哈希)
Redis hash 是一个键值对集合。
Redis hash 是一个string类型的 field 和 value 的映射表,hash 特别适合用于存储对象。

应用场景如身份证对应一个人的各种身份信息,如230611-[''name'':'' '',''sex'':'' '',''age'':'' '']

#实例
redis 127.0.0.1:6379> HMSET user:1 username redis.net.cn password redis.net.cn points 200
OK
redis 127.0.0.1:6379> HGETALL user:1
1) "username"
2) "redis.net.cn"
3) "password"
4) "redis.net.cn"
5) "points"
6) "200"
redis 127.0.0.1:6379>


以上实例中 hash 数据类型存储了包含用户脚本信息的用户对象。 实例中我们使用了 Redis HMSET, HEGTALL 命令,user:1 为键值。
每个 hash 可以存储 232 - 1 键值对(40多亿)。
List(列表)
Redis 列表是简单的字符串列表,按照插入顺序排序。你可以添加一个元素导列表的头部(左边)或者尾部(右边)。

#实例
redis 127.0.0.1:6379> lpush redis.net.cn redis
(integer) 1
redis 127.0.0.1:6379> lpush redis.net.cn mongodb
(integer) 2
redis 127.0.0.1:6379> lpush redis.net.cn rabitmq
(integer) 3
redis 127.0.0.1:6379> lrange redis.net.cn 0 10
1) "rabitmq"
2) "mongodb"
3) "redis"
redis 127.0.0.1:6379>

列表最多可存储 232 - 1 元素 (4294967295, 每个列表可存储40多亿)。

应用场景在一对多的场景下,如【账号:订单号1,订单号2,订单号3,订单号4,订单号5】
Set(集合)
Redis 的 Set 是 string 类型的无序集合。
集合是通过哈希表实现的,所以添加,删除,查找的复杂度都是O(1)。
sadd 命令
添加一个 string 元素到 key 对应的 set 集合中,成功返回1,如果元素以及在集合中返回0,key 对应的 set 不存在返回错误。
sadd key member

#实例
redis 127.0.0.1:6379> sadd redis.net.cn redis
(integer) 1
redis 127.0.0.1:6379> sadd redis.net.cn mongodb
(integer) 1
redis 127.0.0.1:6379> sadd redis.net.cn rabitmq
(integer) 1
redis 127.0.0.1:6379> sadd redis.net.cn rabitmq
(integer) 0
redis 127.0.0.1:6379> smembers redis.net.cn
1) "rabitmq"
2) "mongodb"
3) "redis"

应用场景可以是避免重复录入的信息,如员工名单
注意:以上实例中 rabitmq 添加了两次,但根据集合内元素的唯一性,第二次插入的元素将被忽略。
集合中最大的成员数为 2^32 - 1 (4294967295, 每个集合可存储40多亿个成员)。
zset(sorted set:有序集合)
Redis zset 和 set 一样也是 string 类型元素的集合,且不允许重复的成员。
不同的是每个元素都会关联一个 double 类型的分数。Redis 正是通过分数来为集合中的成员进行从小到大的排序。
zset 的成员是唯一的,但分数 (score) 却可以重复。
zadd 命令
添加元素到集合,元素在集合中存在则更新对应 score
zadd key score member 

#实例
redis 127.0.0.1:6379> zadd redis.net.cn 0 redis
(integer) 1
redis 127.0.0.1:6379> zadd redis.net.cn 0 mongodb
(integer) 1
redis 127.0.0.1:6379> zadd redis.net.cn 0 rabitmq
(integer) 1
redis 127.0.0.1:6379> zadd redis.net.cn 0 rabitmq
(integer) 0
redis 127.0.0.1:6379> ZRANGEBYSCORE redis.net.cn 0 1000
1) "redis"
2) "mongodb"
3) "rabitmq"

 应用场景可以是排行榜,特点是有序,不重复

连接

redis-cli -h 实例连接地址 -p 端口 -a 密码

 

监控

sentinel 的四个主要作用是

  • 监控。Sentinel会不断检查主实例和从属实例是否按预期工作。
  • 通知。Sentinel可以通过API通知系统管理员,另一台计算机程序,其中一个受监控的Redis实例出现问题。
  • 自动故障转移。如果主服务器未按预期工作,Sentinel可以启动故障转移过程,其中从服务器被提升为主服务器,其他其他服务器将重新配置为使用新主服务器,并且使用Redis服务器的应用程序会通知有关新服务器的地址。连接。
  • 配置提供商。Sentinel充当客户端服务发现的权限来源:客户端连接到Sentinels,以便询问负责给定服务的当前Redis主服务器的地址。如果发生故障转移,Sentinels将报告新地址。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值