Redis 基础知识和核心概念解析:探索 Redis 的数据结构与存储方式

🌷🍁 博主 libin9iOak带您 Go to New World.✨🍁
🦄 个人主页——libin9iOak的博客🎐
🐳 《面试题大全》 文章图文并茂🦕生动形象🦖简单易学!欢迎大家来踩踩~🌺
🌊 《IDEA开发秘籍》学会IDEA常用操作,工作效率翻倍~💐
🪁🍁 希望本文能够给您带来一定的帮助🌸文章粗浅,敬请批评指正!🍁🐥

文章目录

  • Redis 基础知识和核心概念解析:探索 Redis 的数据结构与存储方式
    • 摘要:
    • 1. 引言
    • 2. Redis 的数据结构
      • 2.1 字符串(String)
      • 2.2 哈希表(Hash)
      • 2.3 列表(List)
      • 2.4 集合(Set)
      • 2.5 有序集合(Sorted Set)
    • 3. Redis 的键值操作
      • 3.1 添加键值对
      • 3.2 获取键值对
      • 3.3 更新键值对
      • 3.4 删除键值对
      • 3.5 键的命名规则和最佳实践
    • 4. Redis 的过期策略
      • 4.1 设置过期时间
      • 4.2 过期策略对内存使用的影响
      • 4.3 数据淘汰策略
      • 4.4 避免过期策略对数据的影响
    • 5. Redis 的持久化机制
      • 5.1 RDB(Redis Database Dump)
      • 5.2 AOF(Append-Only File)
      • 5.3 如何选择持久化方式
      • 5.4 持久化方式切换与恢复
    • 6. 实例演示:使用 Redis 的数据结构和存储方式
      • 6.1 使用字符串实现缓存功能
      • 6.2 使用列表实现计数器功能
      • 6.3 使用集合实现数据去重功能
      • 6.4 使用有序集合实现排行榜功能
    • 7. 结论
    • 8. 参考文献
  • 原创声明

在这里插入图片描述

Redis 基础知识和核心概念解析:探索 Redis 的数据结构与存储方式

摘要:

本博客旨在深入探讨 Redis 的基础知识和核心概念,重点解析其数据结构和存储方式。Redis是一个开源的高性能键值存储数据库,其将数据存储在内存中,因而具有出色的读写性能。通过本文,读者将全面了解 Redis 支持的各种数据结构,如字符串、哈希表、列表、集合和有序集合,并理解它们的特点、用途以及适用场景。此外,本文还介绍了 Redis 的键值操作,包括添加、获取、更新和删除键值对等基本操作,并讨论了键的命名规则和最佳实践,以及防止键名冲突的方法。我们将深入研究 Redis 的过期策略,探讨如何通过设置过期时间实现数据的自动过期,以及过期策略对内存使用和数据淘汰的影响,以避免内存泄漏和数据丢失。此外,我们还将介绍 Redis 的持久化机制,包括 RDB(Redis Database Dump)和 AOF(Append-Only File)两种方式,并对比它们的优缺点,以帮助读者选择合适的持久化方式。最后,通过实例演示,我们将展示如何使用 Redis 的不同数据结构来实现常见功能,如缓存、计数器和会话管理等,同时展示 Redis 的过期策略和持久化机制在实际项目中的应用。本文将总结 Redis 的基础知识和核心概念,强调数据结构和存储方式在 Redis 中的重要性,并强调深入理解 Redis 的数据结构和存储方式对于合理使用 Redis 数据库的必要性。

1. 引言

Redis是一种流行的开源高性能键值存储数据库,常被用作内存缓存、消息中间件和会话存储等场景。其特点包括快速的读写性能、丰富的数据结构和灵活的持久化机制。在本节中,我们将简要介绍 Redis,引出本篇博客的主题,即探索 Redis 的数据结构和存储方式,深入理解 Redis 的核心概念。

2. Redis 的数据结构

Redis作为一种灵活多样的开源高性能键值存储数据库,支持多种数据结构,每种结构都有其独特的特点和用途。在本节中,我们将深入介绍 Redis 支持的各种数据结构,包括字符串(String)、哈希表(Hash)、列表(List)、集合(Set)、有序集合(Sorted Set)等。通过对比不同数据结构的特点和适用场景,我们将帮助读者选择合适的数据结构,从而提高应用的性能和效率。

2.1 字符串(String)

