RabbitMQ 教程 | 第11章 RabbitMQ 扩展

👨🏻‍💻 热爱摄影的程序员
👨🏻‍🎨 喜欢编码的设计师
🧕🏻 擅长设计的剪辑师
🧑🏻‍🏫 一位高冷无情的编码爱好者
大家好,我是 DevOps 工程师
欢迎分享 / 收藏 / 赞 / 在看!

这篇 RabbitMQ 教程为学习者提供了全面的内容,从 RabbitMQ 的简介开始,涵盖了消息中间件的概念、RabbitMQ 的安装与使用,以及交换机、队列、路由键等相关概念的介绍。进一步深入,教程探讨了 AMQP 协议、客户端开发向导,以及消息的发送和消费方式。同时,学习者还可以了解消息传输保障、高级特性如死信队列、延迟队列、优先级队列、RPC 实现等。此外,教程还涵盖了 RabbitMQ 的管理、配置、运维、监控和集群管理等重要主题,帮助学习者充分掌握 RabbitMQ 的应用。整篇教程丰富内容详实,适合初学者和有经验的开发者参考学习。

全篇共 11 章,9 万余字。本文:第11章 RabbitMQ 扩展。

第11章 RabbitMQ 扩展

11.1 消息追踪

了解如何对 RabbitMQ 中的消息进行追踪和监控,以便进行可靠性检测和问题排查。

11.1.1 Firehose

Firehose 插件是 RabbitMQ 提供的一个插件,它允许将消息传递日志导出到外部系统进行分析和监控。通过 Firehose,您可以将消息传递过程中的各种事件、指标和数据导出到指定的外部系统,如 Elasticsearch、Logstash 等,以便进行实时监控、数据分析和性能优化。

使用 Firehose 插件的步骤:

  1. 安装 Firehose 插件: 首先需要在 RabbitMQ 服务器上安装 Firehose 插件。可以通过 RabbitMQ 的插件管理工具来安装插件,或者手动下载插件文件进行安装。
  2. 配置 Firehose 插件: 安装完插件后,需要对 Firehose 进行配置,以指定数据的输出目的地。通常需要配置导出数据的外部系统的连接信息,如 Elasticsearch 的地址、用户名、密码等。
  3. 启用 Firehose 插件: 配置完成后,需要在 RabbitMQ 中启用 Firehose 插件。通过启用插件,RabbitMQ 将会把消息传递日志数据导出到配置的外部系统。
  4. 监控和分析: 一旦 Firehose 插件启用成功,RabbitMQ 将开始将消息传递日志数据导出到指定的外部系统。在外部系统中,您可以使用各种监控和分析工具来实时监控消息的传递状态、性能指标等,并进行数据分析和优化。

Firehose 插件的优势:

  • 实时监控: Firehose 允许实时地将消息传递日志导出到外部系统,使您能够及时监控 RabbitMQ 集群的运行状态和性能。
  • 灵活性: 通过配置 Firehose 插件,您可以选择导出的日志内容和指标,以满足特定的监控和分析需求。
  • 集成性: Firehose 插件支持导出数据到多种外部系统,如 Elasticsearch、Logstash 等,使其与现有的监控和分析平台无缝集成。
  • 性能优化: 通过监控和分析导出的日志数据,您可以发现潜在的性能瓶颈和问题,并对 RabbitMQ 进行优化。

注意事项:

  • 在配置 Firehose 插件时,需要确保外部系统的连接信息正确,以保证数据能够正确地导出到指定的目的地。
  • 导出的日志数据可能会产生较大的数据量,因此需要确保外部系统的存储和性能能够满足需求。
  • 在使用 Firehose 插件时,需要谨慎处理敏感信息,以确保数据的安全性。

总的来说,Firehose 插件是 RabbitMQ 提供的一个强大的工具,通过它可以将消息传递日志导出到外部系统,帮助您实时监控和分析 RabbitMQ 集群的性能,从而优化消息传递过程和提高系统的稳定性和可靠性。

11.1.2 rabbitmq_tracing 插件

