RabbitMQ搭建集群环境、配置镜像集群、负载均衡

RabbitMQ集群搭建

  • Linux安装RabbitMQ
    • 下载
    • 安装
    • 基本操作命令
    • 开启管理界面及配置
  • RabbitMQ集群搭建
    • 确定rabbitmq安装目录
    • 启动第一个节点
    • 启动第二个节点
    • 停止命令
    • 创建集群
    • 查看集群
    • 集群管理
  • RabbitMQ镜像集群配置
    • 启用HA策略
    • 创建一个镜像队列
    • 测试镜像队列
  • 负载均衡-HAProxy
    • 安装HAProxy
    • 配置haproxy
    • 启动HAProxy服务
    • 查看HAProxy监控
    • Java代码连接MQ集群

Linux安装RabbitMQ

下载

RabbitMQ官方下载页:https://www.rabbitmq.com/download.html

RabbitMQ下载:https://github.com/rabbitmq/rabbitmq-server/tags

erlang下载:https://github.com/rabbitmq/erlang-rpm/releases

下载RabbitMQ与erlang: https://packagecloud.io/rabbitmq

安装

注意:在下载 rabbitmq-servererlang包时,若包名含el8代表需要Centos8才能安装!例如: rabbitmq-server-3.11.13-1.el8.noarch.rpm,否则安装将出现如下类似异常:

[root@node01 ~]# rpm -ivh erlang-25.3-1.el8.x86_64.rpm 
警告:erlang-25.3-1.el8.x86_64.rpm:V4 RSA/SHA256 Signature, 密钥 ID cc4bbe5b: NOKEY
错误:依赖检测失败:
        libcrypto.so.1.1()(64bit) 被 erlang-25.3-1.el8.x86_64 需要
        libcrypto.so.1.1(OPENSSL_1_1_0)(64bit) 被 erlang-25.3-1.el8.x86_64 需要
        libcrypto.so.1.1(OPENSSL_1_1_1)(64bit) 被 erlang-25.3-1.el8.x86_64 需要
        libstdc++.so.6(CXXABI_1.3.9)(64bit) 被 erlang-25.3-1.el8.x86_64 需要
        libtinfo.so.6()(64bit) 被 erlang-25.3-1.el8.x86_64 需要
        libz.so.1(ZLIB_1.2.7.1)(64bit) 被 erlang-25.3-1.el8.x86_64 需要

由于服务器时CentOS7,故寻找包名带el7的软件包,这里使用如下包

rabbitmq-server-3.6.5-1.noarch.rpm

erlang-18.3-1.el7.centos.x86_64.rpm

下载地址:https://download.csdn.net/download/qq_38628046/87697057

1.安装或更新依赖环境

yum install build-essential openssl openssl-devel unixODBC unixODBC-devel make gcc
gcc-c++ kernel-devel m4 ncurses-devel tk tc xz

yum install zlib-devel bzip2-devel openssl-devel ncurses-devel sqlite-devel
readline-devel tk-devel gcc make -y

2.安装erlang

[root@node01 ~]# rpm -ivh erlang-18.3-1.el7.centos.x86_64.rpm
准备中...                          ################################# [100%]
正在升级/安装...
   1:erlang-18.3-1.el7.centos         ################################# [100%]

3.安装rabbitmq

[root@node01 ~]# rpm -ivh rabbitmq-server-3.6.5-1.noarch.rpm
警告:rabbitmq-server-3.6.5-1.noarch.rpm:V4 RSA/SHA1 Signature, 密钥 ID 6026dfca: NOKEY
错误:依赖检测失败:
        socat 被 rabbitmq-server-3.6.5-1.noarch 需要

访问:https://mirrors.aliyun.com/centos/7.9.2009/os/x86_64/Packages/下载依赖

在这里插入图片描述

wget http://mirrors.aliyun.com/centos/7.9.2009/os/x86_64/Packages/socat-1.7.3.2-2.el7.x86_64.rpm
[root@node01 ~]# rpm -ivh socat-1.7.3.2-2.el7.x86_64.rpm
警告:socat-1.7.3.2-2.el7.x86_64.rpm:V4 RSA/SHA1 Signature, 密钥 ID 87e360b8: NOKEY
错误:依赖检测失败:
        tcp_wrappers 被 socat-1.7.3.2-2.el7.x86_64 需要

