一、初识redis

定义

  Redis是一个开源的Key-Value数据库,通常被称为数据结构服务器,其值可以是多种常见的数据格式,且读写性能极高,且所有操作都是原子性的

高性能的主要原因

  • 1、基于内存存储,命令几乎都是操作内存,内存的读写速度非常快。
  • 2、单线程处理网络请求,避免不必要的上下文切换,同时不存在加锁/释放锁等同步操作。【PS:正在运行的redis server肯定不止一个线程,但只有一个线程来处理网络请求】
  • 3、使用多路I/O复用模型(select、poll、epoll),可以高效处理大量并发连接。
  • 4、数据结构专门设计,CRUD操作相对简单。

二、安装Redis

  由于我们使用redis的场景一般是安装在服务器上的,所以这里以linux环境为例子进行安装:

#1、下载源码包
wget http://download.redis.io/releases/redis-5.0.0.tar.gz

#2、解压源码包
tar -zxvf redis-5.0.0.tar.gz #3、进入安装目录
cd redis-5.0.0 #4、编译【从Makefile中读取指令,然后编译】
make #5、进入源码目录
cd src #6、安装【从Makefile中读取指令,然后安装到指定的位置】
make install

  安装完成后进入/usr/local/bin目录中可以看到生成了一些可执行文件

  • redis-benchmark:官方自带的redis性能测试工具
  • redis-check-aof:修复语法错误的AOF文件
  • redis-check-rdb:修复语法错误的RDB文件
  • redis-cli:客户端命令行工具【redis-cli -h {host} -p {port} 链接到指定的redis服务器】
  • redis-sentinel:哨兵启动程序
  • redis-server:服务端启动程序

配置redis

  安装完成后,redis默认是本机连接的形式,外网无法访问,我们需要改一下配置文件:

  修改完文件以后我们直接输入以下命令重启Redis服务器:

#使用对应的配置文件来启动Redis服务器【这里我们是进入了src目录里面去执行redis-server,而不是直接使用安装好以后在/usr/local/bin目录下的快捷命令】
#PS:../redis.conf表示使用此配置文件进行启动
#PS:&
表示后台启动,跳出后不关闭程序 redis-server ../redis.conf &

三、Redis源码结构

  redis源码主要放在安装目录下的src目录里面:

  核心部分如下:

(1)基本数据结构

  • 动态字符串 :sds.c
  • 整数集合 :intset.c
  • 压缩列表 :ziplist.c
  • 快速链表 :quicklist.c
  • 字典 :dict.c
  • Streams :底层实现结构为listpack.c和rax.c

(2)Redis数据类型的底层实现

  • redis对象 :object.c
  • 字符串 : t_string.c
  • 列表 :t_list.c
  • 字典 :t_hash.c
  • 集合及有序集合 :t_set.c 和 t_zset.c
  • 数据流 :t_stream.c

(3)Redis数据库的实现

  • 数据库的底层实现 :db.c
  • 持久化 :rdb.c 和 aof.c

(4)Redis服务端和客户端实现

  • 事件驱动 :ae.c 和 ae_epoll.c
  • 网络连接 :anet.c 和 networking.c
  • 服务端程序 :server.c
  • 客户端程序 :redis-cli.c

(5)其它

  • 主从复制 :replication.c
  • 哨兵 :sentinel.c
  • 集群 :cluster.c
  • 其他数据结构 :hyperloglog.c 、 geo.c 等
  • 其他功能 :pub/sub 【发布/订阅】、 Lua脚本等

