我是靠谱客的博主 感性大地,最近开发中收集的这篇文章主要介绍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用做库存管理模块等。

最后

以上就是感性大地为你收集整理的redis操作多数据库以及持久化的全部内容,希望文章能够帮你解决redis操作多数据库以及持久化所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(44)

评论列表共有 0 条评论

立即
投稿
返回
顶部