Redis学习(一)—–初识redis

数据库 waitig 415℃ 百度已收录 0评论

简介

Redis是一种非结构化的数据库,将数据采用键值对的形式存储在内存中,由于存储在内存中,所以运行很快。

为什么快?

  1. 所有的数据都是放在内存中进行管理的,当然比存储在外存的结构化数据库快
  2. 是用C语言实现的,更接近操作系统,运行更快
  3. 采用单线程架构,避免了多线程产生的资源竞争问题
  4. 源代码特别精简

Redis单线程架构

Redis使用了单线程架构和I/O多路复用模型来实现高性能的内存数据库 服务.Redis是单线程来处理命令的,一
条命令从客户端达到服务端不会立刻被执行,所有命令都会进入一个队列
中,然后逐个被执行。

Redis采用单线程还很快的原因

第一,纯内存访问
第二,非阻塞I/O,Redis使用epoll作为I/O多路复用技术的实现,再加上 Redis自身的事件处理模型将epoll中的连接、读写、关闭都转换为事件,不 在网络I/O上浪费过多的时间
第三,单线程避免了线程切换和竞态产生的消耗

数据结构

Redis都是采用键值对的形式存储,但是在底层有5种不同的数据结构,用于存储value值,分别是string、hash、list、set、sort-set

  • string 就跟普通的键值对无区别,value是一个字符串
  • hash被存储的value又是一个键值对
  • list是一个链表,分别有zipList、linkedList(底层编码方式)
  • set是存储字符串类型的无序集合,要求里面的字符串都不相同
  • sort-set是一个有序集合,里面的字符串与一个分值相关联,然后根据分值对所有的字符串排序的有序集合

持久化

Redis采用RDB和AOF进行持久化处理,可单独使用,也可以两种结合使用

  • RDB

RDB是到达一定的时间间隔将内存中的数据持久化到磁盘中,实现内存快照,是Redis默认的持久化方式
优点:RDB文件是一个二进制文件,根据时间点进行数据记录,可以对其进行压缩处理后占用的存储空间很小,压缩后的文件可以进行远程存储,方便备份和全量的复制。并且Redis重启后的恢复速度很快
缺点:会造成出故障的时间点到上一次持久化的时间间隔内的数据丢失,因此适合做冷备份,在数据恢复的时候要创建进程,有时会使机器短时间不可用

  • AOF
    以独立日志的方式记录每次写命令, 重启时再重新执行AOF文件中的命令达到恢复数据的目的
    优点:以追加写命令的方式实现持久化,保证了更好的数据完整性,使目前主流的持久化方式
    缺点:需要不断重写持久化文件来降低持久化文件的空间消耗

本文由【waitig】发表在等英博客
本文固定链接:Redis学习(一)—–初识redis
欢迎关注本站官方公众号,每日都有干货分享!
等英博客官方公众号
点赞 (0)分享 (0)