redis操作多数据库以及持久化

    大家知道,redis中默认是16个数据库,数据库的下标是从0开始的,不做什么设置的话,我们操作的默认数据库是数据库0,怎样切换数据库呢,使用select 数据库索引来切换,切换完后,命令行中会标识当前在操作那个数据库,类似127.0.0.1:6379[15]> ,这里的15就是数据库15的意思,默认的数据库命令行呢,127.0.0.1:6379> 端口号旁边什么也没有。

127.0.0.1:6379> keys *
 1) "s1"
 2) "z4"
 3) "z2"
 4) "ip2"
 5) "ip"
 6) "ip1"
 7) "z1"
 8) "s3"
 9) "z5"
10) "z3"
11) "s2"
127.0.0.1:6379> select 15
OK
127.0.0.1:6379[15]> keys *
(empty array)
127.0.0.1:6379[15]> set s1 aaa
OK
127.0.0.1:6379[15]> keys *
1) "s1"

 

    那么我们怎样操作数据库之间数据的移动呢,使用move的命令。

127.0.0.1:6379> keys *
 1) "s1"
 2) "z4"
 3) "z2"
 4) "ip2"
 5) "ip"
 6) "ip1"
 7) "z1"
 8) "s3"
 9) "z5"
10) "z3"
11) "s2"
127.0.0.1:6379> move ip 15
(integer) 1
127.0.0.1:6379> keys *
 1) "s1"
 2) "z4"
 3) "z2"
 4) "ip2"
 5) "ip1"
 6) "z1"
 7) "s3"
 8) "z5"
 9) "z3"
10) "s2"
127.0.0.1:6379> select 15
OK
127.0.0.1:6379[15]> keys *
1) "s1"
2) "ip"

    这里就完成了,将数据库0的ip数据移动到数据库15中。

 

    接下来,我们,怎样清空数据库中数据呢,使用flushdb和flushall,它们两个有什么区别呢。

  • flushdb

    大家知道redis有16个数据库,flushdb呢,删除当前数据库的数据

127.0.0.1:6379> keys *
 1) "s1"
 2) "z4"
 3) "z2"
 4) "ip2"
 5) "ip1"
 6) "z1"
 7) "s3"
 8) "z5"
 9) "z3"
10) "s2"
127.0.0.1:6379> select 15
OK
127.0.0.1:6379[15]> keys *
1) "s1"
2) "ip"
127.0.0.1:6379[15]>
127.0.0.1:6379[15]> flushdb
OK
127.0.0.1:6379[15]> keys *
(empty array)
127.0.0.1:6379[15]>
127.0.0.1:6379[15]> select 0
OK
127.0.0.1:6379> keys *
 1) "s1"
 2) "z4"
 3) "z2"
 4) "ip2"
 5) "ip1"
 6) "z1"
 7) "s3"
 8) "z5"
 9) "z3"
10) "s2"

 

  • flushall

    flushall是删除数据库0到数据库15的所有数据

127.0.0.1:6379> keys *
1) "ip1"
2) "z1"
3) "s3"
4) "z5"
5) "z3"
6) "s2"
127.0.0.1:6379> select 15
OK
127.0.0.1:6379[15]>
127.0.0.1:6379[15]> keys *
1) "z4"
2) "s1"
3) "ip2"
4) "z2"
127.0.0.1:6379[15]>
127.0.0.1:6379[15]> flushall
OK
127.0.0.1:6379[15]>
127.0.0.1:6379[15]> keys *
(empty array)
127.0.0.1:6379[15]> select 0
OK
127.0.0.1:6379> keys *
(empty array)

 

    大家都知道redis是基于内存的数据库,读取速度是非常快的,但是有一个问题,当服务器关机的时候,内存会被释放,数据就会丢失,我们就需要定期的将数据同步到服务器硬盘中,也称为数据持久化,redis持久化有两种方式,RDB和AOF,其中RDB是默认的方式。

 

RDB

    是redis database的缩写,redis在硬盘中也有自己的保存数据的二进制文件,它的默认名是dump.rdb,也可称为快照,快照它保存数据快,还原数据也快,由于快照是定期执行的,如果服务器不是正常关机的话,最后一次的数据没有快照上,会丢失,它有两个核心函数,rdbsave和rdbload。

 

AOF

    是append only file的缩写,它是只有发生set命令的话,通过write函数,就会向硬盘中appendonly.aof文件的末尾添加数据,当redis重启后,会通过read方法,将appendonly.aof文件中的数据,写回内存中,服务器宕机时,不会丢失数据,但是会产生一个问题,由于是向appendonly.aof末尾添加数据,当发生变量自增,自减的操作时,都会产生记录,会产生冗余的数据。

 

    redis有16个数据库,有的公司,在使用时,按照模块来划分用哪个数据库,例如,数据库1用于user模块,数据库2用于订单模块,数据库3用做库存管理模块等。

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值