rabbitmq_tracing 插件是 RabbitMQ 提供的一个插件,它允许您在 RabbitMQ 中对消息进行追踪和监控。通过 rabbitmq_tracing 插件,您可以捕获消息在 RabbitMQ 中的生命周期事件,包括消息的发布、路由、投递等过程,以及在不同组件之间的传递情况。这些追踪数据可以帮助您了解消息传递的整个流程,诊断潜在的问题,并优化系统性能。

使用 rabbitmq_tracing 插件的步骤:

  1. 安装 rabbitmq_tracing 插件: 首先需要在 RabbitMQ 服务器上安装 rabbitmq_tracing 插件。可以通过 RabbitMQ 的插件管理工具来安装插件,或者手动下载插件文件进行安装。
  2. 配置 rabbitmq_tracing 插件: 安装完插件后,您可以通过 RabbitMQ 的管理界面或命令行来配置 rabbitmq_tracing 插件。可以设置追踪规则,即指定哪些消息或者组件需要进行追踪。
  3. 启用 rabbitmq_tracing 插件: 配置完成后,需要在 RabbitMQ 中启用 rabbitmq_tracing 插件。通过启用插件,RabbitMQ 将会开始对指定的消息和组件进行追踪。
  4. 监控和分析: 一旦 rabbitmq_tracing 插件启用成功,RabbitMQ 将开始捕获指定消息的追踪数据。您可以通过 RabbitMQ 的管理界面或命令行来查看这些追踪数据,或者将数据导出到外部系统进行进一步的监控和分析。

rabbitmq_tracing 插件的优势:

  • 全面追踪: rabbitmq_tracing 插件可以对消息传递的各个环节进行追踪,包括消息的发布、路由、投递等过程,帮助您全面了解消息在 RabbitMQ 中的行为。
  • 细粒度控制: 您可以通过配置追踪规则,指定哪些消息或者组件需要进行追踪,使得您可以根据需求对追踪的数据进行细粒度的控制。
  • 诊断问题: 通过查看追踪数据,您可以发现潜在的问题和瓶颈,帮助您更快地诊断和解决消息传递中的问题。
  • 性能优化: 追踪数据可以帮助您了解系统的性能状况,从而优化消息传递过程,提高系统的吞吐量和稳定性。

注意事项:

  • 在配置 rabbitmq_tracing 插件时,需要谨慎选择追踪规则,避免过多的追踪数据导致性能下降。
  • 追踪数据可能会产生较大的数据量,因此需要确保外部系统的存储和性能能够满足需求。
  • 在使用 rabbitmq_tracing 插件时,需要考虑数据的隐私和安全性,避免敏感信息被泄露。

总的来说,rabbitmq_tracing 插件是一个强大的工具,可以帮助您实现对消息的追踪和监控,从而更好地了解消息传递的整个过程,诊断问题,优化系统性能,提高 RabbitMQ 集群的稳定性和可靠性。

11.1.3 案例:可靠性检测

假设我们有一个使用 RabbitMQ 的分布式系统,其中包含多个服务,这些服务之间通过 RabbitMQ 进行消息通信。我们希望使用消息追踪特性来检测系统的可靠性,确保消息在系统中的传递是稳定和可靠的。

在这个案例中,我们将使用 rabbitmq_tracing 插件来追踪消息,并对消息传递过程中的一些关键事件进行监控和分析。具体步骤如下:

  1. 安装和配置 rabbitmq_tracing 插件: 首先,我们需要在 RabbitMQ 服务器上安装 rabbitmq_tracing 插件,并配置追踪规则。我们可以设置追踪规则,对特定的消息和组件进行追踪。
  2. 启用 rabbitmq_tracing 插件: 配置完成后,需要在 RabbitMQ 中启用 rabbitmq_tracing 插件,使其开始对指定的消息和组件进行追踪。
  3. 定义监控指标: 我们可以定义一些监控指标,用来衡量系统的可靠性。例如,可以监控消息的投递成功率、消息的投递时间、队列中消息的积压情况等。
  4. 收集追踪数据: 一旦 rabbitmq_tracing 插件启用成功,RabbitMQ 将开始捕获指定消息的追踪数据。我们可以定期收集这些数据,并将其存储到外部系统中,用于后续的分析和监控。
  5. 分析追踪数据: 收集到的追踪数据可以帮助我们了解消息传递的整个流程。我们可以通过分析追踪数据,发现潜在的问题和瓶颈,比如消息投递失败、消息堆积、消息丢失等。
  6. 发现并解决问题: 通过分析追踪数据,我们可以发现系统的可靠性问题,并采取相应的措施来解决这些问题。例如,可以增加消息的重试机制、增加队列的容量、优化消息的路由等。
  7. 持续监控: 可靠性检测是一个持续的过程,我们需要定期收集和分析追踪数据,不断优化系统,以确保系统的可靠性和稳定性。

