当前位置:网站首页 > 云计算与后端部署 > 正文

redis端口(redis端口号怎么修改)



Redis 是Remote Dictionary Service 的简称;也是远程字典服务。它是内存数据库,KV 数据库,数据结构数据库。它是一个单线程的单reactor模型。其交互方式是请求响应方式。在正常情况下,如果向redis发出请求,则一定会有响应。

Redis 应用非常广泛,如Twitter、暴雪娱乐、Github、Stack Overflow、腾讯、阿里巴巴、京东、华为、新浪微博等,很多中小型公司也在使用。

Redis 命令查看:http://redis.cn/commands.html。

redis数据的基本结构:

img

redis的存储结构为键值对,其中键为字符串,值可能为很多种数据结构,比如字符串、hash、list等。reds的存储结构和c++ 的unordered_map<string, T>比较像,其中T代表泛型。它共有16个数据库。

redis存储结构(KV):

img

redis中value编码:

img

字符数组,该字符串的编码方式有三种,分别是int方式、raw方式和embstr方式。

  • 当字符串长度不大于20时且能转成整数时,使用int方式存储;
  • 当字符串长度大于20且不大于44时,使用embstr存储。
  • 当字符串长度大于44时,使用raw存储。

embstr 编码是 raw 编码的一种优化方式,其底层数据结构都是简单动态字符串。所以 embstr编码和 raw 编码实现的字符串对象,都包含两部分的结构:redisObject 和 sdshdr.

Note: redisObject是Redis用来表示任意一种类型对象的通用结构体, 其中包含了该对象的类型和编码方式,以及指向底层数据结构的指针邓信息. sdshdr则是Redis专门用来表示简单动态字符串的结构体.

不同的是,raw 编码方式会调用两次内存分配函数来分别创建 redisObject 结构和 sdshdr 结构;而 embstr 编码方式只调用一次内存分配函数为 redisObject 结构和 sdshdr 结构同时分配内存空间, 其原理就是将字符串内容直接存储在redisObject的结构体中.

和raw相比,embstr的优点是:

  1. 创建对象时,内存分配函数从两次降为一次
  2. 销毁对象时,内存释放函数从两次降为一次
  3. embstr编码的字符串,redisObject 结构和 sdshdr 结构处于连续的内存空间中,能更好地利用缓存带来的优势
  4. Embstr 存储较短的字符串时采用一种优化的编码方式,可以减少内存占用;而 Raw 则没有进行任何优化,直接存储字符串的内容。

动态字符串 raw,字符串长度小于1M 时,加倍扩容;超过 1M 每次只多扩1M;字符串最大长度为 512M;

redis 字符串不同于C语言中的字符串,这里是安全字符串,长度是由结构体中的一个成员变量标识的,内容由柔性数组存储。还有一个成员变量描述可用空间,它可以存储图片,二进制协议等二进制数据。

基础命令:

 
  

双向链表实现,列表首尾操作(删除和增加)时间复杂度O(1) ;查找中间元素时间复杂度为
O(n) ;
列表中数据是否压缩的依据:

  1. 元素长度小于 48,不压缩;
  2. 元素压缩前后长度差不超过 8,不压缩;

基础命令:

 
  

应用:

异步消息队列:
操作与队列一样,但是在不同系统间;

img

实际项目中需要保证命令的原子性,所以一般用 lua 脚本 或者使用 pipeline 命令;

 
  

存储结构
节点数量大于 512(hash-max-ziplist-entries) 或所有字符串长度大于 64(hash-max-ziplistvalue),则使用 dict 实现;

节点数量小于等于 512 且有一个字符串长度小于 64,则使用 ziplist 实现;

dict和ziplist的区别:

  • 用于实现哈希表数据类型,支持高效的数据查找和插入; 用于实现列表数据类型,可以高效地存储一系列连续的元素。
  • 相对于 , 数据结构需要占用更多的内存。因为 存储键和值都需要分配内存,并且需要维护哈希表的结构;而 存储的是压缩过的连续元素,不需要分配额外的内存用于维护链表结构。
  • 相对于 , 数据结构的查询效率更高。因为 的底层实现是哈希表,支持 O(1) 时间复杂度的查找操作;而 的底层实现是链表,查找元素的时间复杂度为 O(n)。

基础命令:

 
  

存储结构
元素都为整数且节点数量小于等于 512(set-max-intset-entries),则使用整数数组存储;
元素当中有一个不是整数或者节点数量大于 512,则使用hash存储;

基础命令

 
  

有序集合;用来实现排行榜;它是一个有序唯一;

存储结构:
节点数量大于 128或者有一个字符串长度大于64,则使用跳表(skiplist);
节点数量小于等于128(zset-max-ziplist-entries)且所有字符串长度小于等于64(zset-maxziplist-value),则使用 ziplist 存储;
数据少的时候,注重节省空间;
数量多的时候,注重访问性能;



基础命令:

 
  

Redis发布订阅是为了支持消息的多播机制,关键命令如下:

 
  

发布订阅功能一般要区别命令连接而重新开启一个连接。因为命令连接严格遵循请求回应模式;而pubsub能收到redis主动推送的内容;所以实际项目中如果支持pubsub的话,需要另开一条连接用于处理发布订阅;

缺点

发布订阅的生产者传递过来一个消息,redis会直接找到相应的消费者并传递过去;

假如没有消费者,消息直接丢弃;

假如开始有2个消费者,一个消费者突然挂掉了,另外一个消费者依然能收到消息,但是如果刚挂掉的消费者重新连上后,在断开连接期间的消息对于该消费者来说彻底丢失了。stream的方式,确保消息一定可达。

另外,redis停机重启,pubsub的消息是不会持久化的,所有的消息被直接丢弃;

本专栏知识点是通过<零声教育>的系统学习,进行梳理总结写下文章,对c/c++linux课程感兴趣的读者,可以点击链接,详细查看详细的服务:链接

到此这篇redis端口(redis端口号怎么修改)的文章就介绍到这了,更多相关内容请继续浏览下面的相关推荐文章,希望大家都能在编程的领域有一番成就!

版权声明


相关文章:

  • docker如何启动镜像(docker启动镜像指定端口)2025-08-29 20:09:10
  • 电脑软件后缀名怎么显示(电脑桌面软件后缀怎么显示)2025-08-29 20:09:10
  • 苹果电脑装了双系统以后怎么恢复(苹果电脑双系统重装系统全部都恢复吗)2025-08-29 20:09:10
  • redis 6380端口(redis端口号是多少)2025-08-29 20:09:10
  • 交换机console是什么意思(交换机的console端口)2025-08-29 20:09:10
  • 二级域名解析到端口怎么解决(二级域名解析记录值)2025-08-29 20:09:10
  • 前端工程化体系(前端工程化体系设计与实践考试题目)2025-08-29 20:09:10
  • hpp是什么文件(hpp是什么文件后缀)2025-08-29 20:09:10
  • 电脑安装软件后缀怎么改(电脑软件安装程序后缀)2025-08-29 20:09:10
  • vb饭前吃还是饭后吃比较好吃(vb饭后多久吃比较好)2025-08-29 20:09:10
  • 全屏图片