字符串是 Redis 最基本的数据结构之一,它可以存储任何类型的数据,包括文本、数字和二进制数据等。Redis 的字符串是动态字符串,支持多种操作,如设置、获取和更新值,以及对字符串进行追加、截取等操作。字符串数据结构在很多场景下都非常有用,比如缓存数据、计数器、分布式锁等。

2.2 哈希表(Hash)

哈希表是一种键值对的集合,类似于其他编程语言中的字典或关联数组。在 Redis 中,哈希表的键和值都是字符串类型的,哈希表可以存储多个键值对,并支持对单个键值对进行操作。哈希表适用于存储对象或记录,例如用户信息、商品信息等,便于快速访问和更新特定字段。

2.3 列表(List)

列表是一个有序的字符串元素集合,可以在列表的两端执行添加和删除操作。Redis 的列表是双向链表实现的,因此在两端执行操作的时间复杂度是 O(1)。列表数据结构适用于实现队列、栈、消息队列等功能,也可以用于存储最新的一些数据记录。

2.4 集合(Set)

集合是一种无序、唯一且不重复的字符串元素集合。Redis 的集合数据结构可以对集合进行添加、删除、查找等操作,并且支持交集、并集、差集等集合运算。集合适用于去重、共同好友、共同兴趣爱好等场景。

2.5 有序集合(Sorted Set)

有序集合是集合的扩展,每个元素都关联一个分数(score),使得集合中的元素可以按照分数进行排序。有序集合的实现使用了跳跃表和哈希表,因此在有序集合中添加、删除、查找等操作的时间复杂度是 O(log(N))。有序集合适用于排行榜、计分系统、范围查找等场景。

通过深入了解 Redis 的各种数据结构,读者可以根据应用的实际需求,选择合适的数据结构,从而充分发挥 Redis 在性能和功能方面的优势。接下来,我们将进一步探讨 Redis 的键值操作,帮助读者更好地理解如何与 Redis 进行交互。

3. Redis 的键值操作

Redis是一个键值存储数据库,数据以键值对的形式进行存储和访问。在本节中,我们将详细解释 Redis 中的键值操作,包括添加键值对、获取键值对、更新键值对和删除键值对等基本操作。了解这些操作将帮助您更好地使用 Redis 并充分发挥其优势。

3.1 添加键值对

在 Redis 中,添加键值对是通过使用 SET 命令完成的。SET 命令可以设置一个键的值,并将其保存在 Redis 数据库中。例如,以下命令将名为 “username” 的键设置为 “john_doe” 的值:

SET username john_doe

3.2 获取键值对

获取键值对的操作主要使用 GET 命令。GET 命令可以获取键的值。继续以上面示例中的键 “username” 为例,可以通过以下命令获取其值:

GET username

该命令将返回键 “username” 的值,即 “john_doe”。

3.3 更新键值对

要更新 Redis 中的键值对,可以使用 SET 命令,其行为类似于添加键值对的操作。如果键已存在,SET 命令将覆盖原有的值。例如,以下命令将更新名为 “username” 的键的值为 “jane_smith”:

SET username jane_smith

现在,键 “username” 的值将从 “john_doe” 更新为 “jane_smith”。

3.4 删除键值对

删除 Redis 中的键值对可以使用 DEL 命令。DEL 命令接受一个或多个键作为参数,并从数据库中永久删除这些键及其对应的值。例如,以下命令将删除名为 “username” 的键及其值:

DEL username

键 “username” 及其对应的值将从 Redis 数据库中被移除。

3.5 键的命名规则和最佳实践

在使用 Redis 时,为了保证应用的稳定运行和易于维护,我们需要遵守一些键的命名规则和最佳实践:

  • 命名规则:键的命名应该具有唯一性、描述性,并避免使用特殊字符和空格。建议使用有意义的前缀来区分不同类型的键,以提高键的可读性和管理性。

  • 命名空间:使用命名空间可以有效地隔离不同部分的键,避免键名冲突。例如,为用户信息使用 “user:1”、“user:2”,为商品信息使用 “product:1”、"product:2"等。

  • 过期时间:对于临时数据或缓存数据,建议设置适当的过期时间,以避免数据长时间滞留在内存中,造成内存浪费。

  • 删除策略:在删除键值对时,需要谨慎考虑其影响范围。确保删除操作不会影响其他相关数据的正确性和完整性。

