Redis是什么


一、Redis是什么

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

二、Redis特性

  • 速度快
  • 键值对的数据结构服务器
  • 丰富的功能
  • 简单稳定
  • 持久化
  • 主从复制
  • 高可用和分布式转移
  • 客户端语言多

三、Redis常见的使用场景

  • 缓存数据库
  • 排行榜
  • 计数器
  • 社交网络
  • 消息队列

四、可执行文件

可执行文件作用
redis-server启动Redis
redis-cliRedis命令行客户端
redis-benchmark基准测试工具
redis-check-aofAOF持久化文件检测和修复工具
redis-check-dumpRDB持久化文件检测和修复工具
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多路复用,将连接信息和事件放到队列中,依次放到文件事件分派器,事件分派器将事件分发给事件处理器
在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值