接着再访问:https://mirrors.aliyun.com/centos/7.9.2009/os/x86_64/Packages/下载依赖

wget http://mirrors.aliyun.com/centos/7.9.2009/os/x86_64/Packages/tcp_wrappers-7.6-77.el7.x86_64.rpm
[root@node01 ~]# rpm -ivh tcp_wrappers-7.6-77.el7.x86_64.rpm 
准备中...                          ################################# [100%]
正在升级/安装...
   1:tcp_wrappers-7.6-77.el7          ################################# [100%]
[root@node01 ~]# rpm -ivh socat-1.7.3.2-2.el7.x86_64.rpm
警告:socat-1.7.3.2-2.el7.x86_64.rpm:V4 RSA/SHA1 Signature, 密钥 ID 87e360b8: NOKEY
准备中...                          ################################# [100%]
正在升级/安装...
   1:socat-1.7.3.2-2.el7            ################################# [100%]
[root@node01 ~]# rpm -ivh rabbitmq-server-3.6.5-1.noarch.rpm
警告:rabbitmq-server-3.6.5-1.noarch.rpm:V4 RSA/SHA1 Signature, 密钥 ID 6026dfca: NOKEY
准备中...                          ################################# [100%]
正在升级/安装...
   1:rabbitmq-server-3.6.5-1          ################################# [100%]

注意:rabbitmq默认安装位置:/usr/lib/rabbitmq/bin

基本操作命令

检查RabbitMQ 的状态

systemctl status rabbitmq-server

启动RabbitMQ 服务

systemctl start rabbitmq-server

systemctl restart rabbitmq-server

停止RabbitMQ 服务

systemctl stop rabbitmq-server

将RabbitMQ设置为开机自启动

systemctl enable rabbitmq-server

开启管理界面及配置

开启管理界面

rabbitmq-plugins enable rabbitmq_management

修改默认配置信息

vim /usr/lib/rabbitmq/lib/rabbitmq_server-3.6.5/ebin/rabbit.app

或者创建配置文件,在其中进行配置以覆盖默认配置信息

cd /usr/share/doc/rabbitmq-server-3.6.5/

cp rabbitmq.config.example /etc/rabbitmq/rabbitmq.config

RabbitMQ安装好后,访问http://ip:15672,使用guest用户名那与密码登录。

在这里插入图片描述

在3.3.1以后的版中,处于安全的考虑,guest这个默认的用户只能通过localhost来登录,其他的IP无法直接使用这个账号

编辑配置文件vim /etc/rabbitmq/rabbitmq.config,在其中添加以下内容:

[{rabbit, [{loopback_users, []}]}]

注意:只需要在合适的位置添加{loopback_users, []}]即可