总结:通过使用消息追踪特性,我们可以对消息在 RabbitMQ 中的传递过程进行全面的监控和分析,从而确保系统的可靠性。追踪数据可以帮助我们发现潜在的问题,并采取措施来优化系统性能和稳定性。通过持续监控和优化,我们可以不断提高系统的可靠性,确保消息在系统中的传递是稳定和可靠的。

11.2 负载均衡

了解如何在 RabbitMQ 集群中实现负载均衡,以确保集群的高可用性和稳定性。

11.2.1 客户端内部实现负载均衡

在 RabbitMQ 客户端内部实现负载均衡可以帮助分摊消息处理的压力,从而提高消息处理的效率和性能。负载均衡的目标是将消息均匀地分发给多个消费者,确保每个消费者都能处理大致相同数量的消息,从而避免出现消息处理的不均衡现象。

下面介绍如何在 RabbitMQ 客户端内部实现负载均衡:

  1. 创建多个消费者: 首先,我们需要创建多个消费者实例,每个消费者实例对应一个消费者。这些消费者实例可以运行在不同的线程或进程中,也可以部署在不同的服务器上。
  2. 使用订阅模式: 在 RabbitMQ 中,可以使用订阅模式(Subscription Model)来实现负载均衡。订阅模式中,每个消费者都会订阅一个队列,并通过消费者标签(Consumer Tag)进行标识。
  3. 设置消费者数量限制: 可以通过配置参数来设置每个队列允许的最大消费者数量。这样可以确保每个队列的消息能够被均匀地分发给多个消费者。
  4. 使用轮询算法: 在实现负载均衡时,常用的方法是使用轮询算法(Round-Robin)来决定消息分发的顺序。轮询算法简单高效,每次将消息依次分发给不同的消费者,实现了基本的负载均衡。
  5. 消费者优先级: 在一些特殊情况下,我们可以为消费者设置优先级,让某些消费者处理更重要的消息,从而实现更细粒度的负载均衡。
  6. 消息预取(Prefetch): RabbitMQ 支持预取(Prefetch)机制,可以设置每个消费者能够预取(Prefetch)的消息数量。通过合理设置预取数量,可以避免某个消费者在处理过程中堆积过多的消息,从而保持负载均衡。

总结:通过在 RabbitMQ 客户端内部创建多个消费者,并使用订阅模式和轮询算法,我们可以实现负载均衡,将消息均匀地分发给多个消费者,从而分摊消息处理的压力,提高消息处理的效率和性能。负载均衡是一个重要的技术,特别是在大规模的分布式系统中,通过合理配置和优化,可以实现高吞吐量和低延迟的消息处理。

11.2.2 使用 HAProxy 实现负载均衡

通过 HAProxy 可以实现 RabbitMQ 集群的负载均衡,将客户端的请求均匀地分发给不同的 RabbitMQ 节点,从而实现高可用和高吞吐量的消息处理。下面介绍如何通过 HAProxy 实现 RabbitMQ 集群的负载均衡:

  1. 安装和配置 HAProxy: 首先需要在一台服务器上安装和配置 HAProxy。可以使用适合自己操作系统的包管理工具进行安装,并修改 HAProxy 的配置文件(一般是位于 /etc/haproxy/haproxy.cfg)。
  2. 配置后端 RabbitMQ 节点: 在 HAProxy 的配置文件中,配置后端 RabbitMQ 节点的信息。指定每个节点的 IP 地址和端口号,以及使用的协议。可以使用 server 关键字来定义每个节点,例如:
backend rabbitmq_nodesserver node1 192.168.1.101:5672 checkserver node2 192.168.1.102:5672 checkserver node3 192.168.1.103:5672 check...

