(Redis基础教程之十二) 如何解决Redis中的故障[通俗易懂]

(Redis基础教程之十二) 如何解决Redis中的故障[通俗易懂]介绍 Redis是一个开源的内存中键值数据存储。它带有几个命令,可以帮助您进行故障排除和调试。由于Redis具有内存中的键值存储的性质,因此其中许多命令都集中在内存管理上,但是还有一些其他命令对于概…

(Redis基础教程之十二) 如何解决Redis中的故障

如何使用本指南

本指南以备有完整示例的备忘单形式编写。我们鼓励您跳至与您要完成的任务相关的任何部分。

本指南中显示的命令已在运行Redis版本4.0.9的Ubuntu 18.04服务器上进行了测试。要设置类似的环境,您可以按照我们的指南如何在Ubuntu 18.04上安装和保护Redis的步骤1进行操作。我们将通过使用Redis命令行界面运行它们来演示这些命令的行为。请注意,如果您使用其他Redis界面(例如Redli),则某些命令的确切输出可能会有所不同。redis-cli

另外,您可以提供一个托管的Redis数据库实例来测试这些命令,但是请注意,根据数据库提供者所允许的控制级别,本指南中的某些命令可能无法按所述方式工作。要配置DigitalOcean托管数据库,请遵循我们的托管数据库产品文档。然后,您必须 安装Redli 设置TLS隧道才能通过TLS连接到托管数据库。

对内存相关问题进行故障排除

memory usage告诉您单个键当前正在使用多少内存。它以键的名称作为参数,并输出其使用的字节数:

memory usage key_meaningOfLife


(integer) 42

代码100分

为了更全面地了解您的Redis服务器如何使用内存,可以运行以下memory stats命令:

代码100分memory stats

此命令输出与内存相关的指标及其值的数组。以下是报告的指标memory stats

  • peak.allocated:Redis消耗的最大字节数
  • total.allocated:Redis分配的总字节数
  • startup.allocated:Redis在启动时消耗的初始字节数
  • replication.backlog:复制积压的大小,以字节为单位
  • clients.slaves:所有副本_开销_的总大小(输出和查询缓冲区以及连接上下文)
  • clients.normal:所有客户端开销的总大小
  • aof.buffer:当前和重写的仅附加文件缓冲区的总大小
  • db.0:服务器上正在使用的每个数据库的主要和到期字典的开销,以字节为单位报告
  • overhead.total:用于管理Redis密钥空间的所有开销的总和
  • keys.count:服务器上所有数据库中存储的密钥总数
  • keys.bytes-per-key:服务器的净内存使用率与 keys.count
  • dataset.bytes:数据集的大小,以字节为单位
  • dataset.percentage:Redis占用的Redis净内存使用量的百分比 dataset.bytes
  • peak.percentagepeak.allocated取出的百分比total.allocated
  • fragmentation:当前正在使用的内存量除以Redis实际使用的物理内存之比

memory malloc-stats提供了来自jemalloc的内部统计报告,该报告是Linux系统上Redis使用的内存分配器:

memory malloc-stats

如果您似乎遇到了与内存有关的问题,但是解析前面命令的输出证明是无济于事的,则可以尝试运行memory doctor

代码100分memory doctor

此功能将输出它可以找到的所有内存消耗问题,并提出潜在的解决方案。

获取有关Redis实例的常规信息

与内存管理没有直接关系的调试命令是monitor。此命令使您可以查看Redis服务器处理的每个命令的恒定流:

monitor


OK
1566157213.896437 [0 127.0.0.1:47740] "auth" "foobared"
1566157215.870306 [0 127.0.0.1:47740] "set" "key_1" "878"

另一个对调试有用的命令是info,它返回有关服务器的多个信息和统计信息块:

info


# Server
redis_version:4.0.9
redis_git_sha1:00000000
redis_git_dirty:0
redis_build_id:9435c3c2879311f3
redis_mode:standalone
os:Linux 4.15.0-52-generic x86_64
. . .

此命令返回很多信息。如果您只想查看一个信息块,则可以将其指定为info

info CPU


# CPU
used_cpu_sys:173.16
used_cpu_user:70.89
used_cpu_sys_children:0.01
used_cpu_user_children:0.04

请注意,该info命令返回的信息将取决于您所使用的Redis版本。

使用keys命令

keys如果您忘记了某个键的名称,或者您已经创建了一个键,但又意外误拼了它的名称,则该命令很有用。keys查找与模式匹配的键:

keys pattern

支持以下glob样式的变量

  • ?是通配符站在任何单个字符,这样s?mmy的比赛sammysommysqmmy
  • *是一个通配符,用来代表任何数量的字符,包括没有任何字符,所以sa*y比赛sammysaysammmmmmy,和salmony
  • 您可以通过将模式将其括在方括号中来指定模式可以包含的两个或多个字符,以s[ai]mmy匹配sammysimmy,但不能匹配summy
  • 要设置一个忽略一个或多个字母的通配符,请将其括在方括号中,并在其前面加上一个胡萝卜(^),这样s[^oi]mmy可以匹配sammysxmmy,但不能匹配sommysimmy
  • 要设置一个通配符,其中包括一系列的字母,范围的开头和结尾分开连字符和括号包起来,这样s[a-o]mmy将匹配sammyskmmysommy,但不srmmy

