五. Redis 配置内容(详细配置说明)

五. Redis 配置内容(详细配置说明)

文章目录

  • 五. Redis 配置内容(详细配置说明)
  • 1. Units 单位配置
  • 2. INCLUDES (包含)配置
  • 3. NETWORK (网络)配置
    • 3.1 bind(配置访问内容)
    • 3.2 protected-mode (保护模式)
    • 3.3 port(端口)配置
    • 3.4 timeout(客户端超时时间)配置
    • 3.5 tcp-keepalive()配置
  • 4. GENERAL 通用配置
    • 4.1 daemonize(后台启动)配置
    • 4.2 pidfile(pid 文件存在路径)配置
    • 4.3 loglevel(日志级别)配置
    • 4.4 logfile(日志文件)配置
    • 4.5 databases 16(仓库数量)配置
  • 5. SECURITY 安全配置
    • 5.1 在 redis.conf 配置文件当中设置密码(永久)
    • 5.3 在 命令行设置密码
  • 6. LIMITS 限制配置
    • 6.1 maxclients(客户端连接数)配置
    • 6.2 maxmemory(Redis 最大占用内存)配置
    • 6.3 maxmemory-policy(Redis内存不够的算法配置处理)配置
    • 6.4 maxmemory-samples(内存算法处理的比较样本) 配置
  • 7. 总结:
  • 8. 最后:


关于 Redis 配置文件的文档说明:https://www.cnblogs.com/nhdlb/p/14048083.html

在这里插入图片描述

Redis 的配置的内容,都是在 /etc/redis.conf 这个文件当中进行配置设置的。

在这里插入图片描述

在这里插入图片描述

redis.conf 配置内容有很多很多,这里我们讲解一些比较常用的一些配置信息。

1. Units 单位配置

在这里插入图片描述

:set number   # 在 vim 工具当中 ,表示显示行号
  1. 配置大小单位,开头定义了一些基本的度量单位,只支持 bytes(字节) ,不支持 bit(比特),这是默认的,大家可以更加需要自行修改。
  2. 默认是不区分大小写的,对于命令来说,这个也是大家可以自行修改配置的。

2. INCLUDES (包含)配置

在这里插入图片描述

该配置信息表示:多实例的情况可以把公用的配置文件提取出来,然后 include 导入

3. NETWORK (网络)配置

3.1 bind(配置访问内容)

在这里插入图片描述

 bind 127.0.0.1 -::1
  1. 默认情况 bind 127.0.0.1 表示只能接收本地(本机)的访问请求,其它的主机是无法访问的。
  2. 如果服务器是需要远程访问的,需要将其注释掉。
  3. 这里,我们可以启动 redis ,查看当前允许连接的情况。

在这里插入图片描述

注销 bind , 重新启动 redis, 再查看当前允许连接的情况。

在这里插入图片描述

注意: 需要将 Redis 服务器,关闭了,再重启后,配置才能生效。

[root@localhost ~]# redis-cli  -p 6379 shutdown

在这里插入图片描述

在这里插入图片描述

3.2 protected-mode (保护模式)

在这里插入图片描述

默认是保护模式,也就是 protected-mode no

如果服务器是需要远程访问的, 需要将 yes 设置为 no
在这里插入图片描述

3.3 port(端口)配置

在这里插入图片描述

Redis 服务默认端口 6379,可以自行修改,但是注意要在 655535 的范围。

3.4 timeout(客户端超时时间)配置

如图默认配置:

在这里插入图片描述

 timeout 0

一个空闲的客户端维持多少秒会关闭,0 表示关闭该功能, 即永不超时 。大家可以根据需要自行修改。

3.5 tcp-keepalive()配置

在这里插入图片描述

tcp-keepalive 300
  1. tcp-keepalive 是对访问客户端的一种心跳检测,每隔 n 秒检测一次,单位为秒。
  2. 如果设置为 0 ,则不会进行 keepalive 检测,建议设置成 60

