RabbitMQ 教程 | 第5章 RabbitMQ 管理

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

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

全篇共 11 章,9 万余字。本文:第5章 RabbitMQ 管理。

第5章 RabbitMQ 管理

5.1 多租户与权限

RabbitMQ 提供了多租户特性,允许在单个 RabbitMQ 实例上创建多个独立的虚拟主机(vhost)。每个虚拟主机相当于一个独立的消息代理,拥有自己的交换机、队列、绑定、用户权限等,从而实现了逻辑上的隔离。这样可以让不同的应用或用户组在同一个 RabbitMQ 实例上拥有独立的消息环境,彼此之间不会相互影响。

使用 RabbitMQ 的多租户特性,需要以下步骤:

  1. 创建虚拟主机: 在 RabbitMQ 管理界面或使用 RabbitMQ 命令行工具,可以创建一个新的虚拟主机。每个虚拟主机都有一个唯一的名称,用于标识和区分不同的租户。
  2. 为虚拟主机设置权限: 在 RabbitMQ 中,可以为不同的用户设置不同的权限。可以创建多个用户,并将其分配到不同的虚拟主机上,从而实现对不同租户的访问控制。可以为每个用户指定对虚拟主机的读、写、管理等权限。
  3. 访问控制策略: RabbitMQ 还提供了访问控制策略来限制对虚拟主机的访问。可以通过策略设置,对某个虚拟主机的访问进行控制,如限制最大连接数、最大队列数、最大内存使用等。

以下是使用 RabbitMQ 的多租户特性的示例代码:

public class RabbitMQMultiTenancyExample {private static final String VIRTUAL_HOST = "my_vhost";private static final String USERNAME = "my_user";private static final String PASSWORD = "my_password";public static void main(String[] args) throws Exception {// 创建连接工厂ConnectionFactory factory = new ConnectionFactory();factory.setHost("localhost");factory.setVirtualHost(VIRTUAL_HOST);factory.setUsername(USERNAME);factory.setPassword(PASSWORD);// 创建连接和通道try (Connection connection = factory.newConnection();Channel channel = connection.createChannel()) {// 在指定的虚拟主机中声明交换机、队列等操作// ...// 发布消息到指定的虚拟主机中// ...}}
}

在上面的示例中,我们创建了一个虚拟主机 my_vhost,并为该虚拟主机创建了一个名为 my_user 的用户,并设置了相应的密码。然后在代码中,我们使用这个虚拟主机和用户连接到 RabbitMQ,并进行了相应的消息发布等操作。

总结来说,通过 RabbitMQ 的多租户特性,可以在单个 RabbitMQ 实例上实现消息的逻辑隔离,为不同的应用或用户组提供独立的消息环境,并可以通过设置不同用户的权限和访问控制策略来实现对虚拟主机的访问控制。

5.2 用户管理

在 RabbitMQ 中,可以通过管理界面或者使用 RabbitMQ 命令行工具来创建和管理用户,包括设置用户角色和权限。以下是通过 RabbitMQ 管理界面和命令行工具创建和管理用户的步骤:

使用 RabbitMQ 管理界面:

  1. 打开 RabbitMQ 的管理界面,通常是通过浏览器访问 http://localhost:15672。
  2. 使用管理员账号登录管理界面。默认情况下,管理员用户名为 guest,密码也为 guest,但是建议在生产环境中修改默认管理员密码。
  3. 在管理界面中,点击"Admin"标签页,然后点击"Add a user"按钮。
  4. 输入用户名和密码,然后点击"Add user"按钮创建新用户。
  5. 点击"Back to users"链接,找到刚创建的用户,然后点击"Set permission"按钮。
  6. 在设置用户权限的界面,可以为用户分配虚拟主机和角色。RabbitMQ 预定义了几种角色,如"administrator"、"monitoring"、"policymaker"和"management"。可以根据需求选择相应的角色,也可以自定义角色并分配相应的权限。
  7. 点击"Set permission"按钮保存设置。

使用 RabbitMQ 命令行工具:

在命令行中使用 rabbitmqctl 命令行工具可以创建和管理 RabbitMQ 的用户,以下是一些常用的命令:

