• Redis入门概述


    在这里插入图片描述


    一、NoSQL数据库

    NoSQL(NoSQL = Not Only SQL ),意即“不仅仅是SQL”,泛指非关系型的数据库。 NoSQL 不依赖业务逻辑方式存储,而以简单的key-value模式存储。因此大大的增加了数据库的扩展能力。它相比于传统的关系型数据库有以下几个区别:不遵循SQL标准、不支持ACID原则、它的性能远超于SQL。

    适用的场景

    1. 对数据高并发的读写
    2. 海量数据的读写
    3. 对数据有较高的扩展性

    不适合的场景

    1. 需要支持事务相关的操作
    2. 基于sql的结构化查询存储,处理复杂的关系,需要即时查询

    最早出现的NoSql数据库叫做Memcache,它的数据都保存在内存中,需要频繁访问数据库的网站访问速度提升效果十分显著,一般不持久化,它只支持简单的key-value模式,支持类型相对单一,它的作用一般是作为缓存数据库辅助持久化的数据库。
    在这里插入图片描述

    二、Redis 概述

    Redis是一个key-value存储系统。和Memcached类似,它支持存储的value类型相对更多,包括string(字符串)、list(链表)、set(集合)、zset(sorted set --有序集合)和hash(哈希类型)。它的数据类型都支持push/pop、add/remove及取交集并集和差集及更丰富的操作,而且这些操作都是原子性的。在此基础上,redis支持各种不同方式的排序。与memcached一样,为了保证效率,数据都是缓存在内存中。区别的是redis会周期性的把更新的数据写入磁盘或者把修改操作写入追加的记录文件,并且在此基础上实现了master-slave(主从)同步。

    适用场景

    场景一:配合关系型数据库做高速缓存

    • 将高频次,热门访问的数据放到缓存中,降低数据库IO,提高查询性能
    • 在分布式架构,最常见的问题就是session存在哪里,使用redis做缓存,将session数据放到redis中实现session共享。

    在这里插入图片描述

    场景二:多样的数据结构存储持久化数据

    • 最常见的网站Top N 数据、最新的N 个数据、手机验证码等等,通过Redis的数据类型结构进行持久化的存储。

    Redis是单线程+多路IO复用技术

    多路复用是指使用一个线程来检查多个文件描述符(Socket)的就绪状态,比如调用select和poll函数,传入多个文件描述符,如果有一个文件描述符就绪,则返回,否则阻塞直到超时。得到就绪状态后进行真正的操作可以在同一个线程里执行,也可以启动线程执行(比如使用线程池)。

    一个场景说明多路IO复用技术:
    相信大家都有去火车站买票的经历,遇到节假日的时候一票难求,这时在火车站就会有一种人,可以替人买票,我们亲切的将其称之为黄牛。有了黄牛的出现,我们可以把买票的需求告诉黄牛,让黄牛帮我们购买。有一天,有三个人找到黄牛让其帮忙购票,这时黄牛去火车站买票的过程为单线程操作,如果黄牛买到了三个人中某个人的票,通知其去黄牛哪里取票即可。假设第一个人想要去上海的票,通知黄牛去买票,黄牛在买票的时候,第一个人不用一直等待,可以做自己的事情,例如:吃饭、睡觉等,等到黄牛买到票后,通知第一个人取票就可。其他两个人也类似,也就是说这三个人都是在买票,但是在没有买到票的时候一直在干活,CPU一直处于工作状态,这个过程就是多路IO复用
    在这里插入图片描述

    与Redis不同的是Memcache底层采用的是多线程+锁进行实现的。

    三、在Linux环境下安装Redis

    安装步骤

    第一步:下载Redis(我下载的是6.2.7版本)

    点击进入Redis官方下载网页

    在这里插入图片描述
    第二步:测试 gcc版本 (安装redis依赖gcc)

    gcc --version
    
    • 1

    在这里插入图片描述

    如果没有gcc的话通过如下命令进行安装C语言编译环境

    yum install centos-release-scl scl-utils-build
    yum install -y devtoolset-8-toolchain
    scl enable devtoolset-8 bash
    
    • 1
    • 2
    • 3

    第三步:解压下载的Redis tar.gz文件

    tar -zxvf xxx
    
    • 1

    在这里插入图片描述
    第四步:进入解压后的文件 执行make命令进行编译

    在这里插入图片描述
    第五步:继续执行: make install

    安装成功后会默认安装到/usr/local/bin路径

    在这里插入图片描述

    • redis-benchmark:性能测试工具,可以在自己本子运行,看看自己本子性能如何
    • redis-check-aof:修复有问题的AOF文件,rdb和aof后面讲
    • redis-check-dump:修复有问题的dump.rdb文件
    • redis-sentinel:Redis集群使用
    • redis-server:Redis服务器启动命令
    • redis-cli:客户端,操作入口

    前台启动(不建议)

    前台启动,命令行窗口不能关闭,否则服务器停止

    redis-server
    
    • 1

    在这里插入图片描述

    后台启动(推荐)

    • 备份redis.conf,拷贝一份redis.conf到其他目录
    • 台启动设置daemonize no改成yes

    在这里插入图片描述

    • Redis启动

    在这里插入图片描述

    • 用客户端访问:redis-cli

    在这里插入图片描述

    • .Redis关闭

    在这里插入图片描述

    四、Redis配置文件解析

    • 配置大小单位,开头定义了一些基本的度量单位,只支持bytes,不支持bit。

    在这里插入图片描述

    • 类似jsp中的include,多实例的情况可以把公用的配置文件提取出来

    在这里插入图片描述

    • 默认情况bind=127.0.0.1只能接受本机的访问请求不写的情况下,无限制接受任何ip地址的访问,生产环境肯定要写你应用服务器的地址;服务器是需要远程访问的,所以需要将其注释掉
      在这里插入图片描述
    • 将本机访问保护模式设置no
      在这里插入图片描述
    • 默认端口号为:6379

    在这里插入图片描述

    • 一个空闲的客户端维持多少秒会关闭,0表示关闭该功能,即永不关闭。
      在这里插入图片描述
    • 是否为后台进程,设置为yes,守护进程,后台启动

    在这里插入图片描述

    • 存放pid文件的位置,每个实例会产生一个不同的pid文件
      在这里插入图片描述
    • 设定库的数量 默认16,默认数据库为0,可以使用SELECT 命令在连接上指定数据库id
      在这里插入图片描述
    • 设置redis可以使用的内存量。一旦到达内存使用上限,redis将会试图移除内部数据.
    • 建议必须设置,否则,将内存占满,造成服务器宕机

    在这里插入图片描述

    • 设置redis同时可以与多少个客户端进行连接。默认情况下为10000个客户端。
    • 如果达到了此限制,redis则会拒绝新的连接请求,并且向这些连接请求方发出“max number of clients reached”以作回应。
      在这里插入图片描述
  • 相关阅读:
    城市网吧视频智能监控方案,实现视频远程集中监控
    SOCKS5代理与网络安全:如何安全地进行爬虫操作
    SPARK中的wholeStageCodegen全代码生成--以aggregate代码生成为例说起(4)
    C++多线程 join、detach、joinable
    windows 安装配置GO开发环境
    [附源码]Python计算机毕业设计Django姜太公渔具销售系统
    SpringBoot整合knife4j3.0.3
    模式也能开盲盒,”盲返“模式带动电商平台共享经济
    工业互联网系列2 - 赋能传统制造业
    Mybatis——Mybatis表之间的关联关系和事务、缓存机制以及ORM
  • 原文地址:https://blog.csdn.net/Zp_insist/article/details/126506903