关于Redis的一些事
一、Redis是什么
Redis是一个开源的使用ANSI C语言编写,支持网络,基于内存也可以持久化的日志型,Key-Value数据库,并提供多种语言的API
二、Redis特性
- 速度快
- 键值对的数据结构服务器
- 丰富的功能
- 简单稳定
- 持久化
- 主从复制
- 高可用和分布式转移
- 客户端语言多
三、Redis常见的使用场景
- 缓存数据库
- 排行榜
- 计数器
- 社交网络
- 消息队列
- …
四、可执行文件
可执行文件 | 作用 |
---|---|
redis-server | 启动Redis |
redis-cli | Redis命令行客户端 |
redis-benchmark | 基准测试工具 |
redis-check-aof | AOF持久化文件检测和修复工具 |
redis-check-dump | RDB持久化文件检测和修复工具 |
redis-sentinel | 启动哨兵 |
五、全局命令
1.keys【全量遍历健】
全局遍历健:用来列出所有满足特定正则字符串的key,当redis数据量比较大时,性能较差,会造成阻塞,应该避免使用
2.scan【 渐进式遍历健】
SCAN cursor[MATCH pattern][COUNT count]
参数说明:cursor整数值(hash桶的索引值),第二个是key的正则模式,第三次是一次遍历key的数量
SCAN命令的问题:在scan的过程中如果有健的变化(增删改),那么遍历的效果可能会出现问题,比如新增的健没有遍历到,遍历重复的健等。开发时使用scan需要注意这个问题
3.info 【查看Redis服务运行信息】
分为9块,每个块都有非常多的参数
- Server:服务器运行的环境参数
- Clients:客户端相关信息
- Memory:服务器运行内存统计数据
- Persistence:持久化信息
- Stats:通用统计数据
- Replication:主从复制相关信息
- CPU:CPU使用情况
- Cluster:集群信息
- KeySpace:键值对统计数量信息
192.168.1.110:6379> info
# Server
redis_version:6.0.5
redis_git_sha1:00000000
redis_git_dirty:0
redis_build_id:d305b8d88680923d
redis_mode:standalone
os:Linux 3.10.0-514.el7.x86_64 x86_64
arch_bits:64
multiplexing_api:epoll
atomicvar_api:atomic-builtin
gcc_version:9.3.1
process_id:2148
run_id:0c65770532456b6923796538d45533ec79bb08cf
tcp_port:6379
uptime_in_seconds:13776
uptime_in_days:0
hz:10
configured_hz:10
lru_clock:2477256
executable:/usr/local/redis/./bin/redis-server
config_file:/usr/local/redis/./6379/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:865536
used_memory_human:845.25K
used_memory_rss:8167424
used_memory_rss_human:7.79M
used_memory_peak:865536
used_memory_peak_human:845.25K
used_memory_peak_perc:100.18%
used_memory_overhead:819034
used_memory_startup:801936
used_memory_dataset:46502
used_memory_dataset_perc:73.12%
allocator_allocated:911784
allocator_active:1175552
allocator_resident:3690496
total_system_memory:1023963136
total_system_memory_human:976.53M
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.29
allocator_frag_bytes:263768
allocator_rss_ratio:3.14
allocator_rss_bytes:2514944
rss_overhead_ratio:2.21
rss_overhead_bytes:4476928
mem_fragmentation_ratio:9.92
mem_fragmentation_bytes:7344392
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:1
rdb_bgsave_in_progress:0
rdb_last_save_time:1646643656
rdb_last_bgsave_status:ok
rdb_last_bgsave_time_sec:0
rdb_current_bgsave_time_sec:-1
rdb_last_cow_size:4354048
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:1
total_commands_processed:5
instantaneous_ops_per_sec:0
total_net_input_bytes:139
total_net_output_bytes:18572
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:109
evicted_keys:0
keyspace_hits:0
keyspace_misses:0
pubsub_channels:0
pubsub_patterns:0
latest_fork_usec:49423
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:276533247fdcd69ce4bcc5ae6eb475bb26ce3abb
master_replid2:0000000000000000000000000000000000000000
master_repl_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:8.549004
used_cpu_user:4.765582
used_cpu_sys_children:0.049364
used_cpu_user_children:0.001028
# Modules
# Cluster
cluster_enabled:0
# Keyspace
db0:keys=2,expires=0,avg_ttl=0
192.168.1.110:6379>
六、Redis是单线程吗
Redis的单线程指的是Redis的网络IO和键值对读写是由一个线程来完成的,这也是Redis对外提供键值对服务的主要流程。但是Redis其他功能,比如持久化,异步删除,集群数据同步等是由额外的线程来完成的
七、Redis单线程快的原因
所有的数据都在内存中,所有的计算都是内存级别的计算,而且单线程避免了多线程的切换造成的性能损耗问题
八、Redis单线程如何处理多的并发客户端连接
Redis的IO多路复用,Redis利用epoll来实现io多路复用,将连接信息和事件放到队列中,依次放到文件事件分派器,事件分派器将事件分发给事件处理器