  1. 创建用户:

rabbitmqctl add_user <username> <password>

示例:rabbitmqctl add_user myuser mypassword

  1. 设置用户角色:

rabbitmqctl set_user_tags <username> <tag>

示例:rabbitmqctl set_user_tags myuser administrator

  1. 设置用户权限:

rabbitmqctl set_permissions -p <vhost> <username> <conf> <write> <read>

示例:rabbitmqctl set_permissions -p my_vhost myuser "." "." ".*"

注意事项:

  • 管理员用户通常具有最高权限,可以创建/删除虚拟主机、用户、角色等,并且有对所有虚拟主机的完全访问权限。
  • 非管理员用户通常只能在其所属虚拟主机中进行操作。
  • 可以通过 rabbitmqctl list_users 命令查看当前所有用户和其角色。
  • 在生产环境中,建议对用户进行合理的权限划分,限制其权限范围,以确保安全性和隔离性。

总结来说,可以通过 RabbitMQ 管理界面或命令行工具来创建和管理用户,包括设置用户角色和权限。管理员用户具有最高权限,可以创建和管理其他用户和角色,非管理员用户可以在其所属虚拟主机中进行操作。在设置用户权限时,建议进行合理的权限划分,以确保系统的安全性和隔离性。

5.3 Web端管理

RabbitMQ 提供了一个强大且易用的 Web 管理界面,也称为 RabbitMQ Management Plugin。通过该界面,管理员和开发人员可以方便地进行队列、交换机、连接等管理操作,监控消息队列的状态,以及查看集群的健康状态。以下是 Web 管理界面的主要功能和优势:

  1. 可视化管理:Web 管理界面以直观的图表和表格形式展示了消息队列的状态和指标,使得管理和监控变得更加直观和易于理解。
  2. 队列和交换机管理:通过 Web 界面可以轻松地创建、删除、查看队列和交换机的信息,包括名称、类型、绑定等。管理员可以直接在界面上执行这些操作,无需使用命令行工具。
  3. 连接和通道管理:Web 管理界面提供了连接和通道的详细信息,管理员可以查看当前连接和通道的状态、消费者数、所属虚拟主机等。
  4. 虚拟主机管理:管理员可以管理虚拟主机的创建和删除,并对虚拟主机进行权限设置,以实现多租户的隔离和访问控制。
  5. 用户管理:Web 管理界面允许管理员创建、删除和管理用户,同时可以为用户设置角色和权限。
  6. 监控和性能分析:Web 管理界面提供了丰富的监控指标和性能分析信息,包括队列的消息数、消费者数、吞吐量等,可以帮助管理员实时了解系统的状态。
  7. 插件管理:RabbitMQ 支持插件机制,通过 Web 管理界面可以方便地查看和启用各种插件,拓展 RabbitMQ的功能。
  8. 集群管理:对于部署了 RabbitMQ 集群的情况,Web 管理界面可以方便地查看集群的状态、节点信息和健康状态。

使用 Web 管理界面,不仅可以简化 RabbitMQ 的管理和监控工作,还提供了直观的数据可视化,帮助管理员更好地了解消息队列的状态和性能表现。同时,Web 管理界面还支持多语言,方便了全球范围内的使用。建议在生产环境中启用 Web 管理界面,并设置合适的访问控制,以确保系统的安全性。

5.4 应用与集群管理

管理 RabbitMQ 的应用和集群包括应用的启动和关闭,以及集群节点的配置和管理。下面分别介绍这些方面的操作:

应用的启动和关闭:

  1. 启动应用:在启动 RabbitMQ 应用之前,需要先启动 Erlang 节点。然后可以通过命令行工具或脚本启动 RabbitMQ 应用。
    • 使用命令行工具启动:在命令行中输入 rabbitmq-server 命令即可启动 RabbitMQ 应用。
    • 使用脚本启动:不同操作系统可能使用不同的启动脚本。通常,Linux 系统使用 service rabbitmq-server start 命令,而 Windows 系统可以通过服务面板启动。
  1. 关闭应用:要停止 RabbitMQ 应用,可以使用以下方法:
    • 使用命令行工具:在命令行中输入 rabbitmqctl stop 命令即可停止 RabbitMQ 应用。
    • 使用脚本:在 Linux 系统上,可以使用 service rabbitmq-server stop 命令来停止 RabbitMQ 应用。在 Windows 系统上,也可以通过服务面板停止。

集群节点的配置和管理:

  1. 集群配置:要配置 RabbitMQ 集群,需要在每个节点上设置相同的 /etc/rabbitmq/rabbitmq.config 配置文件。配置文件中包含了节点名称、集群节点信息、网络端口、认证等配置。确保所有节点的配置文件保持一致,然后启动所有节点。
  2. 集群节点的加入和离开:要加入集群,需要在节点配置文件中指定其他节点的名称。节点启动后,它会自动连接到其他节点并加入集群。要离开集群,可以通过命令行工具或脚本禁用集群插件,然后重启节点。
  3. 集群健康状态监控:可以使用 RabbitMQ 的 Web 管理界面或命令行工具来监控集群的健康状态。通过查看节点状态、队列状态和消息状态等指标,可以确保集群正常运行。
  4. 集群节点的升级和维护:在集群中,如果需要对某个节点进行升级或维护,可以先将该节点从集群中移除,然后进行相应操作,完成后再加入集群。

注意事项:

  • 在设置集群时,要确保所有节点的时间同步,以避免由于时间不一致导致的问题。
  • 确保所有节点都能够相互访问,通信端口没有被防火墙阻止。
  • 在修改配置文件或执行操作时,务必备份相关数据,以防止数据丢失。

总结来说,管理 RabbitMQ 的应用和集群包括启动和关闭应用,配置集群节点,加入和离开集群,监控集群健康状态,以及节点的升级和维护。确保节点的配置一致性和正常运行,以保障 RabbitMQ 集群的稳定性和可靠性。

5.4.1 应用管理

启动和关闭 RabbitMQ 应用可以使用命令行工具或者脚本来执行。同时,RabbitMQ 提供了 Web 管理界面,可以进行应用管理的一些常见操作。以下是详细介绍:

启动和关闭 RabbitMQ 应用:

  1. 启动 RabbitMQ 应用:
    • 在 Linux 系统上,打开终端,输入以下命令启动 RabbitMQ 应用:
    • 在 Windows 系统上,打开命令提示符,输入以下命令启动 RabbitMQ 应用:
  1. 如果一切正常,RabbitMQ 应用将会启动并监听默认端口 5672。在启动 RabbitMQ 应用之前,确保已经安装并正确配置了 Erlang/OTP 环境。
rabbitmq-server
rabbitmq-server
  1. 关闭 RabbitMQ 应用:
    • 在 Linux 系统上,可以通过 Ctrl + C 来终止 RabbitMQ 应用的运行。
    • 在 Windows 系统上,可以通过在命令提示符中输入 Ctrl + C 或者关闭命令行窗口来终止 RabbitMQ 应用。

应用管理中的一些常见操作:

RabbitMQ 提供了 Web 管理界面,通过该界面可以进行应用管理的一些常见操作,包括:

  1. 队列管理:在 Web 界面中,可以创建、删除和查看队列。也可以查看队列的消息数、消费者数等指标。
  2. 交换机管理:可以创建、删除和查看交换机,并设置交换机的类型和属性。
  3. 虚拟主机管理:可以创建、删除和查看虚拟主机,并设置虚拟主机的权限和访问控制策略。
  4. 用户管理:可以创建、删除和管理用户,并设置用户角色和权限。
  5. 连接和通道管理:可以查看当前连接和通道的状态、消费者数等信息。
  6. 监控和性能分析:Web 管理界面提供了丰富的监控指标和性能分析信息,帮助管理员实时了解系统的状态和性能。
  7. 插件管理:可以查看和启用各种插件,拓展 RabbitMQ 的功能。

以上操作都可以通过 Web 管理界面直观地进行,而无需使用命令行工具。通过 Web 管理界面,管理员可以更方便地进行应用管理和监控工作,提高工作效率。

总结来说,可以使用命令行工具或脚本来启动和关闭 RabbitMQ 应用。而在应用管理方面,RabbitMQ 的 Web 管理界面提供了一系列功能,包括队列、交换机、虚拟主机、用户等的创建、删除、查看、设置等操作,同时提供监控和性能分析信息,帮助管理员更好地管理和监控 RabbitMQ 应用。

5.4.2 集群管理

配置和管理 RabbitMQ 的集群可以通过多机多节点配置和单机多节点配置来实现。下面分别介绍这两种配置方式的步骤:

多机多节点配置:

在多机多节点配置中,RabbitMQ 的不同节点运行在不同的机器上,构成一个分布式集群。这样可以实现更高的可靠性和容错性。