在上面的配置中,我们定义了三个后端节点,分别是 node1、node2 和 node3,它们的 IP 地址和端口号分别是 192.168.1.101:5672、192.168.1.102:5672 和 192.168.1.103:5672。check 参数表示 HAProxy 会定期检查这些节点的健康状态,确保它们正常运行。

  1. 配置前端监听: 在 HAProxy 的配置文件中,配置前端监听,指定客户端连接 HAProxy 的 IP 地址和端口号,并将请求转发到后端 RabbitMQ 节点。例如:
frontend rabbitmq_frontendbind *:5672mode tcpdefault_backend rabbitmq_nodes

在上面的配置中,我们配置了一个前端监听,监听在 5672 端口上,并将请求转发到名为 rabbitmq_nodes 的后端节点。

  1. 启动 HAProxy: 配置完成后,保存并退出配置文件。然后启动 HAProxy 服务,确保它正常运行。
  2. 连接 RabbitMQ 集群: 现在,客户端可以通过连接到 HAProxy 的 IP 地址和端口号(即 192.168.1.100:5672)来访问 RabbitMQ 集群。HAProxy 会根据负载均衡算法将请求转发到不同的后端 RabbitMQ 节点,实现消息处理的负载均衡。

总结:通过配置 HAProxy,我们可以实现 RabbitMQ 集群的负载均衡,提高消息处理的效率和可用性。HAProxy 是一个强大的负载均衡工具,可以用于各种分布式系统的负载均衡场景。注意在配置时,需要确保 RabbitMQ 节点正常运行,并且 HAProxy 与 RabbitMQ 节点之间的网络连接畅通,以确保负载均衡的顺利进行。

11.2.3 使用 Keepalived 实现高可靠负载均衡

使用 Keepalived 可以实现 RabbitMQ 集群的高可用负载均衡,保证 RabbitMQ 服务的高可用性和可靠性。Keepalived 是一个用于实现高可用性的软件,它可以通过虚拟 IP(VIP)实现在多台服务器之间的故障转移,从而确保服务的连续性。下面介绍如何使用 Keepalived 实现 RabbitMQ 集群的高可用负载均衡:

  1. 安装和配置 Keepalived: 首先需要在每个 RabbitMQ 节点上安装 Keepalived。可以使用适合自己操作系统的包管理工具进行安装,并修改 Keepalived 的配置文件(一般是位于 /etc/keepalived/keepalived.conf)。
  2. 配置虚拟 IP(VIP): 在 Keepalived 的配置文件中,配置虚拟 IP(VIP),这个 IP 地址将用于客户端连接 RabbitMQ 集群。指定 VIP 的 IP 地址和网络接口,例如:
vrrp_instance rabbitmq_vip {state MASTERinterface eth0virtual_router_id 51priority 101advert_int 1authentication {auth_type PASSauth_pass your_password}virtual_ipaddress {192.168.1.100}
}

在上面的配置中,我们配置了一个 VIP 地址为 192.168.1.100,它将绑定到 eth0 网络接口。state MASTER 表示该节点为主节点,其他节点可以配置为 state BACKUP,以实现主备节点的故障转移。

  1. 配置 RabbitMQ 节点信息: 在 Keepalived 的配置文件中,配置 RabbitMQ 节点的信息。指定每个节点的 IP 地址和端口号,以及使用的协议。例如:
real_server rabbitmq_node1 {192.168.1.101 5672weight 1TCP_CHECK {connect_timeout 3nb_get_retry 3delay_before_retry 3connect_port 5672}
}real_server rabbitmq_node2 {192.168.1.102 5672weight 1TCP_CHECK {connect_timeout 3nb_get_retry 3delay_before_retry 3connect_port 5672}
}...

在上面的配置中,我们配置了两个 RabbitMQ 节点,分别是 rabbitmq_node1 和 rabbitmq_node2,它们的 IP 地址和端口号分别是 192.168.1.101:5672 和 192.168.1.102:5672。

  1. 启动 Keepalived: 配置完成后,保存并退出配置文件。然后启动 Keepalived 服务,确保它正常运行。
  2. 连接 RabbitMQ 集群: 现在,客户端可以通过连接到 VIP 地址(即 192.168.1.100:5672)来访问 RabbitMQ 集群。Keepalived 会自动将客户端的请求转发到当前主节点(具有 VIP)的 RabbitMQ 节点上,实现负载均衡和高可用。