为什么需要心跳检测机制:

  1. TCP 协议中有长连接短连接 之分。短连接 环境下,数据交互完毕后,主动释放连接。
  2. 长连接 的环境下,进行一次数据交互后,很长一段时间内无数据交互时,客户端可能意外断开,这些 TCP 连接并未来得及正常释放 ,那么,连接的另一方并不知道对端的情况。就会一直维护这个连接,长时间的积累会导致非常多的半打开连接,造成端系统资源的消耗和浪费,且有可能导致在一个无效的数据链路层面发送业务数据,结果就是发送失败。所以服务端要做到快速感知失败,减少无效链接操作,这就有了 TCPKeepalive(保活探测) 机制

在这里插入图片描述

tcp-keepalive 10

配置成功后,需要重启 Redis 服务才会生效。

[root@localhost etc]# redis-cli -p 6379 shutdown

4. GENERAL 通用配置

4.1 daemonize(后台启动)配置

在这里插入图片描述

daemonize yes
  1. 是否为后台进程,设置为 yes
  2. 设置为 yes 后, 表示守护进程, 后台启动

4.2 pidfile(pid 文件存在路径)配置

在这里插入图片描述

 pidfile /var/run/redis_6379.pid

存放 pid 文件的位置,每个实例会产生一个不同的 pid 文件, 记录 redis 的进程号

在这里插入图片描述

[root@localhost run]# ps -ef | grep redis
[root@localhost run]# cat redis_6379.pid 

在这里插入图片描述

[root@localhost run]# ps -aux | grep sshd

在这里插入图片描述

4.3 loglevel(日志级别)配置

在这里插入图片描述

loglevel notice

Redis 日志分为 4 个级别,默认的设置为 notice,开发测试阶段可以用 debug(日志内容较多,不建议生产环境使用),生产模式一般选用 notice

Redis 日志级别为如下 4 种

  1. debug :会打印很多信息,适用于开发和测试阶段。
  2. verbose(冗长的) :包含很多不太有用的信息,但比 debug 要清爽一些。
  3. notice :适用于生产模式。
  4. warning :警告信息。

在这里插入图片描述

127.0.0.1:6379> config get loglevel

4.4 logfile(日志文件)配置

在这里插入图片描述

logfile ""
  1. logfile “” 就是说,默认为控制台打印,并没有日志文件生成
  2. 可以为 redis.conf 的 logfile 指定配置项。如下:
 logfile "/var/log/redis/redis.log"

在这里插入图片描述

修改了配置文件,需要重启 redis 才会生成。
在这里插入图片描述

127.0.0.1:6379> config get logfile

4.5 databases 16(仓库数量)配置

在这里插入图片描述

databases 16
  1. 设定库的数量,默认是16个,默认数据库为 0 号,数据库索引是从 0 开始的
  2. 可以适用 select<dbid> 命令在连接上指定数据库 id

在这里插入图片描述

5. SECURITY 安全配置

SECURITY 安全配置,就是为 Redis 客户端登录的时候,设置密码。

在 Redis 当中,设置密码有两种方式:

5.1 在 redis.conf 配置文件当中设置密码(永久)

在这里插入图片描述

# requirepass foobared

这里我们测试,将注释去掉,适用这个 foobared 作为密码。

 requirepass foobared

在这里插入图片描述

修改了配置,需要重启 Redis 服务,才会生效。

在这里插入图片描述

在这里插入图片描述

127.0.0.1:6379> auth foobared 
127.0.0.1:6379> auth 密码   # 登录 redis 客户端,使用密码

在这里插入图片描述

在这里插入图片描述

127.0.0.1:6379> acl list
# 注意:需要进入到 Redis 客户端

在这里插入图片描述

127.0.0.1:6379> acl whoami 
# 注意:需要进入到 Redis 客户端

在这里插入图片描述

5.3 在 命令行设置密码

在这里插入图片描述

127.0.0.1:6379> config get requirepass

在这里插入图片描述

在这里插入图片描述

127.0.0.1:6379> config set requirepass rainbowsea

6. LIMITS 限制配置

6.1 maxclients(客户端连接数)配置

在这里插入图片描述

  1. 设置 Redis 同时可以与多少个客户端进行连接(包括远程连接)

  2. 默认情况下为 10000 个客户端。

  3. 如果达到了此限制,redis 会拒绝新的连接请求,并且向这些连接请求方发出 “max number of clients reached”

  4. 注意一点的是:当超过连接数目了,你可以进入到 Redis 客户端,但是的命令是不会被 Redis 执行的,并提示 “max number of clients reached”

