概述
大家知道,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用做库存管理模块等。
最后
以上就是感性大地为你收集整理的redis操作多数据库以及持久化的全部内容,希望文章能够帮你解决redis操作多数据库以及持久化所遇到的程序开发问题。
如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。
发表评论 取消回复