总结:通过配置 Keepalived,我们可以实现 RabbitMQ 集群的高可用负载均衡,保证 RabbitMQ 服务的高可用性和可靠性。Keepalived 提供了一种简单且可靠的方式来实现主备节点的故障转移,从而确保 RabbitMQ 服务的连续性。注意在配置时,需要确保 RabbitMQ 节点正常运行,并且 Keepalived 与 RabbitMQ 节点之间的网络连接畅通,以确保高可用负载均衡的顺利进行。

11.2.4 使用 Keepalived+LVS 实现负载均衡

通过 Keepalived 和 LVS(Linux Virtual Server)可以实现 RabbitMQ 集群的负载均衡,保证 RabbitMQ 服务的高可用性和性能优化。Keepalived 用于实现高可用性,而 LVS 则用于实现负载均衡。下面介绍如何使用 Keepalived 和 LVS 来实现 RabbitMQ 集群的负载均衡:

  1. 安装和配置 Keepalived: 首先需要在每个 RabbitMQ 节点上安装 Keepalived。可以使用适合自己操作系统的包管理工具进行安装,并修改 Keepalived 的配置文件(一般是位于 /etc/keepalived/keepalived.conf)。
  2. 配置虚拟 IP(VIP): 在 Keepalived 的配置文件中,配置虚拟 IP(VIP),这个 IP 地址将用于客户端连接 RabbitMQ 集群。指定 VIP 的 IP 地址和网络接口,例如:
vrrp_instance rabbitmq_vip {state MASTERinterface eth0virtual_router_id 51priority 101advert_int 1authentication {auth_type PASSauth_pass your_password}virtual_ipaddress {192.168.1.100}
}

在上面的配置中,我们配置了一个 VIP 地址为 192.168.1.100,它将绑定到 eth0 网络接口。state MASTER 表示该节点为主节点,其他节点可以配置为 state BACKUP,以实现主备节点的故障转移。

  1. 配置 LVS 策略: 在 RabbitMQ 集群之前的一个节点上配置 LVS 策略,用于将客户端请求均衡地转发到 RabbitMQ 节点上。LVS 提供了多种负载均衡算法,如 Round Robin、Least Connections 等,可以根据实际需求选择合适的算法。配置示例如下:
virtual_server 192.168.1.100 5672 {delay_loop 10lb_algo rrlb_kind DRpersistence_timeout 50protocol TCPreal_server 192.168.1.101 5672 {weight 1TCP_CHECK {connect_timeout 3nb_get_retry 3delay_before_retry 3connect_port 5672}}real_server 192.168.1.102 5672 {weight 1TCP_CHECK {connect_timeout 3nb_get_retry 3delay_before_retry 3connect_port 5672}}
}

在上面的配置中,我们配置了一个 LVS 策略,将 VIP 地址 192.168.1.100:5672 转发到两个 RabbitMQ 节点 192.168.1.101:5672 和 192.168.1.102:5672 上,使用的负载均衡算法是 Round Robin(lb_algo rr)。

  1. 启动 Keepalived 和 LVS: 配置完成后,保存并退出配置文件。然后启动 Keepalived 和 LVS 服务,确保它们正常运行。
  2. 连接 RabbitMQ 集群: 现在,客户端可以通过连接到 VIP 地址(即 192.168.1.100:5672)来访问 RabbitMQ 集群。LVS 会根据负载均衡策略将客户端的请求转发到合适的 RabbitMQ 节点上,实现负载均衡和高可用。

总结:通过配置 Keepalived 和 LVS,我们可以实现 RabbitMQ 集群的负载均衡和高可用性,提高消息处理的性能和可靠性。Keepalived 提供了故障转移机制,保证 RabbitMQ 服务的高可用性;而 LVS 提供了负载均衡机制,将客户端请求均衡地转发到 RabbitMQ 节点上,实现消息的负载均衡。注意在配置时,需要确保 RabbitMQ 节点正常运行,并且 Keepalived 和 LVS 与 RabbitMQ 节点之间的网络连接畅通,以确保负载均衡和高可用性的顺利进行。

11.3 小结

