Redis学习(一)-----初识redis
来源:互联网 发布:苹果下软件赚钱的软件 编辑:程序博客网 时间:2024/06/11 03:30
简介
Redis是一种非结构化的数据库,将数据采用键值对的形式存储在内存中,由于存储在内存中,所以运行很快。
为什么快?
- 所有的数据都是放在内存中进行管理的,当然比存储在外存的结构化数据库快
- 是用C语言实现的,更接近操作系统,运行更快
- 采用单线程架构,避免了多线程产生的资源竞争问题
- 源代码特别精简
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文件中的命令达到恢复数据的目的
优点:以追加写命令的方式实现持久化,保证了更好的数据完整性,使目前主流的持久化方式
缺点:需要不断重写持久化文件来降低持久化文件的空间消耗
阅读全文
0 0
- Redis学习(一)-----初识redis
- redis(一)初识
- Redis初识(一)
- Redis数据库系列(一)------初识Redis
- Redis之(一)初识Redis
- 【Redis学习笔记】Redis初识
- 初识Redis(一)
- 一、 初识Redis
- redis学习(一)
- Redis学习(一)
- Redis学习(一)
- Redis学习(一)
- Redis 学习(一)
- 【redis 基础篇一】redis初识
- redis学习(一)Redis应用场景
- Redis学习笔记(一)--认识Redis
- Redis 学习(一)redis的安装
- redis学习之(一)redis安装
- [LeetCode] 递归求解二叉树路径之和是否等于给定值(2)
- UVA-11600-Masud Rana
- mysql命令gruop by报错this is incompatible with sql_mode=only_full_group_by
- java AWT 五子棋
- Http+servlet
- Redis学习(一)-----初识redis
- 基本数据类型参数的传值
- python3.6.1环境配置出现Requirement already up-to-date: pip in c:\python36\lib\site-packages决解方案
- 51Nod 1499 图(最小割+边在割的一边有收益建图)
- <设计模式可复用面向对象软件的基础> [2.4]、装饰者模式(C#)
- 输入Scanner的用法
- Rhyme/Linux 权限管理 特殊文件权限SetUID的解析、使用与注意事项
- Android Studio有关Gradle更新问题--
- [论文解读] 3D Fully Convolutional Network for Vehicle Detection in Point Cloud