Redis5设计与源码分析读后感(一)认识Redis的更多相关文章

  1. Redis5设计与源码分析读后感(四)压缩列表

    一.引言 上一节我们总结了跳跃表的知识,我们知道了有序数组可以用跳跃表实现,也可以用压缩列表来实现,这一篇文章我们来总结一下压缩列表相关的知识. 二.压缩列表简介 定义:压缩列表 ziplist 本质 ...

  2. Redis5设计与源码分析读后感(三)跳跃表

    一.引言 有序集合在日常开发中相当常见,比如做排名等相关的功能,肯定要用到排序的功能,那么常见底层实现有很多种: 数组 :不便于元素的插入和删除 链表 :查询效率低,需要遍历所有元素 平衡树OR红黑树 ...

  3. Redis5设计与源码分析读后感(二)简单动态字符串SDS

    一.引言 学习之前先了解几个概念: SDS定义:简单动态字符串,Redis的基本数据结构之一,用于储存字符串和整型数据. 二进制安全:C语言中用"\0"表示字符串结束,如果字符串本 ...

  4. [源码分析] OpenTracing之跟踪Redis

    [源码分析] OpenTracing之跟踪Redis 目录 [源码分析] OpenTracing之跟踪Redis 0x00 摘要 0x01 总体逻辑 1.1 相关概念 1.2 埋点插件 1.3 总体逻 ...

  5. 《redis 5设计与源码分析》:第二章 简单动态字符串

    介绍 简单动态字符串(Simple Dynamic Strings, SDS)是Redis的基本数据结构之一,用于存储字符串和整型数据.它的特点是:方便扩容.二进制安全. 二进制安全 在C语言中,用& ...

  6. ABP源码分析一:整体项目结构及目录

    ABP是一套非常优秀的web应用程序架构,适合用来搭建集中式架构的web应用程序. 整个Abp的Infrastructure是以Abp这个package为核心模块(core)+15个模块(module ...

  7. jQuery源码分析系列

    声明:本文为原创文章,如需转载,请注明来源并保留原文链接Aaron,谢谢! 版本截止到2013.8.24 jQuery官方发布最新的的2.0.3为准 附上每一章的源码注释分析 :https://git ...

  8. jquery2源码分析系列

    学习jquery的源码对于提高前端的能力很有帮助,下面的系列是我在网上看到的对jquery2的源码的分析.等有时间了好好研究下.我们知道jquery2开始就不支持IE6-8了,从jquery2的源码中 ...

  9. [转]jQuery源码分析系列

    文章转自:jQuery源码分析系列-Aaron 版本截止到2013.8.24 jQuery官方发布最新的的2.0.3为准 附上每一章的源码注释分析 :https://github.com/JsAaro ...

随机推荐

  1. ceph scrub error解决方案

    参考链接:https://blog.csdn.net/u010317005/article/details/79242794 问题现象: 原因分析: 数据的不一致性(inconsistent)指对象的 ...

  2. Python之运维

    这几日一直研究运维监控的事情,有次看见有一个脚本写的还不错,如今已经找不到地址了 就只能用Python代替shell了 其中原理是 监控 /proc/下的各种文件,/proc/ 顾名思义其为进程的文件 ...

  3. 四则运算生成命令行程序 (Python)

    Github项目地址:Github Pages 结对项目成员:张鹏 3118004985 郑靓 3118004988 一.项目需求分析 二.功能实现 三.代码实现or功能说明 ★ GUI功能扩展说明 ...

  4. 2020无损车载音源抖音歌曲下栽经典流行MP3新歌曲视频音乐下载包

    2020无损车载音源抖音歌曲下栽经典流行MP3新歌曲视频音乐下载包 偶有几次乘出租车晚归,除了发现出租车司机都很爱听叶文有话要说之外,也发现有的出租车司机还是很有听歌品位的,车载音响系统改的也很棒.有 ...

  5. discuz论坛替换logo之后不显示该怎么办

    http://www.wocaoseo.com/thread-2-1-1.html 这个虽然不算是seo的问题,但是在平时的操作之中经常性的遇到,常常是我用FTP已经上传替换了原来的logo,但是前台 ...

  6. Pyqt QImage 与 np array 转换方法

    Pyqt QImage 与 np array 转换方法(转载) img=cv2.resize(src=img,dsize=None,fx=0.2,fy=0.2) img2=cv2.cvtColor(i ...

  7. Qt 子窗口监听主窗口信号

    Qt 子窗口监听主窗口信号(转载)  原文链接:https://www.cnblogs.com/ybqjymy/p/12169762.html 1 MainWindow *ptr = NULL; 2 ...

  8. WPF新手快速入门系列 1.布局

    [概要] 该系列文章主要描述,新手如何快速上手做wpf开发.看过网上部分的教程,主要讲述的是介绍控件.这并没有问题,但是没有把自己的使用经验也完整的描述出来. 所以特此编写此系列文章希望能帮助到,因为 ...

  9. 用 Java 拿下 HTML 分分钟写个小爬虫

    本文适合有 Java 基础知识的人群 本文作者:HelloGitHub-秦人 HelloGitHub 推出的<讲解开源项目>系列,今天给大家带来一款开源 Java 版一款网页元素解析框架- ...

  10. laravel核心Ioc容器

    laravel容器和依赖注入 啥是Ioc容器,方便我们实现依赖注入的一种实现,也就是说依赖注入不一定需要控制反转容器,只不过使用容器可能会方便些. laravel通过向容器中绑定接口的具体实现,可实现 ...