遵守上述最佳实践有助于保持 Redis 数据库的良好状态,提高系统的性能和可维护性。

通过了解 Redis 的键值操作以及键的命名规则和最佳实践,您将能够更加熟练地使用 Redis 来管理数据,并确保应用在键值存储方面的稳定运行。接下来,我们将探讨 Redis 的过期策略,了解如何自动管理数据的过期与淘汰。

4. Redis 的过期策略

在 Redis 中,过期策略是一项重要的功能,允许为键设置过期时间,从而使数据在特定时间自动过期。这对于管理临时数据、缓存和会话等具有时效性的数据非常有用。在本节中,我们将详细解释 Redis 如何通过设置过期时间来实现数据的自动过期,以及如何避免过期策略对内存使用和数据淘汰的影响,从而防止出现内存泄漏和数据丢失的问题。

4.1 设置过期时间

在 Redis 中,可以使用 EXPIRE 命令为键设置过期时间。EXPIRE 命令接受两个参数:键和过期时间(以秒为单位)。例如,以下命令将名为 “session_id” 的键设置过期时间为 3600 秒(1 小时):

EXPIRE session_id 3600

经过 3600 秒后,如果再尝试获取该键的值,将返回空值,表示该键已过期并自动删除。

4.2 过期策略对内存使用的影响

设置过期时间可以使 Redis 自动删除过期的键值对,从而释放内存空间。这对于管理大量具有时效性的数据非常有用,可以避免数据长时间滞留在内存中导致内存占用过高的问题。

4.3 数据淘汰策略

当 Redis 的内存使用达到上限时,为了继续接收新数据,需要删除部分键值对。这时,Redis 会采取数据淘汰策略来删除哪些键值对。Redis 提供了多种数据淘汰策略,常见的有:

  • LRU(Least Recently Used):删除最近最少使用的键值对。
  • LFU(Least Frequently Used):删除最不经常使用的键值对。
  • TTL(Time To Live):删除剩余过期时间最短的键值对。

可以通过配置文件或在运行时动态修改 Redis 的数据淘汰策略。

4.4 避免过期策略对数据的影响

在使用过期策略时,需要注意以下几点,以避免对数据产生不良影响:

  • 合理设置过期时间:设置过期时间应该根据实际业务需求,确保数据在需要的时间内存在,并尽快释放不再需要的数据。

  • 考虑数据的访问频率:对于频繁访问的数据,可以适当延长过期时间或者采用其他缓存机制,以减少频繁的数据过期和重新加载。

  • 注意过期时间的一致性:如果多个键之间存在关联,需要确保它们的过期时间一致,以避免数据不一致的情况。

  • 使用惰性删除:Redis 使用惰性删除机制,即键过期后,并不会立即删除,而是在有请求访问该键时,才会进行删除操作。这样可以减少删除操作的频率,提高性能。

通过合理设置过期时间和淘汰策略,并遵循上述最佳实践,可以确保 Redis 的过期策略对数据的管理更加高效和安全。

在接下来的部分,我们将探讨 Redis 的持久化机制,了解如何保障数据在断电或异常情况下的安全性。

5. Redis 的持久化机制

为了确保在断电或异常情况下不丢失数据,Redis 提供了持久化机制,可以将数据保存到硬盘上。持久化机制是保障数据安全的重要手段,可以在 Redis 重启后将数据恢复到上一次持久化的状态。在本节中,我们将介绍 Redis 的两种主要持久化方式:RDB(Redis Database Dump)和 AOF(Append-Only File),并对比它们的优缺点,帮助读者选择合适的持久化方式来满足应用的数据安全需求。

5.1 RDB(Redis Database Dump)

RDB 是 Redis 的一种快照持久化方式。当满足一定条件时,Redis 将数据库中的数据以二进制形式保存到硬盘上的 RDB 文件中。RDB 文件是 Redis 数据在某个时间点上的完整快照,可以通过加载 RDB 文件来恢复 Redis 的数据。

优点

  • RDB 方式适合用于备份和全量数据恢复,因为 RDB 文件包含了完整的数据状态。
  • RDB 方式对于 Redis 的性能影响较小,适合在生产环境中使用。

缺点

  • RDB 文件是全量数据,如果数据很大,生成 RDB 文件的过程可能会导致 Redis 的阻塞。
  • RDB 方式并不是实时持久化,数据会在一段时间间隔后进行持久化,因此在持久化间隔内可能会丢失部分数据。

