redis多数据库使用防止key冲突

  • redis
  • 7月 3, 2014
  • 0 评论

【摘要】实际应用中会有多个项目都要使用redis,如果每一个app都要起一个单独的实例那会比较浪费,如果使用一个实例则必须要避免多个项目之间的key冲突问题。

其实redis2.x以上默认支持了16个数据,0-15,每个数据库相互之间是隔离的,这个比较类似关系型数据,如:mysql的多个数据库之间是互不影响。

redis.conf中相关配置:
databases 16

测试版本
redis_version:2.4.10:

连接redis
# redis-cli -p 6380
默认是db0,也可以使用select 0明确指出

redis 127.0.0.1:6380> select 0
OK
redis 127.0.0.1:6380>  set key1 "value1"
OK
redis 127.0.0.1:6380> set key2 "value2"
OK
redis 127.0.0.1:6380>

继续,在db1上进行操作

redis 127.0.0.1:6380[1]> set key1 "db1 value1"
OK
redis 127.0.0.1:6380[1]> set key2 "db1 value2"
OK
redis 127.0.0.1:6380[1]> 

验证:

redis 127.0.0.1:6380[1]> select 0
OK
redis 127.0.0.1:6380> keys *
1) "key2"
2) "key1"

redis 127.0.0.1:6380> select 1
OK
redis 127.0.0.1:6380[1]> keys *
1) "key2"
2) "key1"


redis 127.0.0.1:6380[1]> info
db0:keys=2,expires=0
db1:keys=2,expires=0

很明显能够看出来,redis不同数据库(keyspace 在redis-2.6以后的版本)中,key之间是互不影响的,当然,如果要在同一个数据库中也可以,前提是key能够事先定义好,比如按照项目或者app的名称作为前缀,从而避免key冲突的存在。

u2

Related Posts

  • redis
  • 3月 17, 2014
  • 190 views
基于sentinel+redis下HA集群的搭建

[摘要]之前的文章中介绍了redis+keepalived来…

Read more

  • redis
  • 3月 11, 2014
  • 214 views
keepalived+redis实现HA的验证

之前对Redis的使用还是中规中矩的Master+Slave…

Read more

You Missed

OpenAI Codex 发布角色插件:当AI开始理解「分析师」和「销售」是两种不同的物种

  • u2
  • 6月 15, 2026
  • 36 views
OpenAI Codex 发布角色插件:当AI开始理解「分析师」和「销售」是两种不同的物种

TraceClaw:企业级透明可控智能体,全行为审计+零信任执行

  • u2
  • 6月 13, 2026
  • 40 views

一年前让英伟达蒸发6000亿美元的中国AI,现在被黄仁勋请上了CES的PPT

  • u2
  • 6月 7, 2026
  • 81 views

当AI开始”破坏”:Anthropic告诉我们,每个用户都该重新审视自己的使用方式

  • u2
  • 6月 6, 2026
  • 85 views

10款大模型同台黑客测试:GPT-5.5拿了王冠,DeepSeek便宜15倍,Gemini直接退赛

  • u2
  • 6月 5, 2026
  • 72 views

30天,0天,90天:一纸行政令,把AI公司的”自由发布”踩了急刹车

  • u2
  • 6月 4, 2026
  • 93 views