安装
在 centos 上使用 yum 安装
| 1 | 安装源 | 
单点启动
| 1 | sudo systemctl start redis | 
可通过查看 redis 日志来查看启动过程或者运行过程中的各种问题
日志开启需要在redis.conf配置
| 1 | logfile /var/log/redis/redis.log | 
配置
在 redis 客户端可以使用config set设定临时配置,该配置仅临时有效,可通过config rewrite将临时配置写入到redis.conf中使其永久有效
- maxmemory 设定最大内存使用 - 1 
 2- # 设置为5m 
 maxmemory 5m
- maxmemory_policy 过期策略 
使用
redis 的备份文件 dump.db 在启动 redis-server 的目录下直接生成
使用shell执行redis命令
| 1 | 
 | 
- 查询所有 - key,以及过期时间,省略- ip,端口,密码- 1 - echo keys '*' |redis-cli |awk '{print "echo -n "$1 " && echo ttl " $1 " |redis-cli"}'|sh 
- 查看占用内存较多的 key - 1 
 2
 3
 4
 5
 6
 7
 8
 9
 10
 11
 12
 13
 14
 15
 16
 17
 18
 19
 20
 21- ~$ redis-cli --bigkeys 
 Scanning the entire keyspace to find biggest keys as well as
 average sizes per key type. You can use -i 0.1 to sleep 0.1 sec
 per 100 SCAN commands (not usually needed).
 [00.00%] Biggest string found so far 'hello3' with 3 bytes
 -------- summary -------
 Sampled 3 keys in the keyspace!
 Total key length in bytes is 17 (avg len 5.67)
 Biggest string found 'hello3' has 3 bytes
 0 lists with 0 items (00.00% of keys, avg size 0.00)
 0 hashs with 0 fields (00.00% of keys, avg size 0.00)
 3 strings with 6 bytes (100.00% of keys, avg size 2.00)
 0 streams with 0 entries (00.00% of keys, avg size 0.00)
 0 sets with 0 members (00.00% of keys, avg size 0.00)
 0 zsets with 0 members (00.00% of keys, avg size 0.00)