  1. 确保节点间的网络互通:首先确保所有节点之间的网络是互通的,即节点之间可以相互通信。确保网络端口没有被防火墙阻止。
  2. 安装并配置 Erlang/OTP:在每台机器上安装并配置相同版本的 Erlang/OTP。RabbitMQ 是基于 Erlang 开发的,因此所有节点必须使用相同版本的 Erlang/OTP。
  3. 配置节点名称:在每个节点的配置文件中,设置相同的节点名称。配置文件通常位于 /etc/rabbitmq/rabbitmq.config 或 /etc/rabbitmq/rabbitmq-env.conf。
  4. 启动 RabbitMQ 节点:在每个节点上分别启动 RabbitMQ 应用。在命令行中输入 rabbitmq-server 命令启动 RabbitMQ 应用。
  5. 加入集群:在每个节点上设置相同的 rabbitmq.conf 配置文件,包含其他节点的名称。在每个节点启动后,它们会自动连接到其他节点并加入集群。

单机多节点配置:

在单机多节点配置中,多个 RabbitMQ 节点运行在同一台机器上,这些节点可以共享相同的 Erlang/OTP 虚拟机,但是各节点的端口号必须不同。

  1. 安装并配置 Erlang/OTP:在机器上安装并配置 Erlang/OTP。确保 Erlang/OTP 环境能够支持多节点运行。
  2. 配置节点名称和端口号:在每个节点的配置文件中,设置不同的节点名称和端口号。配置文件通常位于 /etc/rabbitmq/rabbitmq.config 或 /etc/rabbitmq/rabbitmq-env.conf。
  3. 启动 RabbitMQ 节点:在每个节点上分别启动 RabbitMQ 应用。在命令行中输入 rabbitmq-server -detached 命令启动 RabbitMQ 应用。
  4. 加入集群:在每个节点上设置相同的 rabbitmq.conf 配置文件,包含其他节点的名称和端口号。在每个节点启动后,它们会自动连接到其他节点并加入集群。

无论是多机多节点配置还是单机多节点配置,集群中的节点之间要确保网络互通和配置一致性。配置完毕后,可以通过 RabbitMQ 的 Web 管理界面或命令行工具来监控和管理集群状态。集群可以提供更高的可用性和性能,保障消息的高可靠性和分布式处理能力。在进行集群配置时,务必注意备份相关数据,以防止数据丢失。

5.5 服务端状态

RabbitMQ 提供了多种方式来查看服务器的状态信息,包括队列、交换机、连接等统计数据。以下是一些常见的查看服务器状态信息的方法:

  1. Web 管理界面: RabbitMQ 的 Web 管理界面是最直观和常用的查看服务器状态信息的方式。通过浏览器访问 http://localhost:15672/(默认地址)或您配置的管理界面地址,在登录后,可以在界面上看到多个选项卡,每个选项卡显示了不同的统计数据,如:
    • Overview(总览):显示了整个 RabbitMQ 服务器的概览信息,包括活动连接、队列数、消息发布率等。
    • Queues(队列):显示了所有队列的详细信息,包括队列的名称、消息数、消费者数等。
    • Exchanges(交换机):显示了所有交换机的详细信息,包括交换机的名称、类型、绑定信息等。
    • Connections(连接):显示了当前所有连接的详细信息,包括连接的名称、客户端地址、虚拟主机等。
    • Channels(通道):显示了当前所有通道的详细信息,包括通道的编号、消费者数等。
  1. 命令行工具: RabbitMQ 提供了命令行工具 rabbitmqctl 来查看服务器状态信息。您可以在终端或命令提示符中输入以下命令来获取相应的统计数据:
    • 查看队列信息:rabbitmqctl list_queues
    • 查看交换机信息:rabbitmqctl list_exchanges
    • 查看连接信息:rabbitmqctl list_connections
    • 查看通道信息:rabbitmqctl list_channels
    • 查看节点状态:rabbitmqctl status
  1. HTTP API 接口: RabbitMQ 提供了 HTTP API 接口,可以通过发送 HTTP 请求获取服务器的状态信息。API 接口的地址通常为 http://localhost:15672/api/(默认地址),您可以使用 curl 命令或任何 HTTP 客户端库来访问 API 接口,获取各种统计数据。
  2. 插件: RabbitMQ 支持各种插件,这些插件可以提供额外的功能和统计信息。您可以查看 RabbitMQ 官方文档,了解更多关于插件的信息。

总的来说,RabbitMQ 提供了丰富的方式来查看服务器的状态信息,包括 Web 管理界面、命令行工具、HTTP API 接口等。通过监控服务器的状态信息,您可以更好地了解 RabbitMQ 的运行状态,帮助调优和排查问题。

5.6 HTTP API 接口管理

RabbitMQ 提供了 HTTP API 接口,通过这些接口可以方便地对 RabbitMQ 进行管理和监控。API 接口的地址通常为 http://localhost:15672/api/(默认地址),您可以使用 curl 命令或任何 HTTP 客户端库来访问 API 接口。以下是一些常用的 HTTP API 接口和其用法:

  1. 获取队列列表:

GET /api/queues

这个接口用于获取所有队列的列表。返回的 JSON 数据中包含队列的名称、消息数量、消费者数量等信息。

  1. 获取交换机列表:

GET /api/exchanges

这个接口用于获取所有交换机的列表。返回的 JSON 数据中包含交换机的名称、类型、是否持久化等信息。

  1. 获取连接列表:

GET /api/connections

这个接口用于获取当前所有连接的列表。返回的 JSON 数据中包含连接的名称、客户端地址、虚拟主机等信息。

  1. 获取通道列表:

GET /api/channels

这个接口用于获取当前所有通道的列表。返回的 JSON 数据中包含通道的编号、是否活跃、消费者数量等信息。

  1. 获取节点信息:

GET /api/nodes

这个接口用于获取所有节点的信息。返回的 JSON 数据中包含节点的名称、内存使用情况、磁盘使用情况等信息。

  1. 获取队列的消息数量:

GET /api/queues/vhost/queue-name

这个接口用于获取特定队列的消息数量。其中 vhost 是虚拟主机名称,queue-name 是队列名称。