5.2 AOF(Append-Only File)

AOF 是 Redis 的另一种持久化方式,它以追加的方式将 Redis 执行的写命令追加到一个只写文件(Append-Only File)中。通过回放 AOF 文件中的命令,可以重新构建出完整的数据状态。

优点

  • AOF 方式可以提供更高的数据安全性,因为它是通过追加写命令的方式记录数据的变化,数据更新操作都会被记录下来。
  • AOF 文件是一个日志文件,可以通过配置来设置不同的同步频率,确保数据的实时持久化。

缺点

  • AOF 文件通常比 RDB 文件更大,因为它记录了每次数据更新的操作,可能会占用更多的磁盘空间。
  • AOF 文件回放数据的过程相对于加载 RDB 文件较慢,这可能会导致 Redis 启动时间较长。

5.3 如何选择持久化方式

选择合适的持久化方式需要根据实际需求和业务场景来决定:

  • 如果对于数据的实时性要求较高,可以选择 AOF 方式,以确保数据的实时持久化和安全性。
  • 如果对于数据的恢复速度要求较高,或者数据量较大,可以选择 RDB 方式,以减少 Redis 启动时间和占用的磁盘空间。
  • 也可以同时使用 RDB 和 AOF 的方式,以提供更高的数据安全性和灵活性。

在配置持久化方式时,需要谨慎选择合适的同步频率,以平衡数据安全性和性能。

5.4 持久化方式切换与恢复

Redis 允许在运行过程中切换持久化方式,例如从 RDB 切换到 AOF,或者从 AOF 切换到 RDB。同时,可以根据需要在启动时加载 RDB 文件或者回放 AOF 文件来恢复数据。

为了确保数据的安全和完整性,切换持久化方式和恢复数据时需要注意备份原有的持久化文件,以防止意外数据丢失。

通过了解 Redis 的持久化机制,您可以根据应用的实际需求选择合适的持久化方式,以保障数据的安全性,并在 Redis 的运维过程中灵活运用持久化功能。接下来,我们将通过实例演示,展示 Redis 的数据结构和存储方式在实际项目中的应用。

6. 实例演示:使用 Redis 的数据结构和存储方式

在本节中,我们将通过实际代码演示,展示如何使用 Redis 的不同数据结构来实现常见功能。Redis 提供了多种数据结构,包括字符串、哈希表、列表、集合和有序集合,它们各自具有不同的特点和用途。我们将分别演示如何利用这些数据结构来实现以下功能:

6.1 使用字符串实现缓存功能

首先,我们将展示如何使用 Redis 的字符串数据结构来实现简单的缓存功能。假设我们有一个需要频繁计算的函数,我们可以将计算结果存储在 Redis 中,并设置适当的过期时间,从而避免重复计算。

import redis# 连接 Redis 服务器
redis_client = redis.StrictRedis(host='localhost', port=6379, db=0)# 定义需要缓存的函数
def expensive_function(arg):# 此处模拟耗时计算result = arg * 2return resultdef cached_function(arg):# 尝试从缓存中获取计算结果cached_result = redis_client.get(f'cache:{arg}')if cached_result:return int(cached_result)else:# 如果缓存中没有结果,则进行计算,并存储到缓存中result = expensive_function(arg)redis_client.setex(f'cache:{arg}', 60, result)  # 设置过期时间为 60 秒return result# 示例使用
result1 = cached_function(5)  # 首次计算并缓存
print(result1)  # 输出:10result2 = cached_function(5)  # 从缓存中获取
print(result2)  # 输出:10

6.2 使用列表实现计数器功能

接下来,我们将展示如何使用 Redis 的列表数据结构来实现计数器功能。假设我们有一个网站,需要统计每天的访问量,我们可以使用 Redis 的列表来记录每次访问的时间戳,并定时清理过期数据。

import redis
import time# 连接 Redis 服务器
redis_client = redis.StrictRedis(host='localhost', port=6379, db=0)def record_daily_visits():# 获取当前时间戳timestamp = int(time.time())# 将时间戳添加到列表的右侧redis_client.rpush('daily_visits', timestamp)def get_daily_visits():# 获取列表的长度,即访问量visits = redis_client.llen('daily_visits')return visits# 示例使用
record_daily_visits()  # 记录访问
record_daily_visits()  # 记录访问visits = get_daily_visits()  # 获取访问量
print(visits)  # 输出:2

