redis和平常写的数据结构有什么区别?
一、redis和平常写的数据结构的区别
最大的区别,redis 作为缓存组件,可以独立部署。这也是为什么本地内存很快,但还是要用 redis 这类缓存的原因。Redis是基于c语言编写的开源非关系型内存数据库,可以用作数据库、缓存、消息中间件。
redis是一个开源的使用C语言编写的一个kv存储系统,是一个速度非常快的非关系远程内存数据库。它支持包括String、List、Set、Zset、hash五种数据结构。除此之外,通过复制、持久化和客户端分片等特性,用户可以很方便地将redis扩展成一个能够包含数百GB数据和每秒处理上百万次的请求的系统。目前支持多种语言的api,方便用户使用。
redis同时也内置了事务、LUA脚本、复制等功能,提供两种持久化选项,一种是每隔一段时间将数据导入到磁盘(快照模式),另一种是追加命令到日志中(AOF模式)。如果只是作为高效的内存数据库使用也可以关闭持久化功能。通过哨兵(sentinel)和自动分区(Cuuster)的方式可以提高redis服务器的高可用性。
与关系型数据库相比,redis的命令请求不需要经过查询分析器或查询优化器进行处理,也避免了更新数据时引起的随机读\写,这些慢操作。它直接读写内存中的数据,并且数据是按照一定的数据结构存储的。所以它的速度非常快。
延伸阅读:
二、字符串(String)
与其它编程语言或其它键值存储提供的字符串非常相似,键(key)——值(value) (字符串格式),字符串拥有一些操作命令,如:get set del 还有一些比如自增或自减操作等等。redis是使用C语言开发,但C中并没有字符串类型,只能使用指针或符数组的形式表示一个字符串,所以redis设计了一种简单动态字符串(SDS[Simple Dynamic String])作为底实现:
定义SDS对象,此对象中包含三个属性:
len buf中已经占有的长度(表示此字符串的实际长度)
free buf中未使用的缓冲区长度
buf[] 实际保存字符串数据的地方
所以取字符串的长度的时间复杂度为O(1),另,buf[]中依然采用了C语言的以\0结尾可以直接使用C语言的部分标准C字符串库函数。
空间分配原则:当len小于IMB(1024*1024)时增加字符串分配空间大小为原来的2倍,当len大于等于1M时每次分配 额外多分配1M的空间。

相关推荐HOT
更多>>
redis和平常写的数据结构有什么区别?
一、redis和平常写的数据结构的区别最大的区别,redis 作为缓存组件,可以独立部署。这也是为什么本地内存很快,但还是要用 redis 这类缓存的原...详情>>
2023-10-17 23:41:41
Rust的for循环中的自变量前为什么不加mut?
一、Rust的for循环中的自变量前不加mut的原因在Rust的for循环中,自变量前没有加mut的原因是,for循环默认情况下是将自变量作为不可变的绑定来...详情>>
2023-10-17 21:31:48
简单的bug管理工具怎么开发?
一、简单的bug管理工具开发1. 轻量化,即开即用,容易上手对Bug的分类是修复前很重要的一步,因此,要提前做好筛选工作。在轻流的Bug管理方案中...详情>>
2023-10-17 20:30:29
软件研发类项目怎么模块化管理?
一、软件研发类项目模块化管理1. 层次分明可以简单理解为设计一个结构合理的树状菜单。2. 抽象与细分抽象:只考虑要解决的问题(用户需求),不...详情>>
2023-10-17 19:22:45热门推荐
技术干货