本章介绍了 RabbitMQ 的扩展特性,包括消息追踪、负载均衡等内容。通过学习这些高级特性,您可以更好地应对复杂的消息传递场景。在附录中,我们提供了集群元数据信息示例、HTTP API 接口详细内容以及网络分区图谱等供参考。在学习完这些内容后,您将对 RabbitMQ 有一个全面而深入的了解,并能够灵活应用 RabbitMQ 来构建高性能、可靠的消息传递系统。

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

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

相关文章

webpack基础知识一:说说你对webpack的理解?解决了什么问题?

一、背景 Webpack 最初的目标是实现前端项目的模块化,旨在更高效地管理和维护项目中的每一个资源 模块化 最早的时候,我们会通过文件划分的形式实现模块化,也就是将每个功能及其相关状态数据各自单独放到不同的JS 文件中 约定每个文件是一…

Java thymeleaf bug排查记录

刚学Java 做项目时报了一个错误 一时间看的莫名其妙 EL1008E: Property or field createTime cannot be found on object of type java.util.HashMap - maybe not public or not valid? 随即向上排查至第一个报错,发现是thymeleaf渲染时报错。 Exception proces…

leetcode 1290.二进制链表转整数

⭐️ 题目描述 &#x1f31f; leetcode链接&#xff1a;二进制链表转整数 ps&#xff1a; 1 0 1 (0 << 1) 1 0 1 1 (1 << 1) 0 2 0 2 (2 << 1) 1 4 1 5代码&#xff1a; int getDecimalValue(struct ListNode* head) {int ans 0;while(head !…

【数据结构】常见的排序算法

常见的排序算法 常见的排序算法插入排序之直接插入排序时间复杂度特性总结 插入排序之希尔排序时间复杂度 选择排序之直接选择排序特性总结 选择排序之堆排序时间复杂度特性总结 交换排序之冒泡排序特性总结 交换排序之快速排序hoare版本挖坑法双指针法快速排序的优化1&#xf…

PyCharm安装使用2023年教程,PyCharm与现流行所有编辑器对比。

与PyCharm类似的功能和特性的集成开发环境&#xff08;IDE&#xff09;和代码编辑器有以下几种&#xff1a; Visual Studio Code&#xff08;VS Code&#xff09;&#xff1a;由Microsoft开发&#xff0c;VS Code是一个高度可定制和可扩展的代码编辑器。它支持多种编程语言&am…

微信小程序nodejs+vue+uniapp高校食堂线上预约点餐系统

本次设计任务是要设计一个食堂线上预约点餐系统&#xff0c;通过这个系统能够满足管理员及学生的食堂线上预约点餐分享功能。系统的主要包括首页、个人中心、学生管理、菜品分类管理、菜品管理、关于我们管理、意见反馈、系统管理、订单管理等功能。 开发语言 node.js 框架&am…

使用ubuntu-base制作根文件系统

1&#xff1a;ubuntu官网下载最小根文件系统&#xff1a; 放置到电脑的ubuntu中&#xff0c; Mkdir Ubuntu_rootfs Cd Ubuntu_rootfs Sudo tar –zxvf Ubuntu-bash-xxxxxx.tar.gz 2&#xff1a;电脑的ubuntu安装qemu搭建arm模拟系统 将/usr/bin/qemu-arm-static/(64位拷贝…

css滚动条样式指南

css滚动条样式指南 滚动条是网页设计中经常被忽视的元素。虽然它看起来像是一个小细节&#xff0c;但它在网站导航中起着至关重要的作用。默认的滚动条可能看起来不合适&#xff0c;有损整体美观。本文将介绍如何使用 CSS 自定义滚动条。 在 Chrome、Edge 和 Safari 中设置滚…

python字符串输入输出与注解

目录 数据输入 前言 数据输出 字符串 字符串的三种定义方法 引号嵌套 字符串的拼接 字符串格式化 拼接字符串缺点 python常用的格式符号 格式化的精度控制 字符串快速格式化 快速格式化特点 对表达式进行格式化 具体案例 字符串的大小比较 字符串比较方式 变…

【数据结构和算法】排序算法

说明&#xff1a;以下排序如无特别说明&#xff0c;都是从小到大升序排序 1. 冒泡排序 核心思想&#xff1a;每个元素与其相邻元素比较&#xff0c;如果前者大于后者则交换&#xff0c;每次循环结束后会将最大值放到最后&#xff0c;像小水泡从底下冒到上面成大水泡一样&…