6.2 maxmemory(Redis 最大占用内存)配置

在这里插入图片描述

# maxmemory <bytes>
  1. 在默认情况下, 对 32 位 实例会限制在 3 GB, 因为 32 位的机器最大只支持 4GB 的 内存,而系统本身就需要一定的内存资源来支持运行,所以 32 位机器限制最大 3 GB 的 可用内存是非常合理的,这样可以避免因为内存不足而导致 Redis 实例崩溃
  2. 在默认情况下, 对于 64 位实例是没有限制
  3. 当用户开启了 redis.conf 配置文件的 maxmemory 选项,那么 Redis 将限制选项的值 不能小于 1 MB

maxmemory 设置的建议:

  1. Redis 的 maxmemory 设置取决于使用情况, 有些网站只需要 32MB,有些可能需要 12GB
  2. maxmemory 只能根据具体的生产环境来调试,不要预设一个定值,从小到大测试, 基本标准是不干扰正常程序的运行。
  3. Redis 的最大使用内存跟搭配方式有关,如果只是用 Redis 做纯缓存, 64-128M 对一般小 型网站就足够了
  4. 如果使用 Redis 做数据库的话,设置到物理内存的 1/2 到 3/4 左右都可以
  5. 如果使用了快照功能的话,最好用到 50%以下,因为快照复制更新需要双倍内存空间, 如果没有使用快照而设置 redis 缓存数据库,可以用到内存的 80%左右,只要能保证 Java、 NGINX 等其它程序可以正常运行就行了

6.3 maxmemory-policy(Redis内存不够的算法配置处理)配置

在这里插入图片描述

 # maxmemory-policy noevictio

policy 可以配置如下选项:

  1. volatile-lru:使用 LRU 算法移除 key,只对设置了过期时间的键;(最近最少使用)
  2. allkeys-lru:在所有集合 key 中,使用 LRU 算法移除 key
  3. volatile-random:在过期集合中移除随机的 key,只对设置了过期时间的键
  4. allkeys-random:在所有集合 key 中,移除随机的 key
  5. volatile-ttl:移除那些 TTL 值最小的 key,即那些最近要过期的 key
  6. noeviction:不进行移除。针对写操作,只是返回错误信息

无论是选择那种配置,都会丢失数据,所以,尽量还是设置好合适的 Redis 内存,方式内存不够用

6.4 maxmemory-samples(内存算法处理的比较样本) 配置

在这里插入图片描述

# maxmemory-samples 5
  1. 设置样本数量,LRU 算法和最小 TTL 算法都并非是精确的算法,而是估算值,所以你可 以设置样本的大小,redis 默认会检查这么多个 key 并选择其中 LRU 的那个。
  2. 一般设置 3 到 7 的数字,数值越小样本越不准确,但性能消耗越小。

举例理解:

简单的比较就是:当你在 8W 个人当中,找到身高 180 的人,很费时间和精力。但是当让你从 10,100个人当中找 身高 180的人,那就更简单了。简单的理解就是一个参考的样本。参考的数量越多精确度越高,但是成本也就越高。参考的数量少的,精确的就越低,但是消耗的成本却更低。

7. 总结:

  1. 注意: 上述的所有配置都需要将 Redis 服务器,关闭了,再重启后,配置才能生效。
  2. 查看 redis.conf 配置文件的信息,可以进入到 Redis 客户端后,使用 config get 配置属性/信息 命令。注意: 需要先进入到 Redis 客户端才行。

在这里插入图片描述

127.0.0.1:6379> config get loglevel
1) "loglevel"
2) "notice"
127.0.0.1:6379> config get logfile
1) "logfile"
2) ""
  1. 在命令行当中设置 redis.conf 配置文件的信息,可以进入到 Redis 客户端后,使用 config set 配置属性/信息 命令。注意: 需要先进入到 Redis 客户端才行。同时因为是在 客户端命令设置的配置信息,那么退出了客户端,该命令行配置的信息就都失效了。

在这里插入图片描述

127.0.0.1:6379> config set requirepass rainbowsea

在这里插入图片描述

在这里插入图片描述

127.0.0.1:6379> auth rainbowsea

在这里插入图片描述

127.0.0.1:6379> config get requirepass

