zoukankan      html  css  js  c++  java
  • Redis学习总结

    Redis是什么

    Key-Value数据库
    官网:https://redis.io/
    中文网:http://www.redis.cn/
    教程:https://www.runoob.com/redis/redis-tutorial.html

    为什么要用Redis

    1. 开源免费
    2. 高性能
    3. 支持存储多种数据结构
    4. 支持数据备份
    5. 支持数据持久化
    6. 原子性的操作

    Redis的安装(centos 7)

    下载安装包

      ```
      wget http://download.redis.io/releases/redis-6.0.5.tar.gz
      ```
    

    解压安装包

      ```
      tar zxvf redis-6.0.5.tar.gz
      ```
    

    编译安装

      ```
      make
      ```
    
      编译时提示:`bash: make: command not found` 时,证明make未安装,运行以下命令安装即可:
      ```
      yum -y install gcc automake autoconf libtool make
      ```
    
      若编译报错:
      ```
      In file included from server.c:30:0:
      server.h:1045:5: error: expected specifier-qualifier-list before ‘_Atomic’
           _Atomic unsigned int lruclock; /* Clock for LRU eviction */
           ^
      server.c: In function ‘serverLogRaw’:
      server.c:1028:31: error: ‘struct redisServer’ has no member named ‘logfile’
           int log_to_stdout = server.logfile[0] == '';
                                     ^
      server.c:1031:23: error: ‘struct redisServer’ has no member named ‘verbosity’
           if (level < server.verbosity) return;
                             ^
      server.c:1033:47: error: ‘struct redisServer’ has no member named ‘logfile’
           fp = log_to_stdout ? stdout : fopen(server.logfile,"a");
                                                     ^
      server.c:1046:47: error: ‘struct redisServer’ has no member named ‘timezone’
               nolocks_localtime(&tm,tv.tv_sec,server.timezone,server.daylight_active);
                                                     ^
      server.c:1046:63: error: ‘struct redisServer’ has no member named ‘daylight_active’
               nolocks_localtime(&tm,tv.tv_sec,server.timezone,server.daylight_active);
                                                                     ^
      server.c:1049:19: error: ‘struct redisServer’ has no member named ‘sentinel_mode’
               if (server.sentinel_mode) {
      ```
      时,运行`gcc -v`查看gcc版本,Redis要求gcc版本在5.3以上,运行以下命令可安装gcc:
      ```
      # 升级gcc到5.3及以上,如下升级到gcc 9.3:
      yum -y install centos-release-scl
      yum -y install devtoolset-9-gcc devtoolset-9-gcc-c++ devtoolset-9-binutils
      scl enable devtoolset-9 bash
      
      # 需要注意的是scl命令启用只是临时的,退出shell或重启就会恢复原系统gcc版本。
      
      如果要长期使用gcc 9.3的话:
      echo "source /opt/rh/devtoolset-9/enable" >>/etc/profile
      
      这样退出shell重新打开就是新版的gcc了
      以下其他版本同理,修改devtoolset版本号即可。
      ```
      相关博客:https://ncc0706.github.io/2020/05/21/db/redis/02.centos7-install-redis.6.0.3/
    

    修改配置

    修改配置文件:/apps/redis/redis-6.0.5/redis.conf

    启动方式

    前台启动:
    daemonize no
    后台启动:
    daemonize yes

    启动端口号

      ```
      port 6379
      ```
    

    绑定主机号

      ```
      bind 127.0.0.1
      ```
    

    连接密码

      ```
      requirepass foobared
      ```
    

    指定PID文件

      ```
      pidfile /var/run/redis_6379.pid
      ```
    

    最大客户端连接数

      ```
      maxclients 128
      ```
    

    最大内存限制

      ```
      maxmemory <bytes>
      ```
    

    数据库的数量

      ```
      databases 16
      ```
    

    客户端超时关闭时间

      未0表示不关闭
      ```
      timeout 
      ```
    

    在多长时间内,有多少次更新操作,就将数据同步到数据文件

      ```
      save <seconds> <changes>
      ```
      #### 存储本地数据库时是否压缩
      指定存储至本地数据库时是否压缩数据,默认为 yes,Redis 采用 LZF 压缩,如果为了节省 CPU 时间,可以关闭该选项,但会导致数据库文件变的巨大
      ```
      rdbcompression yes
      ```
    

    本地数据库文件名

      ```
      dbfilename dump.rdb
      ```
    

    本地数据库存放目录

      ```
      dir ./
      ```
    

    master ip和端口

      设置当本机为 slave 服务时,设置 master 服务的 IP 地址及端口,在 Redis 启动时,它会自动从 master 进行数据同步
      ```
      slaveof <masterip> <masterport>
      ```
    

    master密码

      当 master 服务设置了密码保护时,slav 服务连接 master 的密码
      ```
      masterauth <master-password>
      ```
    

    日志记录级别

      ```
      loglevel debug|verbose|notice|warning
      ```
    

    日志记录水平

      ```
      logfile stdout
      ```
    

    是否在每次更新操作后进行日志记录

      指定是否在每次更新操作后进行日志记录,Redis 在默认情况下是异步的把数据写入磁盘,如果不开启,可能会在断电时导致一段时间内的数据丢失。因为 redis 本身同步数据文件是按上面 save 条件来同步的,所以有的数据会在一段时间内只存在于内存中。默认为 no
      ```
      appendonly no
      ```
    

    更新日志文件名

      ```
      appendfilename appendonly.aof
      ```
    

    更新日志条件

      指定更新日志条件,共有 3 个可选值:
      no:表示等操作系统进行数据缓存同步到磁盘(快)
      always:表示每次更新操作后手动调用 fsync() 将数据写到磁盘(慢,安全)
      everysec:表示每秒同步一次(折中,默认值)
      ```
      appendfsync everysec
      ```
    

    是否启用虚拟内存机制

      指定是否启用虚拟内存机制,默认值为 no,简单的介绍一下,VM 机制将数据分页存放,由 Redis 将访问量较少的页即冷数据 swap 到磁盘上,访问多的页面由磁盘自动换出到内存中(在后面的文章我会仔细分析 Redis 的 VM 机制)
      ```
      vm-enabled no
      ```
    

    虚拟内存文件路径

      虚拟内存文件路径,默认值为 /tmp/redis.swap,不可多个 Redis 实例共享
      ```
      vm-swap-file /tmp/redis.swap
      ```
    

    大于多少的数据就存入虚拟内存

      将所有大于 vm-max-memory 的数据存入虚拟内存,无论 vm-max-memory 设置多小,所有索引数据都是内存存储的(Redis 的索引数据 就是 keys),也就是说,当 vm-max-memory 设置为 0 的时候,其实是所有 value 都存在于磁盘。默认值为 0
      ```
      vm-max-memory 0
      ```
    

    设置 swap 文件中的 page 数量

      设置 swap 文件中的 page 数量,由于页表(一种表示页面空闲或使用的 bitmap)是在放在内存中的,,在磁盘上每 8 个 pages 将消耗 1byte 的内存。
      ```
      vm-pages 134217728
      ```
    

    访问swap文件的线程数

      设置访问swap文件的线程数,最好不要超过机器的核数,如果设置为0,那么所有对swap文件的操作都是串行的,可能会造成比较长时间的延迟。默认值为4
      ```
      vm-max-threads 4
      ```
    

    在向客户端应答时,是否把较小的包合并为一个包发送

      ```
      glueoutputbuf yes
      ```
    

    常用命令

    启动

      ```
      ## 默认
      redis-server
      ## 自定义配置文件
      redis-server ./redis.conf 
      ## 指定配置
      ### 如:配置后台启动,且端口是 1123
      redis-server ./redis.conf --daemonize yes --port 1123
      ```
    

    停止

      ```
      redis-server stop
      ```
    

    重启

      ```
      redis-server restart
      ```
  • 相关阅读:
    Spring事务原理分析-部分二
    Spring事务原理分析-部分一
    Spring 通读官方文档
    Spring IOC 源码解析
    SpringAOP原理分析
    Docker学习笔记
    TCP、UDP和HTTP关系
    洛谷P3312
    洛谷P3327
    BZOJ3073
  • 原文地址:https://www.cnblogs.com/hutianyao/p/13118147.html
Copyright © 2011-2022 走看看