**警告:**本Redis的文件警告说,keys应该几乎从来没有在生产环境中使用,因为它可能会对性能产生重大的负面影响。

结论

本指南详细介绍了许多命令,这些命令可用于故障排除和解决与Redis一起使用时可能遇到的问题。如果您想在本指南中概述其他相关的命令,参数或过程,请在下面的评论中提出疑问或提出建议。

有关Redis命令的更多信息,请参阅关于如何管理Redis数据库的系列教程。

  1. 如何在ubuntu18.04上安装和保护redis
  2. 如何连接到Redis数据库
  3. 如何管理Redis数据库和Keys
  4. 如何在Redis中管理副本和客户端
  5. 如何在Redis中管理字符串
  6. 如何在Redis中管理list
  7. 如何在Redis中管理Hashes
  8. 如何在Redis中管理Sets
  9. 如何在Redis中管理Sorted Sets
  10. 如何在Redis中运行事务
  11. 如何使Redis中的Key失效
  12. 如何解决Redis中的故障
  13. 如何从命令行更改Redis的配置
  14. Redis数据类型简介 作者:分布式编程 出处:https://zthinker.com/ 如果你喜欢本文,请长按二维码,关注 分布式编程 .分布式编程

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
转载请注明出处: https://daima100.com/8401.html

(0)
上一篇 2023-02-28
下一篇 2023-02-28

相关推荐

  • 【巨杉数据库SequoiaDB】巨杉 Tech | SequoiaDB SQL实例高可用负载均衡实践[通俗易懂]

    【巨杉数据库SequoiaDB】巨杉 Tech | SequoiaDB SQL实例高可用负载均衡实践[通俗易懂]1 前言 在应用程序中,应用配置连接的数据库IP地址和端口号都是固定一个的,当所属IP地址的服务器宕机后,需要人为手工更改IP地址切换数据库服务器。同时当应用接收到成千上万的并发 http 请求时,…

    2023-02-09
    139
  • redis 存储之 redisObject[亲测有效]

    redis 存储之 redisObject[亲测有效]redisObject redis 是 key-value 存储系统,其中key类型一般为字符串,而 value 类型则为 redis 对象(redisObject)。Redis 对象可以绑定各种类型

    2023-03-13
    161
  • 计算机语言中的奇妙旋律——Python sin of 5

    计算机语言中的奇妙旋律——Python sin of 5Python语言中的sin()函数是计算给定角度的正弦值,而sin of 5则是指将角度设置为5度时的sin()值。Python中的sin()函数是math库中的函数,可以使用from math import sin来导入该函数。

    2024-03-16
    75
  • Python 字典:快速检索和存储数据

    Python 字典:快速检索和存储数据Python 开发人员熟知的数据类型之一是列表,但是如果需要使用键来存储和检索元素,列表就无法满足要求了。Python 中的字典是一个非常有用的数据结构,允许您使用键来存储和检索值。在本文中,我们将深入了解 Python 字典,其用法、优缺点和使用场景。

    2024-04-03
    72
  • 将Django模型转换为字典,方便数据处理

    将Django模型转换为字典,方便数据处理a href=”https://beian.miit.gov.cn/”苏ICP备2023018380号-1/a Copyright www.python100.com .Some Rights Reserved.

    2024-03-09
    74
  • 降低Python版本方法

    降低Python版本方法Python是一门功能强大而且可扩展性高的编程语言。但是,新版本的Python可能会导致旧有程序的不兼容问题,甚至可能阻碍开发和生产的进程。因此,降低Python版本是一个非常重要的问题。本文将介绍各种方法来降低Python版本,以及如何控制库和包的版本以确保代码的正常运行。

    2024-09-08
    27
  • 数据库发展史(上)

    数据库发展史(上)数据库技术是信息技术领域的核心技术之一,几乎所有的信息系统都需要使用数据库系统来组织、存储、操纵和管理业务数据。数据库领域也是现代计算机学科的重要分支和研究方向。目前,在数据库领域已经产生了四位图灵…

    2023-04-12
    160
  • 新特性解读 | mysql 8.0 memcached api 新特性[亲测有效]

    新特性解读 | mysql 8.0 memcached api 新特性[亲测有效]作者:杨涛涛 资深数据库专家,专研 MySQL 十余年。擅长 MySQL、PostgreSQL、MongoDB 等开源数据库相关的备份恢复、SQL 调优、监控运维、高可用架构设计等。目前任职于爱可生…

    2023-03-18
    155

发表回复

您的电子邮箱地址不会被公开。 必填项已用*标注