%% -*- mode: erlang -*-
%% ----------------------------------------------------------------------------
%% RabbitMQ Sample Configuration File.
%%
%% See http://www.rabbitmq.com/configure.html for details.
%% ----------------------------------------------------------------------------
[
 {rabbit,
  [%%
  {loopback_users, []}
   %% Network Connectivity
   %% ====================
   %%

   %% By default, RabbitMQ will listen on all interfaces, using
   %% the standard (reserved) AMQP port.
   %%
   %% {tcp_listeners, [5672]},

   %% To listen on a specific interface, provide a tuple of {IpAddress, Port}.
   %% For example, to listen only on localhost for both IPv4 and IPv6:
   %%
   %% {tcp_listeners, [{"127.0.0.1", 5672},
   %%                  {"::1",       5672}]},

保存后重启rabbitmq-server即可使用guest用户名和密码来登录

在这里插入图片描述

RabbitMQ集群搭建

官方文档:https://www.rabbitmq.com/clustering.html

确定rabbitmq安装目录

查找rabbitmq的安装目录

[root@node01 rabbitmq-server-3.6.5]# whereis rabbitmq
rabbitmq: /usr/lib/rabbitmq /etc/rabbitmq
[root@node01 rabbitmq-server-3.6.5]# cd /usr/lib/rabbitmq/bin
[root@node01 bin]# ls
rabbitmqctl  rabbitmq-defaults  rabbitmq-env  rabbitmq-plugins  rabbitmq-server

确保RabbitMQ正常运行

rabbitmqctl status

然后停止rabbitmq服务

 systemctl stop rabbitmq-server

启动第一个节点

[root@node01 bin]# RABBITMQ_NODE_PORT=5673 RABBITMQ_NODENAME=mq1 rabbitmq-server start

              RabbitMQ 3.6.5. Copyright (C) 2007-2016 Pivotal Software, Inc.
  ##  ##      Licensed under the MPL.  See http://www.rabbitmq.com/
  ##  ##
  ##########  Logs: /var/log/rabbitmq/mq1.log
  ######  ##        /var/log/rabbitmq/mq1-sasl.log
  ##########
              Starting broker...
 completed with 6 plugins.

在这里插入图片描述

启动第二个节点

web管理插件端口占用,所以还要指定其web插件占用的端口号。

[root@node01 bin]# RABBITMQ_NODE_PORT=5674 RABBITMQ_SERVER_START_ARGS="-rabbitmq_management listener [{port,15673}]" RABBITMQ_NODENAME=mq2 rabbitmq-server start

              RabbitMQ 3.6.5. Copyright (C) 2007-2016 Pivotal Software, Inc.
  ##  ##      Licensed under the MPL.  See http://www.rabbitmq.com/
  ##  ##
  ##########  Logs: /var/log/rabbitmq/mq2.log
  ######  ##        /var/log/rabbitmq/mq2-sasl.log
  ##########
              Starting broker...
 completed with 6 plugins.

在这里插入图片描述

停止命令

[root@node01 ~]# rabbitmqctl -n mq1 stop
Stopping and halting node mq1@node01 ...

[root@node01 ~]# rabbitmqctl -n mq2 stop
Stopping and halting node mq2@node01 ...

创建集群

mq1操作作为主节点:

注意:操作节点前,确保mq处于运行状态

[root@node01 ~]# rabbitmqctl -n mq1 stop_app
Stopping node mq1@node01 ...
[root@node01 ~]# rabbitmqctl -n mq1 reset
Resetting node mq1@node01 ...
[root@node01 ~]# rabbitmqctl -n mq1 start_app
Starting node mq1@node01 ...

mq2操作为从节点:

[root@node01 ~]# rabbitmqctl -n mq2 stop_app
Stopping node mq2@node01 ...
[root@node01 ~]# rabbitmqctl -n mq2 reset
Resetting node mq2@node01 ...
[root@node01 ~]# rabbitmqctl -n mq2 join_cluster mq1@'node01'
Clustering node mq2@node01 with mq1@node01 ...
[root@node01 ~]# rabbitmqctl -n mq2 start_app
Starting node mq2@node01 ...

查看集群

[root@node01 ~]# rabbitmqctl cluster_status -n mq1
Cluster status of node mq1@node01 ...
[{nodes,[{disc,[mq1@node01,mq2@node01]}]},
 {running_nodes,[mq2@node01,mq1@node01]},
 {cluster_name,<<"mq1@node01">>},
 {partitions,[]},
 {alarms,[{mq2@node01,[]},{mq1@node01,[]}]}]

查看web监控
在这里插入图片描述

集群管理

将节点加入指定集群中

注意:需停止RabbitMQ应用并重置节点

rabbitmqctl join_cluster {cluster_node} [–ram]

显示集群的状态

rabbitmqctl cluster_status

修改集群节点的类型

注意:需要停止RabbitMQ应用

rabbitmqctl change_cluster_node_type {disc|ram}

将节点从集群中删除,允许离线执行

rabbitmqctl forget_cluster_node [–offline]

在集群中的节点应用启动前咨询clusternode节点的最新信息,并更新相应的集群信息

这个和join_cluster不同,它不加入集群。考虑这样一种情况,节点A和节点B都在集群中,当节点A离线了,节点C又和节点B组成了一个集群,然后节点B又离开了集群,当A醒来的时候,它会尝试联系节点B,但是这样会失败,因为节点B已经不在集群中了。

rabbitmqctl update_cluster_nodes {clusternode}

取消队列queue同步镜像的操作

rabbitmqctl cancel_sync_queue [-p vhost] {queue}

设置集群名称。集群名称在客户端连接时会通报给客户端。Federation和Shovel插件也会有用到集群名称的地方。集群名称默认是集群中第一个节点的名称,通过这个命令可以重新设置。

rabbitmqctl set_cluster_name {name}

RabbitMQ镜像集群配置

RabbitMQ 的默认集群模式可以让交换机、绑定等元数据复制到集群中的所有节点,从而保证这些元数据在整个集群中都是可用的。

但是,队列内容并不会被自动复制到集群中的其他节点上。这意味着,如果一个节点宕机或出现故障,就会导致该节点上的队列内容无法被消费者读取。

为了解决这个问题,需要创建镜像队列。镜像队列是一种特殊的队列类型,它会将队列的消息复制到集群中的其他节点上,从而保证在任何情况下都能够正常地消费队列的消息。

当需要构建高可用性的 RabbitMQ 集群时,通常会采用镜像队列来保证消息的传递和持久化。

启用HA策略

镜像队列是基于普通的集群模式的,然后再添加一些策略,所以还是得先配置普通集群,然后才能设置镜像队列。

设置镜像队列有2种方式:

1.通过命令设置镜像队列

rabbitmqctl set_policy ha "^" '{"ha-mode":"all"}'

2.通过网页管理端设置镜像队列

Name:策略名称

Pattern:匹配的规则,如果是匹配所有的队列,是^

Definition:使用ha-mode模式中的all,也就是同步所有匹配的队列。问号链接帮助文档

在这里插入图片描述

创建一个镜像队列

创建一个队列,然后可以看到队列开始进行同步
在这里插入图片描述
同步完成,mq1@node01节点上的队列数据向mq2@node01节点上同步
在这里插入图片描述

测试镜像队列

mq1@node01节点,向队列发送消息
在这里插入图片描述
查看mq2@node01节点的队列,发现消息已同步
在这里插入图片描述

负载均衡-HAProxy

HAProxy提供高可用性、负载均衡以及基于TCP和HTTP应用的代理,支持虚拟主机,它是免费、快速并且可
靠的一种解决方案,包括Twitter,Reddit,StackOverflow,GitHub在内的多家知名互联网公司在使用。
HAProxy实现了一种事件驱动、单一进程模型,此模型支持非常大的并发连接数。

官方下载:https://www.haproxy.org/download/

安装HAProxy

下载HAProxy的tar.gz安装包

wget https://www.haproxy.org/download/2.7/src/haproxy-2.7.6.tar.gz

解压缩安装包

tar xvfz haproxy-2.7.6.tar.gz
cd haproxy-2.7.6

查看内核版本

[root@node01 ~]# uname -r
3.10.0-1160.88.1.el7.x86_64

编译并安装HAProxy

ARGET=linux310:内核版本

ARCH=x86_64:系统位数

PREFIX=/usr/local/haproxy:haprpxy安装路径
make TARGET=linux310 PREFIX=/usr/local/haproxy ARCH=x86_64

make install PREFIX=/usr/local/haproxy

配置haproxy

建一个名为"haproxy"的用户组

# -r 将该用户组设置为系统级别的组
groupadd -r haproxy

创建一个名为"haproxy"的用户

# -g 将该用户添加到上面创建的"haproxy"用户组中
# -r 将该用户设置为系统级别用户
useradd -r -g haproxy haproxy

创建haproxy配置文件

mkdir -p /etc/haproxy

# 源码目录下执行
cp examples/quick-test.cfg /etc/haproxy/haproxy.cfg

修改配置文件/etc/haproxy/haproxy.cfg,按照需要进行配置,参考如下示例

# 全局配置参数,属于进程级的配置
global
    # 日志配置 local0:日志设备 info:日志记录级别
    log 127.0.0.1 local0 info
    # haproxy工作目录
    chroot /usr/local/haproxy
    # haproxy启动后进程的pid文件路径
    pidfile /usr/local/haproxy/haproxy.pid
    # 每个haproxy进程可接受的最大并发连接数
    maxconn 4000
    user    haproxy        
    group   haproxy  
    # haproxy启动时可创建的进程数,默认1个,值应小于服务器的CPU核数,高版本已弃用
    # nbproc  1
    # haproxy在后台运行
    daemon
    
# 默认参数配置    
defaults
    mode tcp
    log global
    option abortonclose
    option redispatch
    # 配置连接后端服务器失败重试次数,超过3次后会将失败的后端服务器标记为不可用
    retries 3
    # 配置成功连接到一台服务器的最长等待时间,默认单位是毫秒,也可自己指定单位
    timeout connect 10000
    # 配置连接客户端发送数据时的最长等待时间,默认单位是毫秒,也可自己指定单位
    timeout client 1m
    # 配置服务器端回应客户端数据发送时最长等待时间,默认单位是毫秒,也可自己指定单位
    timeout server 1m
    # 配置对后端服务器的检测超时时间,默认单位是毫秒,也可自己指定单位
    timeout check  10s
    # 最大连接数
    maxconn 3000
    
# 定义服务叫"proxy_status "名字的虚拟节点
# haproxy代理的两个mq
listen proxy_status 
	# 配置监听5672端口
    bind  0.0.0.0:5672
    	  # tcp模式  
          mode tcp
          # 轮询访问mq1与mq2
          balance roundrobin
          # mq真实IP:端口
          server node01 192.168.10.13:5673 check inter 10s
          server node02 192.168.10.13:5674 check inter 10s


# 定义服务叫"admin_stats"名字的虚拟节点     
# haproxy管理页面
frontend admin_stats 
    # 监听地址和端口
    bind  *:8888
          # http模式  
          mode http
          # 配置在客户端和服务器完成一次连接请求后,haproxy主动关闭此TCP连接
          option httpclose
          # 配置后端服务器需要获得客户端的真实IP,通过增加"X-Forwarded-For"来记录客户端IP
          option forwoardfor
          # 启用日志来记录http请求,默认只对tcp日志进行日志记录
          option httplog
          maxconn 10
          stats enable
          stats refresh 30s
          # 统计页面路径
          stats uri /admin
          # 设置统计页面认证的用户和密码
          stats auth admin:123123
          stats hide-version
          stats admin if TRUE

启动HAProxy服务

/usr/local/haproxy/sbin/haproxy -f  /etc/haproxy/haproxy.cfg

查看haproxy进程状态

[root@node01 haproxy]# ps -ef|grep haproxy
haproxy    6061      1  0 22:51 ?        00:00:00 /usr/local/haproxy/sbin/haproxy -f /etc/haproxy/haproxy.cfg
root       6318  27966  0 22:51 pts/8    00:00:00 grep --color=auto haproxy

查看HAProxy监控

访问http://192.168.10.13:8888/admin查看HAProxy监控
在这里插入图片描述

Java代码连接MQ集群

import com.rabbitmq.client.Channel;
import com.rabbitmq.client.Connection;
import com.rabbitmq.client.ConnectionFactory;

import java.io.IOException;
import java.util.concurrent.TimeoutException;

/**
 * 发送消息
 */
public class HelloWorld {
    public static void main(String[] args) throws IOException, TimeoutException {

        // 创建连接工厂
        ConnectionFactory factory = new ConnectionFactory();
        // 设置参数
        factory.setHost("192.168.10.13");// HaProxy的ip
        factory.setPort(5672); //端口 HaProxy的监听的端口
        // 创建连接 Connection
        Connection connection = factory.newConnection();
        // 创建Channel
        Channel channel = connection.createChannel();
        // 创建队列Queue
        channel.queueDeclare("hello_queue",true,false,false,null);
        String body = "hello rabbitmq";
        // 发送消息
        channel.basicPublish("","hello_queue",null,body.getBytes());
        // 释放资源
        channel.close();
        connection.close();

        System.out.println("send success....");

    }
}

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

网络(六)传输层协议介绍

目录 一、TCP协议介绍 1. 定义 2. 特性 二、TCP报文格式 1. 图示 2. 报文选项注释 三、TCP三次握手 1. 定义 2. 图示 3. 过程 四、TCP四次挥手 1. 定义 2. 图示 3. 过程 五、UDP协议介绍 六、TCP/UDP协议区别 七、TCP的三次握手中为什么不是两次、四次&…

网络爬虫第1天之数据解析库的使用

一、正则表达式 正则表达式&#xff08;Regular Expression 简称regex或regexp&#xff09;是一种强大的文本处理工具&#xff0c;它可以帮助实现快速的检索、替换或验证字符串中的特定模式。 1、match match()方法会尝试从字符串开始的位置到字符结束的位置匹配正则表达式&am…

JS中浅拷贝和深拷贝

本篇文章咱们一起来学习下JS中的浅拷贝和深拷贝&#xff0c;了解它们在内存上的区别&#xff0c;并掌握浅拷贝和深拷贝的常用实现方法。 引用赋值 在学习拷贝之前&#xff0c;咱们先来看一个常见的情景&#xff0c;如下图&#xff1a; 大家觉得这是深拷贝还是浅拷贝&#xff0…

gitee gihub上传步骤

上传 1. 到具体要上传的文件目录 2. 右击git Bash Here 初始化仓库&#xff1a;git init 3. 添加文件 添加所有文件 : git add . &#xff08;注意这里有个点&#xff09;添加具体文件&#xff1a; git add test.md 4. 添加到暂存区 git commit -m 暂存区 5. 将本地代…

深入解析HashMap数据结构及其应用

目录 引言 1. HashMap简介 2. 哈希表的基本原理 3. HashMap的内部结构 4. 哈希冲突的处理 5. HashMap的常见操作 6. HashMap的性能优化 7. 实际应用场景 结论 引言 在计算机科学中&#xff0c;数据结构是构建和组织数据的一种方式&#xff0c;而HashMap是其中一种常用…

Wiley将废除OA期刊“Hindawi”,MDPI、Frontier系列OA期刊将受巨大影响

公众号&#xff1a;生信漫谈&#xff0c;获取最新科研信息&#xff01; Wiley将废除OA期刊“Hindawi”&#xff0c;MDPI、Frontier系列OA期刊将受巨大影响https://mp.weixin.qq.com/s/w1QvXnHHDV04gbABUxo3kA 周三上午&#xff0c;知名国际出版商Wiley在财报电话会议上宣布&a…

Java小案例-RocketMQ的11种消息类型,你知道几种?(请求应答消息)

前言 Rocket的请求应答消息是指在使用Rocket&#xff08;这里可能是RocketMQ或者Rocket框架&#xff09;进行通信时&#xff0c;客户端发送一个请求到服务端&#xff0c;然后服务端处理该请求并返回一个响应的过程中的数据交换。 在RocketMQ中&#xff1a; 请求应答消息通常…

代码随想录算法训练营Day4 | 24.两两交换链表中的节点、19.删除链表的倒数第 N 个节点、面试题. 链表相交、142.环形链表II

LeetCode 24 两两交换链表中的节点 本题要注意的条件&#xff1a; 遍历终止条件改变引用指向的时候&#xff0c;需要保存一些节点记录 为了更好的操作链表&#xff0c;我定义了一个虚拟的头节点 dummyHead 指向链表。如下图所示 既然要交换链表中的节点&#xff0c;那么肯定…

在线学习平台,云课堂云教育类网站源码,在线题库+随身携带的刷题神器+视频安装教程

源码介绍 在线题库&#xff1a;由传统的线下学习模式改为在线学习。能够实现学员在线学习、练习、考试 优点&#xff1a;方便、便宜、自我管理、选择性更多 、成人教育 &#xff08;1&#xff09;公考&#xff1a;国考、省考、事业单位… &#xff08;2&#xff09;升学&…

9. DashBoard

9. DashBoard 文章目录 9. DashBoard9.1 部署Dashboard9.2 使用DashBoard 在kubernetes中完成的所有操作都是通过命令行工具kubectl完成的。 为了提供更丰富的用户体验&#xff0c;kubernetes还开发了一个基于web的用户界面&#xff08;Dashboard&#xff09;。 用户可以使用…

在Windows上通过VS2019自带的Cmake来编译OpenCV-4.5.3源码

文章目录 用VS打开OpenCV源码cmake的配置及生成操作生成及安装 用VS打开OpenCV源码 方式一&#xff1a;文件–》打开–》Cmake 找到源码根目录下CMakeLists.txt文件 导入即可。 方式二&#xff1a;在开始使用这里 选择 打开本地文件夹 找到源码的根目录&#xff0c;导入即可…

「斗罗二」七怪大赛1击穿12,蝶神斩打爆人面魔蛛,二代七怪诞生

Hello,小伙伴们&#xff0c;我是拾荒君。 《斗罗大陆Ⅱ绝世唐门》第27集的更新&#xff0c;为我们带来了激烈的二代七怪竞选大赛的精彩瞬间。在这一集中&#xff0c;新一代史莱克七怪的表现尤为出色&#xff0c;他们面对的挑战也愈发艰难。 比赛进行得如火如荼&#xff0c;贝贝…

[ 云计算 | Azure 实践 ] 在 Azure 门户中创建 VM 虚拟机并进行验证

文章目录 一、前言二、在 Azure Portal 中创建 VM三、验证已创建的虚拟机资源3.1 方法一&#xff1a;在虚拟机服务中查看验证3.1 方法二&#xff1a;在资源组服务中查看验证 四、文末总结 一、前言 本文会开始创建新系列的专栏&#xff0c;专门更新 Azure 云实践相关的文章。 …

linux日志管理_日志轮转logrotate

10.2 日志轮转logrotate 10.2.1 简介 日志&#xff1a;记录了程序运行时各种信息。通过日志可以分析用户行为&#xff0c;记录运行轨迹&#xff0c;查找程序问题。 ​ 但由于磁盘的空间是有限的&#xff0c;日志轮转就像飞机里的黑匣子&#xff0c;记录的信息再重要也只能记录…

flume系列之:监控flume agent channel的填充百分比

flume系列之:监控flume agent channel的填充百分比 一、监控效果二、获取flume agent三、飞书告警四、获取每个flume agent channel的填充百分比一、监控效果 二、获取flume agent def getKafkaFlumeAgent():# 腾讯云10.130.112.60zk = KazooClient(hosts

【案例】--“特别抢购”案例

目录 一、案例背景二、技术方案思路三、技术方案具体设计3.1、表设计3.2、Java代码实现一、案例背景 A公司向供应商B公司买了一套软件产品。B公司的这套产品有多个应用系统服务【如appId1、appId2、appId3】,每个应用都有各自的业务应用场景,但都需要管理文档,那么就需要磁…

Linux驱动(中断、异步通知):红外对射,并在Qt StatusBus使用指示灯进行显示

本文工作&#xff1a; 1、Linux驱动与应用程序编写&#xff1a;使用了设备树、中断、异步通知知识点&#xff0c;实现了红外对射状态的异步信息提醒。 2、QT程序编写&#xff1a;自定义了一个“文本指示灯”类&#xff0c;并放置在QMainWidget的StatusBus中。 3、C与C混合编程与…

C++:函数重载

1.函数重载概念 函数重载就是用同一个函数名定义的不同函数&#xff0c;当函数名和不同的参数搭配时函数的功能和含义不同。 2.实现函数重载的条件 同一个作用域&#xff0c;参数个数不同或者参数类型不同或者参数顺序不同(满足一个即可) void func(){} void func(int x){} v…

55 代码审计-JAVA项目注入上传搜索或插件挖掘

目录 必备知识点演示案例:简易Demo段SQL注入及预编译IDEA审计插件FindBugs安装使用Fortify_SCA代码自动审计神器使用Ofcms后台SQL注入-全局搜索关键字Ofcms后台任意文件上传-功能点测试 涉及资源&#xff1a; 我们一般针对java项目&#xff0c;进行漏洞分析的话&#xff0c;主要…

SolidWorks二次开发 C#-读取基于Excel的BOM表信息

SolidWorks二次开发 C#-读取基于Excel的BOM表信息 问题点来源解决方案及思路相关引用链接 问题点来源 这是一位粉丝问的一个问题&#xff0c;他说到: 老师&#xff0c;请问Solidworks二次开发工程图中"基于Excel的材料明细表"怎么读取里面的数据&#xff1f; Ps:这…