6.3 使用集合实现数据去重功能

然后,我们将展示如何使用 Redis 的集合数据结构来实现数据去重功能。假设我们有一个应用,需要去重用户提交的数据,我们可以使用 Redis 的集合来确保每条数据只保存一次。

import redis# 连接 Redis 服务器
redis_client = redis.StrictRedis(host='localhost', port=6379, db=0)def save_data(data):# 将数据添加到集合中,确保不重复redis_client.sadd('unique_data', data)def get_unique_data():# 获取集合中的所有数据unique_data = redis_client.smembers('unique_data')return unique_data# 示例使用
save_data('data1')  # 保存数据
save_data('data2')  # 保存数据
save_data('data1')  # 保存数据,但已存在于集合中,不会重复保存unique_data = get_unique_data()  # 获取去重后的数据
print(unique_data)  # 输出:{'data1', 'data2'}

6.4 使用有序集合实现排行榜功能

最后,我们将展示如何使用 Redis 的有序集合数据结构来实现排行榜功能。假设我们有一个应用,需要统计用户的得分,并展示排行榜,我们可以使用 Redis 的有序集合来记录用户的得分,并根据得分进行排序。

import redis# 连接 Redis 服务器
redis_client = redis.StrictRedis(host='localhost', port=6379, db=0)def record_score(user, score):# 将用户得分添加到有序集合中redis_client.zadd('scores', {user: score})def get_leaderboard():# 获取排行榜,按得分从高到低排序leaderboard = redis_client.zrevrange('scores', 0, -1, withscores=True)return leaderboard# 示例使用
record_score('user1', 100)  # 记录得分
record_score('user2', 150)  # 记录得分
record_score('user3', 120)  # 记录得分leaderboard = get_leaderboard()  # 获取排行榜
print(leaderboard)  # 输出:[('user2', 150.0), ('user3', 120.0), ('user1', 100.0)]

通过这些实例演示,您可以深入了解 Redis 的数据结构和存储方式在实际项目中的应用场景。合理选择合适的数据结构和存储方式,将有助于提高应用性能,并确保数据的安全性和完整性。在实际项目中,您可以根据具体需求灵活运用 Redis 提供的功能,发挥其强大的数据处理能力。接下来,我们将进行结论,总结 Redis 的基础知识和核心概念,并强调深入理解 Redis 的数据结构和存储方式对于合理使用 Redis 数据库的必要性。

7. 结论

本篇博客深入探讨了 Redis 的基础知识和核心概念,涵盖了 Redis 支持的各种数据结构、键值操作、过期策略和持久化机制。通过学习本文,读者应该对 Redis 的功能和用途有了全面的了解,并能够在实际项目中灵活运用 Redis 来满足各种需求。

我们重点强调了 Redis 的数据结构和存储方式在应用中的重要性。合理选择数据结构和存储方式可以大大提高应用的性能和效率。例如,使用字符串来实现缓存功能可以避免重复计算,使用有序集合来实现排行榜可以实现快速的排名查询。

此外,我们还介绍了 Redis 的过期策略和持久化机制,它们是确保数据安全的重要手段。设置合理的过期时间和选择适合的持久化方式可以保障数据在断电或异常情况下的安全性。

最后,我们强调了深入理解 Redis 的数据结构和存储方式对于合理使用 Redis 数据库的必要性。通过熟练掌握 Redis 提供的各种数据结构和功能,读者可以更好地利用 Redis 来优化应用性能、提高数据处理效率,并确保数据的安全和稳定运行。

希望本篇博客能够为读者提供有价值的知识,使您在实际项目中更加自信地运用 Redis,发挥其强大的功能和优势。如果读者有任何疑问或需要进一步了解,可以参考下面的参考文献,深入学习 Redis 的更多细节。谢谢阅读!