  1. 获取队列的消息详情:

GET /api/queues/vhost/queue-name/get

这个接口用于从队列中获取消息的详细信息。其中 vhost 是虚拟主机名称,queue-name 是队列名称。

通过 HTTP API 接口,您可以通过编程的方式访问 RabbitMQ 的状态信息,并根据需要进行监控和管理。请注意,为了安全性考虑,API 接口需要进行身份验证。您需要使用 RabbitMQ 的用户名和密码进行认证,可以通过添加 HTTP 头信息 Authorization: Basic base64encode(username:password) 来实现认证。

同时,使用 API 接口时需谨慎处理敏感信息,避免泄露敏感数据,建议仅在受信任的环境中使用 API 接口。在编程时,您可以使用脚本、HTTP 客户端库或 REST 客户端库来访问 API 接口,以便更方便地进行监控和管理 RabbitMQ。

5.7 小结

本章介绍了 RabbitMQ 的管理特性,包括多租户与权限、用户管理、Web 端管理、应用与集群管理、服务端状态和 HTTP API 接口管理等内容。在下一章中,我们将学习 RabbitMQ 的配置,包括环境变量、配置文件、参数及策略等内容。

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

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

相关文章

SpringCloud学习路线(13)——分布式搜索ElasticSeach集群

前言 单机ES做数据存储&#xff0c;必然面临两个问题&#xff1a;海量数据的存储&#xff0c;单点故障。 如何解决这两个问题&#xff1f; 海量数据的存储问题&#xff1a; 将索引库从逻辑上拆分为N个分片&#xff08;shard&#xff09;&#xff0c;存储到多个节点。单点故障…

Mysql 查询统计最近12个月的数据

包括当月: SELECTt1.yf AS month,count( t2.uuid ) AS total FROM(SELECTDATE_FORMAT(( CURDATE()), %Y-%m ) AS yf UNIONSELECTDATE_FORMAT(( CURDATE() - INTERVAL 1 MONTH ), %Y-%m ) AS yf UNIONSELECTDATE_FORMAT(( CURDATE() - INTERVAL 2 MONTH ), %Y-%m ) AS yf UNION…

F5 LTM 知识点和实验 2-负载均衡基础概念

第二章&#xff1a;负载均衡基础概念 目标&#xff1a; 使用网页和TMSH配置virtual servers&#xff0c;pools&#xff0c;monitors&#xff0c;profiles和persistence等。查看统计信息 基础概念&#xff1a; Node一个IP地址。是创建pool池的基础。可以手工创建也可以自动创…

基于canvas画布的实用类Fabric.js的使用

目录 前言 一、Fabric.js简介 二、开始 1、引入Fabric.js 2、在main.js中使用 3、初始化画布 三、方法 四、事件 1、常用事件 2、事件绑定 3、事件解绑 五、canvas常用属性 六、对象属性 1、基本属性 2、扩展属性 七、图层层级操作 八、复制和粘贴 1、复制 2…

Redis常用命令

目录 Redis通用命令 进入Redis 1.进入redis容器 2.进入redis-cli 查询Redis中储存的key 删除key 查询key的过期时间,以毫秒为单位返回 key 的剩余的过期时间 查询key的数据类型 Redis数据结构 Redis数据查询 1.string 查询key对应的值 设置key对应的值 2.list 查…

ACL原理

ACL原理 ACL是一种用于控制网络设备访问权限的技术&#xff0c;可以通过配置ACL来限制特定用户、应用程序或网络设备对网络资源的访问。 1、ACL&#xff08;Access Control List&#xff09; 2、ACL是一种包过滤技术。 3、ACL基于IP包头的IP地址、四层TCP/UDP头部的端口号、…

磁盘均衡器:HDFS Disk Balancer

HDFS Disk Balancer 背景产生的问题以及解决方法 hdfs disk balancer简介HDFS Disk Balancer功能数据传播报告 HDFS Disk Balancer开启相关命令 背景 相比较于个人PC&#xff0c;服务器一般可以通过挂载多块磁盘来扩大单机的存储能力在Hadoop HDFS中&#xff0c;DataNode负责最…

canvas实现图片平移,缩放的例子

最近有个水印预览的功能&#xff0c;需要用到canvas 绘制&#xff0c;canvas用的不是很熟&#xff0c;配合chatAI 完成功能。 效果如下 代码如下 原先配置是响应式的&#xff0c;提出来了就不显示操作了&#xff0c;模拟值都写死的 界面给大家参考阅读。 <!DOCTYPE html…

Spring AOP 的概念及其作用

一、什么是 Spring AOP&#xff1f; 在介绍 Spring AOP 之前&#xff0c;首先要了解一下什么是 AOP &#xff1f; AOP &#xff08; Aspect Oriented Programming &#xff09;&#xff1a;面向切面编程&#xff0c;它是一种思想&#xff0c; 它是对某一类事情的集中处 理 。…

软件测试面试题——接口自动化测试怎么做?

面试过程中&#xff0c;也问了该问题&#xff0c;以下是自己的回答&#xff1a; 接口自动化测试&#xff0c;之前做过&#xff0c;第一个版本是用jmeter 做的&#xff0c;1 主要是将P0级别的功能接口梳理出来&#xff0c;根据业务流抓包获取相关接口&#xff0c;并在jmeter中跑…

【前端知识】React 基础巩固(四十三)——Effect Hook

React 基础巩固(四十三)——Effect Hook 一、Effect Hook的基本使用 Effect Hook 用来完成一些类似class中生命周期的功能。 在使用类组件时&#xff0c;不管是渲染、网路请求还是操作DOM&#xff0c;其逻辑和代码是杂糅在一起的。例如我们希望把计数器结果显示在标签上&…

8.事件对象

8.1获取事件对象 ●事件对象是什么 也是个对象&#xff0c;这个对象里有事件触发时的相关信息 例如&#xff1a;鼠标点击事件中&#xff0c;事件对象就存了鼠标点在哪个位置等信息 ●使用场景 可以判断用户按下哪个键&#xff0c;比如按下回车键可以发布新闻 可以判断鼠标点击…

【Java|golang】143. 重排链表---快慢指针

给定一个单链表 L 的头节点 head &#xff0c;单链表 L 表示为&#xff1a; L0 → L1 → … → Ln - 1 → Ln 请将其重新排列后变为&#xff1a; L0 → Ln → L1 → Ln - 1 → L2 → Ln - 2 → … 不能只是单纯的改变节点内部的值&#xff0c;而是需要实际的进行节点交换。 …

CentOS7.3 安装 docker

亲测、截图 阿里云服务器 文章目录 更新源2345 启动开机自启 更新源 sudo yum update -y2 sudo yum install -y yum-utils device-mapper-persistent-data lvm23 sudo yum-config-manager --add-repo https://download.docker.com/linux/centos/docker-ce.repo4 sudo yum …

【软件测试】性能测试工具- LoadRunner的介绍和使用

目录 1. LoadRunner是什么2. LoadRunner环境搭建3. LoadRunner三大组件4. LoadRunner脚本录制4.1 WebTous项目介绍启动WebTous项目访问WebTous项目相关配置 4.2 脚本录制新建脚本录制脚本运行脚本 4.3 脚本加强插入事务插入集合点插入检查点插入日志字符串比较 1. LoadRunner是…

【奥比中光Gemini 2L快速上门】

奥比中光Gemini 2L快速上手 目录 奥比中光Gemini 2L快速上手[TOC](目录) 一、下载配置环境1.1 官网下载SDK1.2 配置环境 二、测试2.1 在bin中运行示例2.2 配置cmake 三、CMAKE3.1 CmakeLists.txt中各设置的意义 一、下载配置环境 1.1 官网下载SDK 进入官网&#xff0c;下载名…

MySQL中锁的简介——行级锁

1.行级锁概念及分类 可通过以下语句查看意向锁和行锁的加锁情况&#xff1a; select object_schema,object_name,index_name,lock_type,lock_mode,lock_data from performance_schema.data_locks;InnoDB的行锁是针对于索引加的锁&#xff0c;不通过索引条件检索数据&#xff0…

this is incompatible with sql_mode=only_full_group_by

查看配置 select global.sql_mode 在sql命令行中输入select sql_mode 能够看到sql_mode配置,如果有ONLY_FULL_GROUP_BY&#xff0c;则需要修改 在mysql5.7.5后&#xff0c;ONLY_FULL_GROUP_BY是默认选项&#xff0c;所以就会导致group by的问题 set sql_mode‘复制去掉ONLY_F…

[SSM]Spring6整合JUnit5与集成MyBatis3.5

目录 十七、Spring6整合JUnit5 17.1Spring对JUnit4的支持 17.2Spring对JUnit5的支持 十八、Spring6集成MyBatis3.5 18.1实现步骤 18.2具体实现 18.3spring配置文件的import 十七、Spring6整合JUnit5 17.1Spring对JUnit4的支持 准备工作&#xff1a; <dependencies&…

华为数通HCIA-网络参考模型(TCP/IP)

网络通信模式 作用&#xff1a;指导网络设备的通信&#xff1b; OSI七层模型&#xff1a; 7.应用层&#xff1a;由应用层协议&#xff08;http、FTP、Telnet.&#xff09;为应用程序产生对应的数据&#xff1b; 6.表示层&#xff1a;将应用层产生的数据转换成网络设备看得懂…