day52-Redis

Redis 1.Redis 1.1 RESP连接Redis 1.2 定义&#xff1a;是一个高性能的key-value数据库&#xff08;非关系型数据库&#xff09; 1.3 数据类型&#xff1a; key键的类型是字符串类型&#xff1b; 值的类型有五种&#xff1a;字符串String&#xff0c;哈希hash&#xff0…

Ubuntu安装JDK与IntelliJ IDEA

目录 前言 Ubuntu 安装 JDK 1、更新软件包列表 2、安装OpenJDK 3、验证安装 Ubuntu安装IntelliJ IDEA 1、下载 IntelliJ IDEA 2、解压缩 IntelliJ IDEA 安装包 3、移动 IntelliJ IDEA 到安装目录 4、启动 IntelliJ IDEA 前言 APT&#xff08;Advanced Package Tool&…

使用手机相机检测电脑屏幕刷新率Hz

使用手机相机检测电脑屏幕刷新率Hz 1、电脑打开https://www.testufo.com/frameskipping 2、相机专业模式&#xff1a;快门1/10、ISO自动&#xff0c;拍摄一张照片。120Hz至少要有12个亮块&#xff0c;50Hz至少有6个亮块。 更改刷新速率 1、选择 “开始>设置>系统>显示…

Linux操作系统~Linux基础知识相关题

整卷阅览&#xff1a; 想要获取试卷原版请点击以下链接下载&#xff1a; https://download.csdn.net/download/qq_53142796/88168132https://download.csdn.net/download/qq_53142796/88168132 解题过程&#xff1a; 选择题&#xff08;每小题2分&#xff0c;共30分&#xff…

心跳跟随的心形灯(STM32(HAL)+WS2812+MAX30102)

文章目录 前言介绍系统框架原项目地址本项目开发开源地址硬件PCB软件功能 详细内容硬件外壳制作WS2812级联及控制MAX30102血氧传感器0.96OLEDFreeRTOS 效果视频总结 前言 在好几年前&#xff0c;我好像就看到了焊武帝 jiripraus在纪念结婚五周年时&#xff0c;制作的一个心跳跟…

Xcode protobuf2.5添加arm64编译器补丁生成静态库

项目需求&#xff0c;protobuf源码编成静态库使用 但是&#xff0c;github上的protobuf源码没有对应arm64的编译器定义&#xff0c;编译出来的静态库使用时报错。 下面的连接是arm64编译器代码补丁包&#xff0c;把编译器代码放到src/google/protobuf/stubs/atomicops_intern…

第一课-前提-Stable Diffusion 教程

学习 SD 的前提是电脑配置! SD 参考配置: 建议选择台式机 i5 CPU, 内存16GB,N卡 RTX3060, 8G显存以上的配置(最低配) 在此基础上的配置越高越好。 比如,cpu i7 更好,显卡能有 RTX4090 更好,32显存要能有最好,嘿嘿嘿。 如何查看自己的显卡配置? Win+R 输入 “dxdiag…

变压器参数测定中空载实验和短路实验的理解

确定变压器的参数是在《电机学》和《电力系统分析》中非常重要的一个环节&#xff0c;这里用自己习惯的方式讲一下怎样理解 首先要讲下变压器的额定参数&#xff0c;这个也是个常考的知识点 额定功率&#xff0c;即视在功率&#xff0c;电压电流&#xff0c;单位是VA或者kVA额…

kubernetes基于helm部署gitlab-runner

kubernetes基于helm部署gitlab-runner 这篇博文介绍如何在 Kubernetes 中使用helm部署 GitLab-runner。 先决条件&#xff1a; 已运行的 Kubernetes 集群已运行的 gitlab 实例 项目地址&#xff1a;https://gitlab.com/gitlab-org/charts/gitlab-runner 官方文档&#xff…

三层交换实验

前言 在实际的企业应用中&#xff0c;我们会先建立不同的vlan把用户先隔开来。然后再通过三次交换机技术打通vlan直接的网络。 这样的目的如下&#xff1a; 隔离&#xff1a; 隔离是广播域&#xff0c;也就是隔离的是故障连通&#xff1a; 连通的是正常的通信 比如校园网&am…