8. 参考文献

  1. Redis 官方网站:https://redis.io/documentation

    • Redis 官方文档提供了全面的关于 Redis 的详细说明和使用指南,包括命令参考和配置说明等内容,是深入了解 Redis 的权威来源。
  2. Redis 数据结构详解 - 简书:https://www.jianshu.com/p/cd8f07df6e2d

    • 这篇文章对 Redis 支持的各种数据结构进行了详细解释和示例演示,有助于理解不同数据结构的特点和用途。
  3. Redis 过期策略与内存淘汰策略 - SegmentFault:https://segmentfault.com/a/1190000013487247

    • 本文深入解析了 Redis 的过期策略以及如何设置合理的内存淘汰策略,帮助您避免内存泄漏和数据丢失问题。
  4. Redis 持久化解析 - 博客园:https://www.cnblogs.com/chenzhaomin/p/11598607.html

    • 这篇文章对 Redis 的持久化机制进行了详细解释,涵盖了 RDB 和 AOF 两种方式的原理和应用场景。
  5. Redis 源码解读 - GitHub:https://github.com/huangz1990/annotated_redis_source

    • 如果您对 Redis 源码感兴趣,这个 GitHub 仓库提供了 Redis 源码的注释和解读,有助于更深入地理解 Redis 的内部实现原理。
  6. Redis 实战 - 朱凯的博客:https://zhu-kai.blog.csdn.net/article/details/79420347

    • 这篇博客中提供了 Redis 的实战应用案例,包括如何使用不同数据结构来解决实际问题,对于实际项目中的应用有很好的参考价值。

希望本文对读者深入了解 Redis 的基础知识和核心概念,探索其数据结构和存储方式有所帮助。让我们开始这次关于 Redis 的探索之旅吧!

原创声明

======= ·

  • 原创作者: 猫头虎

作者wx: [ libin9iOak ]


本文为原创文章,版权归作者所有。未经许可,禁止转载、复制或引用。

作者保证信息真实可靠,但不对准确性和完整性承担责任

未经许可,禁止商业用途。

如有疑问或建议,请联系作者。

感谢您的支持与尊重。

点击下方名片,加入IT技术核心学习团队。一起探索科技的未来,共同成长。

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

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

相关文章

Python-Go python模块与包 - GO问题 - GO容量测试

目录 go 模块与包复习(Init函数 - go mod) init函数有什么用?init函数是什么? go.mod文件是什么?有什么作用? python的模块与包 python中包的分类 1、内置模块:不需要安装,直接…

前端工作中常用 CSS 知识点整理

1.1文字溢出省略号 文字单行溢出: overflow: hidden; // 溢出隐藏 text-overflow: ellipsis; // 溢出用省略号显示 white-space: nowrap; // 规定段落中的文本不进行换行 多行文字溢出: overflow: hidden; // 溢出隐藏 text-overflow: …

Java电子招投标采购系统源码-适合于招标代理、政府采购、企业采购

功能描述 1、门户管理:所有用户可在门户页面查看所有的公告信息及相关的通知信息。主要板块包含:招标公告、非招标公告、系统通知、政策法规。 2、立项管理:企业用户可对需要采购的项目进行立项申请,并提交审批,查看…

【简单认识MySQL主从复制与读写分离】