8. 最后:

“在这个最后的篇章中,我要表达我对每一位读者的感激之情。你们的关注和回复是我创作的动力源泉,我从你们身上吸取了无尽的灵感与勇气。我会将你们的鼓励留在心底,继续在其他的领域奋斗。感谢你们,我们总会在某个时刻再次相遇。”

在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/10925.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

单细胞分析基础-第一节 数据质控、降维聚类

scRNA_pipeline\1.Seurat 生物技能树 可进官网查询 添加链接描述 分析流程 准备:R包安装 options("repos"="https://mirrors.ustc.edu.cn/CRAN/") if(!require("BiocManager")) install.packages("BiocManager",update = F,ask =…

Qt常用控件 输入类控件

文章目录 1.QLineEdit1.1 常用属性1.2 常用信号1.3 例子1&#xff0c;录入用户信息1.4 例子2&#xff0c;正则验证手机号1.5 例子3&#xff0c;验证输入的密码1.6 例子4&#xff0c;显示密码 2. QTextEdit2.1 常用属性2.2 常用信号2.3 例子1&#xff0c;获取输入框的内容2.4 例…

大模型培训讲师老师叶梓分享:DeepSeek多模态大模型janus初探

以下视频内容为叶梓分享DeepSeek多模态大模型janus的部署&#xff0c;并验证其实际效果&#xff0c;包括图生文和文生图两部分。 叶梓老师人工智能培训分享DeepSeek多模态大模型janus初探 DeepSeek 的多模态大模型 Janus 是一款强大的 AI 模型&#xff0c;专注于图像和文本的多…

Linux系统上安装与配置 MySQL( CentOS 7 )

目录 1. 下载并安装 MySQL 官方 Yum Repository 2. 启动 MySQL 并查看运行状态 3. 找到 root 用户的初始密码 4. 修改 root 用户密码 5. 设置允许远程登录 6. 在云服务器配置 MySQL 端口 7. 关闭防火墙 8. 解决密码错误的问题 前言 在 Linux 服务器上安装并配置 MySQL …

17.2 图形绘制7

版权声明&#xff1a;本文为博主原创文章&#xff0c;转载请在显著位置标明本文出处以及作者网名&#xff0c;未经作者允许不得用于商业目的。 17.2.9 字体 17.2.9.1 Font类 Font类定义特定的文本格式&#xff0c;包括字体、字号和样式特性。 Font常用属性&#xff1a; Na…

浅析DDOS攻击及防御策略

DDoS&#xff08;分布式拒绝服务&#xff09;攻击是一种通过大量计算机或网络僵尸主机对目标服务器发起大量无效或高流量请求&#xff0c;耗尽其资源&#xff0c;从而导致服务中断的网络攻击方式。这种攻击方式利用了分布式系统的特性&#xff0c;使攻击规模更大、影响范围更广…

90,【6】攻防世界 WEB Web_php_unserialize

进入靶场 进入靶场 <?php // 定义一个名为 Demo 的类 class Demo { // 定义一个私有属性 $file&#xff0c;默认值为 index.phpprivate $file index.php;// 构造函数&#xff0c;当创建类的实例时会自动调用// 接收一个参数 $file&#xff0c;用于初始化对象的 $file 属…

HarmonyOS NEXT:保存应用数据

用户首选项使用 用户首选项的特点 数据体积小、访问频率高、有加载速度要求的数据如用户偏好设置、用户字体大小、应用的配置参数。 用户搜选项&#xff08;Preferences&#xff09;提供了轻量级配置数据的持久化能力&#xff0c;支持订阅数据变化的通知能力。不支持分布式同…

C++编程语言:抽象机制:模板(Bjarne Stroustrup)

目录 23.1 引言和概观(Introduction and Overview) 23.2 一个简单的字符串模板(A Simple String Template) 23.2.1 模板的定义(Defining a Template) 23.2.2 模板实例化(Template Instantiation) 23.3 类型检查(Type Checking) 23.3.1 类型等价(Type Equivalence) …

OVS-DPDK

dpdk介绍及应用 DPDK介绍 DPDK&#xff08;Data Plane Development Kit&#xff09;是一组快速处理数据包的开发平台及接口。有intel主导开发&#xff0c;主要基于Linux系统&#xff0c;用于快速数据包处理的函 数库与驱动集合&#xff0c;可以极大提高数据处理性能和吞吐量&…

基础项目实战——学生管理系统(c++)

目录 前言一、功能菜单界面二、类与结构体的实现三、录入学生信息四、删除学生信息五、更改学生信息六、查找学生信息七、统计学生人数八、保存学生信息九、读取学生信息十、打印所有学生信息十一、退出系统十二、文件拆分结语 前言 这一期我们来一起学习我们在大学做过的课程…

基于微信小程序的医院预约挂号系统设计与实现(LW+源码+讲解)

专注于大学生项目实战开发,讲解,毕业答疑辅导&#xff0c;欢迎高校老师/同行前辈交流合作✌。 技术范围&#xff1a;SpringBoot、Vue、SSM、HLMT、小程序、Jsp、PHP、Nodejs、Python、爬虫、数据可视化、安卓app、大数据、物联网、机器学习等设计与开发。 主要内容&#xff1a;…

[Linux]从零开始的STM32MP157 U-Boot移植

一、前言 在上一次教程中&#xff0c;我们了解了STM32MP157的启动流程与安全启动机制。我们还将FSBL的相关代码移植成功了。大家还记得FSBL的下一个步骤是什么吗&#xff1f;没错&#xff0c;就是SSBL&#xff0c;而且常见的我们将SSBL作为存放U-Boot的地方。所以本次教程&…

单细胞-第四节 多样本数据分析,下游画图

文件在单细胞\5_GC_py\1_single_cell\2_plots.Rmd 1.细胞数量条形图 rm(list ls()) library(Seurat) load("seu.obj.Rdata")dat as.data.frame(table(Idents(seu.obj))) dat$label paste(dat$Var1,dat$Freq,sep ":") head(dat) library(ggplot2) lib…

高速稳定,功能强大的免费下载工具!!

今天&#xff0c;我向你们介绍一款超强的下载器——破姐版本&#xff0c;它完全免费&#xff0c;支持高速下载&#xff0c;将彻底解决你的下载难题。 01 软件介绍 P2P下载器免费下载工具&#xff0c;它以高速稳定、功能强大、无广告的特点&#xff0c;为你提供卓越的下载体验…

C++:虚函数与多态性习题2

题目内容&#xff1a; 编写程序&#xff0c;声明抽象基类Shape&#xff0c;由它派生出3个派生类&#xff1a;Circle、Rectangle、Triangle&#xff0c;用虚函数分别计算图形面积&#xff0c;并求它们的和。要求用基类指针数组&#xff0c;使它每一个元素指向一个派生类对象。 …

C#,入门教程(10)——常量、变量与命名规则的基础知识

上一篇&#xff1a; C#&#xff0c;入门教程(09)——运算符的基础知识https://blog.csdn.net/beijinghorn/article/details/123908269 C#用于保存计算数据的元素&#xff0c;称为“变量”。 其中一般不改变初值的变量&#xff0c;称为常变量&#xff0c;简称“常量”。 无论…

list的使用,及部分功能的模拟实现(C++)

目录&#xff08;文章中"节点"和"结点"是同一个意思&#xff09; 1. list的介绍及使用 1.1 list的介绍 1.2 list的使用 1.2.1 list的构造 1.2.2 list iterator的使用 1.2.3 list capacity 1.2.4 list element access 1.2.5 list modifiers 1.2.6 list…

MySQL 索引

MySQL 索引 文章目录 MySQL 索引1. 索引概念2. 索引结构3. 索引分类4. 索引使用4.1 单列索引和联合索引4.2 覆盖索引4.3 前缀索引 5. SQL提示6. 索引失效情况 1. 索引概念 索引可以理解为MySQL中用来高效检索数据的数据结构&#xff0c;它是有序的&#xff0c;因为它底层使用的…

JVM方法区

一、栈、堆、方法区的交互关系 二、方法区的理解: 尽管所有的方法区在逻辑上属于堆的一部分&#xff0c;但是一些简单的实现可能不会去进行垃圾收集或者进行压缩&#xff0c;方法区可以看作是一块独立于Java堆的内存空间。 方法区(Method Area)与Java堆一样&#xff0c;是各个…