- 查看运行时相关信息 - 1 
 2
 3
 4
 5
 6
 7
 8
 9
 10
 11
 12
 13
 14
 15
 16
 17
 18
 19
 20
 21
 22
 23
 24
 25
 26
 27
 28
 29
 30
 31
 32
 33
 34
 35
 36
 37
 38
 39
 40
 41
 42
 43
 44
 45
 46
 47
 48
 49
 50
 51
 52
 53
 54
 55
 56
 57
 58
 59
 60
 61
 62
 63
 64
 65
 66
 67
 68
 69
 70
 71
 72
 73
 74
 75
 76
 77
 78
 79
 80
 81
 82
 83
 84
 85
 86
 87
 88
 89
 90
 91
 92
 93
 94
 95
 96
 97
 98
 99
 100
 101
 102
 103
 104
 105
 106
 107
 108
 109
 110
 111
 112
 113
 114
 115
 116
 117
 118
 119
 120
 121
 122
 123
 124
 125
 126
 127
 128
 129
 130
 131
 132
 133
 134
 135
 136
 137
 138
 139
 140
 141
 142
 143
 144
 145
 146
 147
 148
 149
 150
 151
 152- 127.0.0.1:6379> info 
 Server
 redis_version:6.0.3
 redis_git_sha1:00000000
 redis_git_dirty:0
 redis_build_id:eb1391459d1a8dbb
 redis_mode:standalone
 os:Linux 3.10.0-1062.el7.x86_64 x86_64
 arch_bits:64
 multiplexing_api:epoll
 atomicvar_api:atomic-builtin
 gcc_version:8.3.1
 process_id:6077
 run_id:963b3a75b32efa8801d755a1d8ef0129a009ffc8
 tcp_port:6379
 uptime_in_seconds:307
 uptime_in_days:0
 hz:10
 configured_hz:10
 lru_clock:6921052
 executable:/root/redis-server
 config_file:/etc/redis.conf
 Clients
 connected_clients:1
 client_recent_max_input_buffer:2
 client_recent_max_output_buffer:0
 blocked_clients:0
 tracking_clients:0
 clients_in_timeout_table:0
 Memory
 used_memory:867312
 used_memory_human:846.98K
 used_memory_rss:3375104
 used_memory_rss_human:3.22M
 used_memory_peak:867312
 used_memory_peak_human:846.98K
 used_memory_peak_perc:100.18%
 used_memory_overhead:820850
 used_memory_startup:803712
 used_memory_dataset:46462
 used_memory_dataset_perc:73.05%
 allocator_allocated:1019552
 allocator_active:1335296
 allocator_resident:3698688
 total_system_memory:1922482176
 total_system_memory_human:1.79G
 used_memory_lua:37888
 used_memory_lua_human:37.00K
 used_memory_scripts:0
 used_memory_scripts_human:0B
 number_of_cached_scripts:0
 maxmemory:0
 maxmemory_human:0B
 maxmemory_policy:noeviction
 allocator_frag_ratio:1.31
 allocator_frag_bytes:315744
 allocator_rss_ratio:2.77
 allocator_rss_bytes:2363392
 rss_overhead_ratio:0.91
 rss_overhead_bytes:-323584
 mem_fragmentation_ratio:4.09
 mem_fragmentation_bytes:2550304
 mem_not_counted_for_evict:0
 mem_replication_backlog:0
 mem_clients_slaves:0
 mem_clients_normal:16986
 mem_aof_buffer:0
 mem_allocator:jemalloc-5.1.0
 active_defrag_running:0
 lazyfree_pending_objects:0
 Persistence
 loading:0
 rdb_changes_since_last_save:3
 rdb_bgsave_in_progress:0
 rdb_last_save_time:1600756265
 rdb_last_bgsave_status:ok
 rdb_last_bgsave_time_sec:-1
 rdb_current_bgsave_time_sec:-1
 rdb_last_cow_size:0
 aof_enabled:0
 aof_rewrite_in_progress:0
 aof_rewrite_scheduled:0
 aof_last_rewrite_time_sec:-1
 aof_current_rewrite_time_sec:-1
 aof_last_bgrewrite_status:ok
 aof_last_write_status:ok
 aof_last_cow_size:0
 module_fork_in_progress:0
 module_fork_last_cow_size:0
 Stats
 total_connections_received:4
 total_commands_processed:22
 instantaneous_ops_per_sec:0
 total_net_input_bytes:633
 total_net_output_bytes:18936
 instantaneous_input_kbps:0.00
 instantaneous_output_kbps:0.00
 rejected_connections:0
 sync_full:0
 sync_partial_ok:0
 sync_partial_err:0
 expired_keys:0
 expired_stale_perc:0.00
 expired_time_cap_reached_count:0
 expire_cycle_cpu_milliseconds:5
 evicted_keys:0
 keyspace_hits:12
 keyspace_misses:0
 pubsub_channels:0
 pubsub_patterns:0
 latest_fork_usec:0
 migrate_cached_sockets:0
 slave_expires_tracked_keys:0
 active_defrag_hits:0
 active_defrag_misses:0
 active_defrag_key_hits:0
 active_defrag_key_misses:0
 tracking_total_keys:0
 tracking_total_items:0
 tracking_total_prefixes:0
 unexpected_error_replies:0
 Replication
 role:master
 connected_slaves:0
 master_replid:4b6a97cd5859089f722814036486d8d06bbf8432
 master_replid2:0000000000000000000000000000000000000000
 master_repl_offset:0
 master_repl_meaningful_offset:0
 second_repl_offset:-1
 repl_backlog_active:0
 repl_backlog_size:1048576
 repl_backlog_first_byte_offset:0
 repl_backlog_histlen:0
 CPU
 used_cpu_sys:0.233602
 used_cpu_user:0.263460
 used_cpu_sys_children:0.000000
 used_cpu_user_children:0.000000
 Modules
 Cluster
 cluster_enabled:0
 Keyspace
 db0:keys=3,expires=0,avg_ttl=0