文章目录 一、MySQL主从复制1、配置主从复制的原因:2、主从复制原理1、 MySQL的复制类型2、 MySQL主从复制的工作过程;1、 MySQL主从复制延迟2、优化方案:3、 MySQL 有几种同步方式: 三种4、异步复制(Async Replication&#xff0…

【宝藏系列】20个常用的Python技巧

【宝藏系列】20个常用的Python技巧 文章目录 【宝藏系列】20个常用的Python技巧🍉文末推荐【Python之光】 Python的可读性和简单性是其广受欢迎的两大原因,本文介绍20个常用的Python技巧来提高代码的可读性,并能帮助你节省大量时间&#xff0…

springboot整合ELK+kafka采集日志

一、背景介绍 在分布式的项目中,各功能模块产生的日志比较分散,同时为满足性能要求,同一个微服务会集群化部署,当某一次业务报错后,如果不能确定产生的节点,那么只能逐个节点去查看日志文件;lo…

工业自动化数据485采集网关支持modbus协议

S475/S475E系列是一种功能丰富的设备,支持多种通信方式和输入输出功能。以下是对其功能的详细介绍: 通信方式: S475/S475E系列支持多种通信方式,包括短信、RS485、语音拨号、GPRS/3G/4G无线数据网络四种告警方式。这意味着用户可…

AXI协议之AXILite开发设计(二)

微信公众号上线,搜索公众号小灰灰的FPGA,关注可获取相关源码,定期更新有关FPGA的项目以及开源项目源码,包括但不限于各类检测芯片驱动、低速接口驱动、高速接口驱动、数据信号处理、图像处理以及AXI总线等 二、AXI-Lite关键代码分析 1、时钟与…

营销系统积分数据库设计

营销系统总体数据-业务功能模型 在当今日益竞争的市场中,如何提高客户留存率和忠诚度,已成为各大企业迫切需要解决的问题。而积分商城/系统作为一种新型的营销方式,受到青睐。 积分商城/系统是指将用户在使用产品或服务时产生的积分&#xf…

X - Transformer

回顾 Transformer 的发展 Transformer 最初是作为机器翻译的序列到序列模型提出的,而后来的研究表明,基于 Transformer 的预训练模型(PTM) 在各项任务中都有最优的表现。因此,Transformer 已成为 NLP 领域的首选架构&…

mac m1 触控栏TouchBar功能栏异常

电脑可能在高温下运行时间过长,导致TouchBar之前正常显示的调整屏幕亮度与调整声音等功能的按钮均丢失,然后看了一眼键盘设置,设置也是正常的,已勾选显示功能栏 下面请看 如何在MacBook Pro(macOS Monterey&#xff0…

基于Java+SpringBoot+vue前后端分离社区医院信息平台设计实现

博主介绍:✌全网粉丝30W,csdn特邀作者、博客专家、CSDN新星计划导师、Java领域优质创作者,博客之星、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java技术领域和毕业项目实战✌ 🍅文末获取源码联系🍅 👇🏻 精彩专…

【C++】智能指针

文章目录 1. 为什么需要智能指针?2. 智能指针的使用智能指针的常见问题1.使用对象的生命周期去控制资源2. 像指针一样使用3. 拷贝问题auto_ptr ——管理权转移unique_ptr ——防拷贝C98版本C11版本 shared_ptr (根本解决拷贝问题)赋值代码实现 weak_ptr —— 循环引…

RocketMQ教程-(4)-领域模型-消费者(Consumer)

本文介绍 Apache RocketMQ 中消费者(Consumer)的定义、模型关系、内部属性、行为约束、版本兼容性及使用建议。 定义​ 消费者是 Apache RocketMQ 中用来接收并处理消息的运行实体。 消费者通常被集成在业务系统中,从 Apache RocketMQ 服务…

【JVM】详解对象的创建过程

文章目录 1、创建对像的几种方式1、new关键字2、反射3、clone4、反序列化 2、创建过程步骤 1、检查类是否已经被加载步骤 2、 为对象分配内存空间1、指针碰撞针对指针碰撞线程不安全,有两种方案: 2、空闲列表选择哪种分配方式 步骤3、将内存空间初始化为…

如何在armv6 armv7 armv8(aarch64)嵌入式板子上面安装nginx服务器,支持H265码流

如何在armv6 armv6 armv8 aarch64 嵌入式板子上面安装nginx服务器支持推送H265的视频流 开始吧 一,准备工作二,configure时遇到的出错问题1、checking for C compiler … found but is not working2,error: can not detect int size3&#xf…

【博客682】k8s apiserver bookmarks机制以更高效检测变更

k8s apiserver bookmarks机制以更高效检测变更 list-watch背景: List-Watch 是kubernetes中server和client通信的最核心的机制, 比如说api-server监听etcd, kubelet监听api-server, scheduler监听api-server等等,其实…

Jmeter场景设置与监听

Jmeter场景设置 场景的概念: 场景是用来尽量真实模拟用户操作的工作单元,场景设计源自于用户真实操作。 场景设计: 场景设计是根据收集分析用户的实际操作而定义的Jmeter脚本的执行策略。 性能测试中涉及的基本场景有两种,即单一业务场景和混合业务场景…

链表是否有环、环长度、环起点

问题引入 如何检测一个链表是否有环,如果有,那么如何确定环的长度及起点。 引自博客:上述问题是一个经典问题,经常会在面试中被问到。我之前在杭州一家网络公司的电话面试中就很不巧的问到,当时是第一次遇到那个问题&…

RocketMQ集群4.9.2升级4.9.6版本

本文主要记录生产环境短暂停机升级RocketMQ版本的过程 一、整体思路 1.将生产环境MQ4.9.2集群同步到测试环境,并启动,确保正常运行。 2.参照4.9.2配置4.9.6集群 3.停掉4.9.2集群,启动4.9.6集群,测试确保正常运行。 4.停掉4.9.6集…