美文网首页
02-redis单机数据库

02-redis单机数据库

作者: 有何不可12317 | 来源:发表于2018-08-19 21:17 被阅读0次

数据库

服务器中的数据库

redis服务器将所有的数据库都保存在服务器状态reids.h/redisServer结构的db数组中

struct redisServer {
    ...
    redisDb *db;    // 一个数组, 保存着服务器中所有的数据库
    ...
};

在初始化服务器时,会根据dbnum属性来决定应该创建多少个数据库:

struct redisServer {
    ...
    int dbnum;  // 服务器的数据库数量
    ...
};

切换数据库

redis客户端的目标数据库默认为0号数据库

在服务器内部,客户端状态redisClient结构的db属性记录了客户端当前的目标数据库

typedef struct redisClient {
    ...
    redisDb *db;    // 记录客户端当前正在使用的数据库
    ...
} redisClient;

通过SELECT命令实现客户端切换不同数据库

数据库键空间

redis是一个键值对(key-value pair)数据库服务器,服务器中每个数据库都由一个redis.h/redisDb结构表示

其中redisDb结构的dict字典保存了数据库中所有的键值对,将这个字典成为键空间

typedef struct redisDb {
    ...
    dict *dict; // 数据库键空间,保存着数据库中所有的键值对
    ...
} reidsDb;
  • 键空间的键也就是数据库的键,每个键都是一个字符串对象
  • 见空间的值也就是数据库的值,每个值可以是字符串对象,列表对象、哈希对象、集合对象、有序集合对象

添加键值、删除键、更新键、对键取值、以及其他键空间操作

设置键的生存时间或过期时间

EXPIPE      指定秒设置生存时间
PEXPIPE     指定毫秒设置生存时间

EXPIPEAT    指定秒设置过期时间
PEXPIPEAT   指定毫秒设置过期时间

PERSIST     移除键的生存时间
PERSISTAT   移除键的过期时间

TTL         以秒为单位计算并返回键的剩余生存时间
PTTL        以毫秒为单位计算并返回键的剩余生存时间

那么redis怎么保存过期时间的呢

typedef struct redisDb {
    ...
    dict *expires;  // 过期字典,保存着键的过期时间
    ...
} redisDb;

既然键值有生存时间或过期时间,那么过期的键怎么删除呢?或者说过期键的删除策是什么?

  • 定时删除
  • 惰性删除
  • 定期删除

redis过期键删除策略

惰性删除与定期删除相结合

AOF、RDB和复制功能对过期键的处理

RDB文件

执行SAVE或BGSAVE命令创建一个新的RDB文件,不会将过期键保存到新的RDB文件中

  • 如果服务器是主服务器模式运行,在载入RDB文件时,过期键会被忽略,过期键不会造成影响
  • 如果服务器是从服务器模式运行,在载入RDB文件时,保存所有键,但是主从服务器数据同步时,从服务器数据库会被清空,过期键也不会造成影响

AOF文件

某个键过期,但还没有被删除时,以AOF模式运行时不会产生影响,

如果过期键被删除,程序会向AOF文件追加一条DEL命令来显示的记录该键已被删除

在执行AOF重写过程中,过期键不会被保存

复制

存在于主从服务器中,从服务器不会主动删除过期键,客户端读过期键正常返回

只有当主服务器给从服务器发送DEL key时才会删除过期键

当客户端读主服务器过期键,主服务器返回null给客户端,同时给从服务器发送DEL key命令

数据库通知

redis 2.8 版本新增功能

日后在研究吧

参考
黄键宏老师的《redis设计与实现》,机械工业出版社

相关文章

  • 02-redis单机数据库

    数据库 服务器中的数据库 redis服务器将所有的数据库都保存在服务器状态reids.h/redisServer结...

  • Mysql集群PXC (入门)

    为什么需要MySQL集群 传统数据库单机单节点,容灾性能差,例如数据库挂掉,整个网站就会挂掉。单机单节点的数据库性...

  • 015 为什么要分表分库

    为什么要分表分库 分表分库一般会在以下情况下出现: 一、数据库本身的性能瓶颈 单机数据库的存储容量限制 单机数据库...

  • 分布式数据访问层

    一、 数据库从单击到分布式会面临的问题 思考方向: 单机的CRUD扩展到多机后面临的问题、原来依赖的单机数据库特性...

  • 单机数据库

    一:服务器中的数据库1.1: 数据结构redisserver: redisdb 1.2 图示 1.3 特性redi...

  • 2018-10-24 数据库学习

    数据库学习 一.数据库介绍 数据库和excel的区别数据库在线程序excel单机程序 常见的数据库 二.数据库客户...

  • 收缩数据库和日志文件大小

    --先设置数据库为单机模式(数据库名字右键属性---选项---恢复模式选择简单--确定) DBCC SHRINKD...

  • PDO MySQL

    PDO MySQL 如果文章有成千上万篇,该怎样保存? 数据保存有多种方式,比如单机文件、单机数据库(SQLite...

  • ES系列 - 2. 分布式特性

    一、分布式与集群 什么是集群? 与集群相对的是单机。以传统数据库为例,单机就是搭建一个数据库服务器。当服务器访问量...

  • 2018-10-24数据库学习操作

    数据库和excel的区别数据库在线程序excel单机程序 常见的数据库 二.数据库客户端的使用 excel 常见操...

网友评论

      本文标题:02-redis单机数据库

      本文链接:https://www.haomeiwen.com/subject/psdhiftx.html