布隆过滤器
本质上布隆过滤器是一种数据结构,比较巧妙的概率型数据结构(probabilistic data structure),特点是高效地插入和查询,可以用来告诉你 “某样东西一定不存在或者可能存在”。
相比于传统的 List、Set、Map 等数据结构,它更高效、占用空间更少,但是缺点是其返回的结果是概率性的,而不是确切的。
布隆过滤器是一个 bit 向量或者说 bit 数组,长这样:  如果我们要映射一个值到布隆过滤器中,我们需要使用多个不同的哈希函数生成多个哈希值,并对每个生成的哈希值指向的 bit 位置 1,比如针对值
 如果我们要映射一个值到布隆过滤器中,我们需要使用多个不同的哈希函数生成多个哈希值,并对每个生成的哈希值指向的 bit 位置 1,比如针对值geeks进行三个 hash 函数分布生成 hash 值 1,4,7,则上图变成如下  而当我们需要查询
 而当我们需要查询 geeks 这个值是否存在的话,那么哈希函数必然会返回 1、4、7,然后我们检查发现这三个 bit 位上的值均为 1,那么我们可以说 geeks 存在了么?答案是不可以,只能是 geeks 这个值可能存在。 传统的布隆过滤器并不支持删除操作。
如何选择哈希函数个数和布隆过滤器长度
很显然,过小的布隆过滤器很快所有的 bit 位均为 1,那么查询任何值都会返回“可能存在”,起不到过滤的目的了。布隆过滤器的长度会直接影响误报率,布隆过滤器越长其误报率越小。
另外,哈希函数的个数也需要权衡,个数越多则布隆过滤器 bit 位置位 1 的速度越快,且布隆过滤器的效率越低;但是如果太少的话,那我们的误报率会变高。
Redis 因其支持 setbit 和 getbit 操作,且纯内存性能高等特点,因此天然就可以作为布隆过滤器来使用。但是布隆过滤器的不当使用极易产生大 Value,增加 Redis 阻塞风险,因此生成环境中建议对体积庞大的布隆过滤器进行拆分。
拆分的形式方法多种多样,但是本质是不要将 Hash(Key) 之后的请求分散在多个节点的多个小 bitmap 上,而是应该拆分成多个小 bitmap 之后,对一个 Key 的所有哈希函数都落在这一个小 bitmap 上。
相关操作
查看所有没有过期时间的 key
| 1 | echo keys '*' |redis-cli |awk '{print "echo -n "$1"_"" && echo ttl " $1 " |redis-cli"}'|sh|grep '\-1$'|sed 's/_-1//' > 2.txt | 
问题集锦
访问redis集群
访问集群报错
Connection refused: /127.0.0.1:7000
需要对 redis 集群配置对外访问的 ip 地址,更改每个节点下的redis.conf配置,修改或增加配置
| 1 | bind xxx.xxx.xxx.xxx | 
del的相关问题
在使用redis-cli连接redis集群,进行数据操作时,有报错
(error) MOVED 5798 192.24.54.2:6379
这种情况一般是因为启动redis-cli时没有设置集群模式所导致。启动时使用-c参数来启动集群模式,命令如下:
| 1 | redis-cli -c | 
del 删除 key 时内存不会 redis 占用的内存不会回收,而是由 redis 持续占用,在 redis 做其他操作时会去使用这部分内存
启动时没有启动成功
(error) CLUSTERDOWN Hash slot not served
需要重新分配 hash槽
重启时
Node 127.0.0.1:7000 is not empty. Either the node already knows other nodes (check with CLUSTER NODES) or contains some key in database 0.
因为hash槽已经分配过了,无需重新分配。若要重新分配,将每个节点对应的node.conf删除掉再重新执行即可。