RabbitMQ支持的消息模型

  • RabbitMQ基础
  • RabbitMQ支持的消息模型

一、第一种模型(直连)

我们将用Java编写两个程序,发送单个消息的生成者和接收消息并打印出来的消费者。
在下图,“P”是生成者,“C”消费者。中间框是一个队列RabbitMQ保留的消息缓冲区 。

首先构建一个Maven项目,然后引入依赖。

<!-- 导入rabbitmq原生依赖-->
<dependency><groupId>com.rabbitmq</groupId><artifactId>amqp-client</artifactId><version>5.10.0</version>
</dependency>
定义生产者
import com.duan.rabbitmq.utils.RabbitMqUtil;
import com.rabbitmq.client.Channel;
import com.rabbitmq.client.Connection;
import com.rabbitmq.client.ConnectionFactory;
import com.rabbitmq.client.MessageProperties;import java.io.IOException;
import java.util.concurrent.TimeoutException;/**
* @author db
* @version 1.0
* @description Provider 生产者代码
* @since 2022/12/29
*/
public class Producer {public static void main(String[] args) throws IOException, TimeoutException {//        // 1.创建连接工厂//        ConnectionFactory connectionFactory = new ConnectionFactory();//        // 2.设置连接属性//        connectionFactory.setHost("192.168.137.120");//        connectionFactory.setPort(5672);//        connectionFactory.setVirtualHost("/");//        connectionFactory.setUsername("admin");//        connectionFactory.setPassword("123456");//        connectionFactory.setHandshakeTimeout(60000);////        // 3.从连接工厂获得连接//        Connection connection = connectionFactory.newConnection();// 从工具类中获得连接Connection connection = RabbitMqUtil.getConnection();// 4.从连接中获得channelChannel channel = connection.createChannel();// 5.声明队列queue存储消息/*** 参数s:队列名称 如果队列不存在就自动创建* 参数b:用来定义队列特性是否要持久化 true 持久化队列  false 不持久化* 参数b1: exclusive 是否独占队列  true 独占队列 false 不独占* 参数b2:autoDelete 是否在消费完成后自动删除队列 true 自动删除 false 不自动删除* 参数5:额外附加参数**/channel.queueDeclare("hello",true,false,false,null);// 7.发送消息给中间件// 参数1:交换机名称 参数2:队列名称 参数3:传递消息的额外设置 参数4:channel.basicPublish("","hello", MessageProperties.PERSISTENT_TEXT_PLAIN,"hello rabbitmq".getBytes());System.out.println("消息发送成功");//        // 8.关闭连接//        channel.close();//        connection.close();RabbitMqUtil.closeConnectionAndChannel(channel,connection);}
}

执行发送,这个时候可以在web控制台查看到这个队列queue的信息。

定义消费者

import com.duan.rabbitmq.utils.RabbitMqUtil;
import com.rabbitmq.client.*;import java.io.IOException;
import java.util.concurrent.TimeoutException;/*** @author db* @version 1.0* @description Consumer  消费者* @since 2022/12/29*/
public class Consumer {public static void main(String[] args) throws IOException, TimeoutException {
//        ConnectionFactory connectionFactory = new ConnectionFactory();
//        connectionFactory.setHost("192.168.137.120");
//        connectionFactory.setPort(5672);
//        connectionFactory.setVirtualHost("/");
//        connectionFactory.setUsername("admin");
//        connectionFactory.setPassword("123456");
//        connectionFactory.setHandshakeTimeout(60000);
//
//        // 创建连接
//        Connection connection = connectionFactory.newConnection();// 从工具类中获得连接Connection connection = RabbitMqUtil.getConnection();// 创建信道Channel channel = connection.createChannel();// 消费者成功消费时的回调DeliverCallback deliverCallback = (consumerTag,message) ->{System.out.println(new String(message.getBody()));};// 消费者取消消费时的回调CancelCallback callback = consumerTag ->{System.out.println("消费者取消消费接口的回调");};// 参数1:消费队列的名称// 参数2:消息的自动确认机制(已获得消息就通知MQ消息已被消费)true 打开 false 关闭// 参数3:channel.basicConsume("hello",true,deliverCallback,callback);//        channel.close();
//        connection.close();}
}

工具类的包装

package com.duan.rabbitmq.utils;import com.rabbitmq.client.Channel;
import com.rabbitmq.client.Connection;
import com.rabbitmq.client.ConnectionFactory;/*** @author db* @version 1.0* @description RabbitMqUtil* @since 2023/1/2*/
public class RabbitMqUtil {// 定义提供连接对象的方法public static Connection getConnection(){try{// 1.创建连接工厂ConnectionFactory connectionFactory = new ConnectionFactory();// 2.设置连接属性connectionFactory.setHost("192.168.137.120");connectionFactory.setPort(5672);connectionFactory.setVirtualHost("/");connectionFactory.setUsername("admin");connectionFactory.setPassword("123456");connectionFactory.setHandshakeTimeout(60000);return connectionFactory.newConnection();}catch (Exception e){e.printStackTrace();}return null;}// 关闭连接通道和关闭连接的工具方法public static void closeConnectionAndChannel(Channel channel,Connection connection){try{if(channel !=null){channel.close();}if(connection != null){connection.close();}}catch (Exception e){e.printStackTrace();}}
}

报连接超时错误

**解决方案:**原因是连接超时,加超时时间。

maevn项目设置超时时间:factory.setHandshakeTimeout\(60000\)

二、第二种模型(work quene)

work queues被称为任务队列(Task queues)。当消息处理比较耗时的时候,可能生产消息的速度会远远大于消息的消费速度。长此以往,消息就会堆积越来越多,无法及时处理。此时就可以使用work 模型: 让多个消费者绑定到一个队列,共同消费队列中的消息。 队列中的消息一旦消费,就会消失,因此任务是不会被重复执行的。

  • P:生产者
  • C1:消费者1
  • C2:消费者2
定义生成者
package com.duan.rabbitmq.work;import com.duan.rabbitmq.utils.RabbitMqUtil;
import com.rabbitmq.client.Channel;
import com.rabbitmq.client.Connection;import java.io.IOException;/*** @author db* @version 1.0* @description Producer* @since 2023/3/24*/
public class Producer {public static void main(String[] args) throws IOException {Connection connection = RabbitMqUtil.getConnection();Channel channel = connection.createChannel();/*** 声明队列queue存储信息* 参数1: 队列名称* 参数2: 用来定义队列是否要持久化* 参数3: exclusion 是否是独占队列* 参数4: autoDelete 是否再消费完成后自动删除队列* 参数5: 额外附加参数*/channel.queueDeclare("work",true,false,false,null);for(int i = 0; i<10; i++){// 参数1:交换机名称 参数2:队列名称 参数3:消息传递的额外设置channel.basicPublish("","work",null,(i+"work").getBytes());}RabbitMqUtil.closeConnectionAndChannel(channel,connection);}
}
定义消费者1
package com.duan.rabbitmq.work;import com.duan.rabbitmq.utils.RabbitMqUtil;
import com.rabbitmq.client.*;import java.io.IOException;/*** @author db* @version 1.0* @description Consumer1* @since 2023/3/24*/
public class Consumer1 {public static void main(String[] args) throws IOException {Connection connection = RabbitMqUtil.getConnection();// 创建信道Channel channel = connection.createChannel();// 消费者消费成功时的回调channel.queueDeclare("work",true,false,false,null);channel.basicConsume("work",true,new DefaultConsumer(channel){@Overridepublic void handleDelivery(String consumerTag, Envelope envelope, AMQP.BasicProperties properties, byte[] body) throws IOException{System.out.println("消费者1: "+new String(body));}});RabbitMqUtil.closeConnectionAndChannel(channel,connection);}
}
定义消费者2
package com.duan.rabbitmq.work;import com.duan.rabbitmq.utils.RabbitMqUtil;
import com.rabbitmq.client.*;import java.io.IOException;/*** @author db* @version 1.0* @description Consumer1* @since 2023/3/24*/
public class Consumer2 {public static void main(String[] args) throws IOException {Connection connection = RabbitMqUtil.getConnection();// 创建信道Channel channel = connection.createChannel();// 消费者消费成功时的回调channel.queueDeclare("work",true,false,false,null);channel.basicConsume("work",true,new DefaultConsumer(channel){@Overridepublic void handleDelivery(String consumerTag, Envelope envelope, AMQP.BasicProperties properties, byte[] body) throws IOException{try{Thread.sleep(2000);}catch (Exception e){e.printStackTrace();}System.out.println("消费者2: "+new String(body));}});RabbitMqUtil.closeConnectionAndChannel(channel,connection);}
}

rabbitMQ讲按照顺序将每个消息发给下一个使用者,每个消费者都会收到相同数量的消息。
测试结果

消息确认机制

前面看到的是所有的消费者均分消息,会有一个问题,如果一个消费者宕机了,会出现消息丢失现场,希望当出现消费者宕机时,消息被另一个消费者消费,也就是多劳多得生产者代码。

package com.duan.rabbitmq.work;import com.duan.rabbitmq.utils.RabbitMqUtil;
import com.rabbitmq.client.Channel;
import com.rabbitmq.client.Connection;import java.io.IOException;/*** @author db* @version 1.0* @description Producer* @since 2023/3/24*/
public class Producer {public static void main(String[] args) throws IOException {Connection connection = RabbitMqUtil.getConnection();Channel channel = connection.createChannel();/*** 声明队列queue存储信息* 参数1: 队列名称* 参数2: 用来定义队列是否要持久化* 参数3: exclusion 是否是独占队列* 参数4: autoDelete 是否再消费完成后自动删除队列* 参数5: 额外附加参数*/channel.queueDeclare("work",true,false,false,null);for(int i = 0; i<20; i++){// 参数1:交换机名称 参数2:队列名称 参数3:消息传递的额外设置channel.basicPublish("","work",null,(i+"work").getBytes());}RabbitMqUtil.closeConnectionAndChannel(channel,connection);}
}

生成者1

package com.duan.rabbitmq.work;import com.duan.rabbitmq.utils.RabbitMqUtil;
import com.rabbitmq.client.*;import java.io.IOException;/*** @author db* @version 1.0* @description Consumer3* @since 2023/11/27*/
public class Consumer3 {public static void main(String[] args) throws IOException {Connection connection = RabbitMqUtil.getConnection();// 创建信道Channel channel = connection.createChannel();channel.basicQos(1); // 每次只消费一个消息// 消费者消费成功时的回调channel.queueDeclare("work",true,false,false,null);channel.basicConsume("work",false,new DefaultConsumer(channel){@Overridepublic void handleDelivery(String consumerTag, Envelope envelope, AMQP.BasicProperties properties, byte[] body) throws IOException{System.out.println("消费者1: "+new String(body));// 手动确认,参数1:消息标识  参数2:每次确认1个channel.basicAck(envelope.getDeliveryTag(),false);}});}
}

生成者2

package com.duan.rabbitmq.work;import com.duan.rabbitmq.utils.RabbitMqUtil;
import com.rabbitmq.client.*;import java.io.IOException;/*** @author db* @version 1.0* @description Consumer4* @since 2023/11/27*/
public class Consumer4 {public static void main(String[] args) throws IOException {Connection connection = RabbitMqUtil.getConnection();// 创建信道Channel channel = connection.createChannel();channel.basicQos(1);  // 每次消费一个消息// 消费者消费成功时的回调channel.queueDeclare("work",true,false,false,null);channel.basicConsume("work",false,new DefaultConsumer(channel){@Overridepublic void handleDelivery(String consumerTag, Envelope envelope, AMQP.BasicProperties properties, byte[] body) throws IOException{try{Thread.sleep(2000);}catch (Exception e){e.printStackTrace();}System.out.println("消费者2: "+new String(body));channel.basicAck(envelope.getDeliveryTag(),false);}});}
}

测试结果

三、第三种模型(Fanout)

广播模式下:发送消息流程是可以有多个消费者每个消费者都有自己的队列(queue)每个队列都要绑定交换机(exchange)生成者发送消息,只能发送到交换机,交换机决定把消息发给哪个队列,生成者无法决定交换机把消息发给绑定过的所有队列,队列的消费者都能拿到消息,一条消息可以被多个消费者消费。

生产者
package com.duan.rabbitmq.fanout;import com.duan.rabbitmq.utils.RabbitMqUtil;
import com.rabbitmq.client.Channel;
import com.rabbitmq.client.Connection;import java.io.IOException;/*** @author db* @version 1.0* @description Provider* @since 2023/11/28*/
public class Provider {public static void main(String[] args) throws IOException {// 获取连接对象Connection connection = RabbitMqUtil.getConnection();Channel channel = connection.createChannel();// 将通道声明交换机  参数1:交换机名称 参数2:交换机类型channel.exchangeDeclare("logs","fanout");// 发送消息channel.basicPublish("logs","",null,"fanout type message".getBytes());// 释放资源RabbitMqUtil.closeConnectionAndChannel(channel,connection);}
}
消费者1
package com.duan.rabbitmq.fanout;import com.duan.rabbitmq.utils.RabbitMqUtil;
import com.rabbitmq.client.*;import java.io.IOException;/*** @author db* @version 1.0* @description Customer1* @since 2023/11/28*/
public class Customer1 {public static void main(String[] args) throws IOException {// 获得连接对象Connection connection = RabbitMqUtil.getConnection();Channel channel = connection.createChannel();// 通道绑定交换机channel.exchangeDeclare("logs","fanout");// 绑定临时队列String queue = channel.queueDeclare().getQueue();// 绑定交换机和队列channel.queueBind(queue,"logs","");// 消费消息channel.basicConsume(queue,true,new DefaultConsumer(channel){@Overridepublic void handleDelivery(String consumerTag, Envelope envelope, AMQP.BasicProperties properties, byte[] body) throws IOException {System.out.println("消费者1: "+new String(body));}});}
}
消费者2
package com.duan.rabbitmq.fanout;import com.duan.rabbitmq.utils.RabbitMqUtil;
import com.rabbitmq.client.*;import java.io.IOException;/*** @author db* @version 1.0* @description Customer1* @since 2023/11/28*/
public class Customer2 {public static void main(String[] args) throws IOException {// 获得连接对象Connection connection = RabbitMqUtil.getConnection();Channel channel = connection.createChannel();// 通道绑定交换机channel.exchangeDeclare("logs","fanout");// 绑定临时队列String queue = channel.queueDeclare().getQueue();// 绑定交换机和队列channel.queueBind(queue,"logs","");// 消费消息channel.basicConsume(queue,true,new DefaultConsumer(channel){@Overridepublic void handleDelivery(String consumerTag, Envelope envelope, AMQP.BasicProperties properties, byte[] body) throws IOException {System.out.println("消费者2: "+new String(body));}});}
}
消费者3
package com.duan.rabbitmq.fanout;import com.duan.rabbitmq.utils.RabbitMqUtil;
import com.rabbitmq.client.*;import java.io.IOException;/*** @author db* @version 1.0* @description Customer1* @since 2023/11/28*/
public class Customer3 {public static void main(String[] args) throws IOException {// 获得连接对象Connection connection = RabbitMqUtil.getConnection();Channel channel = connection.createChannel();// 通道绑定交换机channel.exchangeDeclare("logs","fanout");// 绑定临时队列String queue = channel.queueDeclare().getQueue();// 绑定交换机和队列channel.queueBind(queue,"logs","");// 消费消息channel.basicConsume(queue,true,new DefaultConsumer(channel){@Overridepublic void handleDelivery(String consumerTag, Envelope envelope, AMQP.BasicProperties properties, byte[] body) throws IOException {System.out.println("消费者3: "+new String(body));}});}
}
测试结果

四、第四种模型(Routing)

fanout模式中,一条消息,会被所有绑定的队列都能消费,但是,在某些场景下,希望不同的消息被不同的队列消费,就需要Direct类型的exchange

Direct模型下:队列与交换机的绑定,不是任意绑定的,而是要指定一个RoutingKey(路由key)消息的发送方在向Exchange发送消息时,也必须指定消息的 RoutingKeyExchange不再把消息交给每一个绑定的队列,而是根据消息的Routing Key进行判断,只有队列的Routingkey与消息的 Routing key完全一致,才会接收到消息。

生产者
package com.duan.rabbitmq.direct;import com.duan.rabbitmq.utils.RabbitMqUtil;
import com.rabbitmq.client.Channel;
import com.rabbitmq.client.Connection;import java.io.IOException;/*** @author db* @version 1.0* @description Provider* @since 2023/11/28*/
public class Provider {public static void main(String[] args) throws IOException {// 建立连接Connection connection = RabbitMqUtil.getConnection();Channel channel = connection.createChannel();channel.exchangeDeclare("logs_direct","direct");String routingKey = "error";channel.basicPublish("logs_direct",routingKey,null,("这是direct模型发布的基于route key: ["+routingKey+"] 发送的消息").getBytes());RabbitMqUtil.closeConnectionAndChannel(channel,connection);}
}
消费者1
package com.duan.rabbitmq.direct;import com.duan.rabbitmq.utils.RabbitMqUtil;
import com.rabbitmq.client.*;import java.io.IOException;/*** @author db* @version 1.0* @description Consumer1* @since 2023/11/28*/
public class Consumer1 {public static void main(String[] args) throws IOException {// 获得连接对象Connection connection = RabbitMqUtil.getConnection();Channel channel = connection.createChannel();// 通道绑定交换机channel.exchangeDeclare("logs_direct","direct");// 绑定临时队列String queue = channel.queueDeclare().getQueue();// 绑定交换机和队列channel.queueBind(queue,"logs_direct","error");// 消费消息channel.basicConsume(queue,true,new DefaultConsumer(channel){@Overridepublic void handleDelivery(String consumerTag, Envelope envelope, AMQP.BasicProperties properties, byte[] body) throws IOException {System.out.println("消费者1: "+new String(body));}});}
}
消费者2
package com.duan.rabbitmq.direct;import com.duan.rabbitmq.utils.RabbitMqUtil;
import com.rabbitmq.client.*;import java.io.IOException;/*** @author db* @version 1.0* @description Consumer1* @since 2023/11/28*/
public class Consumer2 {public static void main(String[] args) throws IOException {// 获得连接对象Connection connection = RabbitMqUtil.getConnection();Channel channel = connection.createChannel();// 通道绑定交换机channel.exchangeDeclare("logs_direct","direct");// 绑定临时队列String queue = channel.queueDeclare().getQueue();// 绑定交换机和队列channel.queueBind(queue,"logs_direct","info");channel.queueBind(queue,"logs_direct","error");channel.queueBind(queue,"logs_direct","warning");// 消费消息channel.basicConsume(queue,true,new DefaultConsumer(channel){@Overridepublic void handleDelivery(String consumerTag, Envelope envelope, AMQP.BasicProperties properties, byte[] body) throws IOException {System.out.println("消费者1: "+new String(body));}});}
}
测试结果

routingKeyinfo时,消费者1和消费者2结果如下:

routingKeyerror时,消费者1和消费者2结果如下:

五、第五种模型(topic)

Topic类型的ExchangeDirect相比,都是可以根据RoutingKey把消息路由到不同的队列。只不过Topic类型Exchange可以让队列在绑定BindingKey 的时候使用通配符!BindingKey 一般都是有一个或多个单词组成,多个单词之间以.分割,例如: item.insert通配符规则:

  • #:匹配一个或多个词
  • *:匹配不多不少恰好1个词

举例:

  • item.#:能够匹配item.spu.insert 或者 item.spu
  • item.*:只能匹配item.spu
生产者
package com.duan.rabbitmq.topic;import com.duan.rabbitmq.utils.RabbitMqUtil;
import com.rabbitmq.client.Channel;
import com.rabbitmq.client.Connection;import java.io.IOException;/*** @author db* @version 1.0* @description Provider* @since 2023/11/30*/
public class Provider {public static void main(String[] args) throws IOException {//获取连接对象Connection connection = RabbitMqUtil.getConnection();Channel channel = connection.createChannel();//声明交换机以及交换机类型 topicchannel.exchangeDeclare("topics","topic");//发布消息String routekey = "save.user.delete";channel.basicPublish("topics",routekey,null,("这里是topic动态路由模型,routekey: ["+routekey+"]").getBytes());//关闭资源RabbitMqUtil.closeConnectionAndChannel(channel,connection);}}
消费者1
package com.duan.rabbitmq.topic;import com.duan.rabbitmq.utils.RabbitMqUtil;
import com.rabbitmq.client.*;import java.io.IOException;/*** @author db* @version 1.0* @description Customer1* @since 2023/11/30*/
public class Customer1 {public static void main(String[] args) throws IOException {// 获得连接对象Connection connection = RabbitMqUtil.getConnection();Channel channel = connection.createChannel();// 通道绑定交换机channel.exchangeDeclare("topics","topic");// 绑定临时队列String queue = channel.queueDeclare().getQueue();// 绑定交换机和队列channel.queueBind(queue,"topics","*.user.*");// 消费消息channel.basicConsume(queue,true,new DefaultConsumer(channel){@Overridepublic void handleDelivery(String consumerTag, Envelope envelope, AMQP.BasicProperties properties, byte[] body) throws IOException {System.out.println("消费者1: "+new String(body));}});}
}
消费者2
package com.duan.rabbitmq.topic;import com.duan.rabbitmq.utils.RabbitMqUtil;
import com.rabbitmq.client.*;import java.io.IOException;/*** @author db* @version 1.0* @description Customer1* @since 2023/11/30*/
public class Customer2 {public static void main(String[] args) throws IOException {// 获得连接对象Connection connection = RabbitMqUtil.getConnection();Channel channel = connection.createChannel();// 通道绑定交换机channel.exchangeDeclare("topics","topic");// 绑定临时队列String queue = channel.queueDeclare().getQueue();// 绑定交换机和队列channel.queueBind(queue,"topics","*.user.#");// 消费消息channel.basicConsume(queue,true,new DefaultConsumer(channel){@Overridepublic void handleDelivery(String consumerTag, Envelope envelope, AMQP.BasicProperties properties, byte[] body) throws IOException {System.out.println("消费者1: "+new String(body));}});}
}
测试结果

代码地址:https://gitee.com/duan138/practice-code/tree/dev/rabbitmq-java

六、总结

以上就是rabbitMQ中常见的几种模式,这些模型通过交换机(Exchange)和队列(Queue)的不同组合与绑定方式实现。本文只是初步了解RabbitMQ相关知识。后续会讲解怎么在SpringBoot中应用。


改变你能改变的,接受你不能改变的,关注公众号:程序员康康,一起成长,共同进步。

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

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

相关文章

思维,1209G1 - Into Blocks (easy version)

一、题目 1、题目描述 2、输入输出 2.1输入 2.2输出 3、原题链接 Problem - 1209G1 - Codeforces 二、解题报告 1、思路分析 考虑&#xff1a; 最终状态为若干段相同数字&#xff0c;且任意两段数字不同 每个数字出现的最左下标和最右下标构成一个区间 连锁反应—…

算法金 | 10 大必知的自动化机器学习库(Python)

大侠幸会&#xff0c;在下全网同名[算法金] 0 基础转 AI 上岸&#xff0c;多个算法赛 Top [日更万日&#xff0c;让更多人享受智能乐趣] 一、入门级自动化机器学习库 1.1 Auto-Sklearn 简介&#xff1a; Auto-Sklearn 是一个自动机器学习库&#xff0c;基于 Python 的 scikit…

【网络编程开发】4.socket套接字及TCP的实现框架 5.TCP多进程并发

4.socket套接字及TCP的实现框架 Socket套接字 Socket套接字是网络编程中用于实现不同计算机之间通信的一个基本构建块。 在现代计算机网络中&#xff0c;Socket套接字扮演着至关重要的角色。它们为应用程序提供了一种方式&#xff0c;通过这种方式&#xff0c;程序能够通过网…

2024年城市建设与环境管理国际会议(ICUCEM 2024)

2024 International Conference on Urban Construction and Environmental Management 【1】大会信息 大会地点&#xff1a;中国成都 投稿邮箱&#xff1a;icucemsub-paper.com 【2】会议简介 2024年城市建设与环境管理国际会议是一个专注于探讨城市建设与环境管理前沿议题…

EasyRecovery2024终极破解指南来袭!

在数字化时代&#xff0c;数据成为了每个人、每家公司最宝贵的资产之一。无论是个人的照片、文档&#xff0c;还是公司的机密信息&#xff0c;一旦丢失&#xff0c;后果不堪设想。因此&#xff0c;数据恢复工具如EasyRecovery2024应运而生&#xff0c;成为了保护数据安全的利器…

kubeedge v1.17.0部署教程

文章目录 前言一、安装k8s平台二、部署kubeedge1.部署MetalLB(可选)2.cloud3.edge4. 部署nginx到edge端 总结参考 前言 本文主要介绍kubeedge v1.17.0的安装过程 主要环境如下表 应用版本centos7.0k8s1.28.2kubeedge1.17.0docker24.0.8centos7.0 一、安装k8s平台 本文主要参…

Doris Connector 结合 Flink CDC 实现 MySQL 分库分表

1. 概述 在实际业务系统中为了解决单表数据量大带来的各种问题&#xff0c;我们通常采用分库分表的方式对库表进行拆分&#xff0c;以达到提高系统的吞吐量。 但是这样给后面数据分析带来了麻烦&#xff0c;这个时候我们通常试将业务数据库的分库分表同步到数据仓库时&#x…

英伟达Docker 安装与GPu镜像拉取

获取nvidia_docker压缩包nvidia_docker.tgz将压缩包上传至服务器指定目录解压nvidia_docker.tgz压缩包 tar -zxvf 压缩包执行rpm安装命令&#xff1a; #查看指定rpm包安装情况 rpm -qa | grep libstdc #查看指定rpm包下的依赖包的版本情况 strings /lib64/libstdc |grep GLI…

【代码随想录】【算法训练营】【第25天】 [216]组合总和III [17] 电话号码的字母组合

前言 思路及算法思维&#xff0c;指路 代码随想录。 题目来自 LeetCode。 day 25&#xff0c;周六&#xff0c;坚持有点困难~ 题目详情 [216] 组合总和III 题目描述 216 组合总和III 解题思路 前提&#xff1a;组合子集问题 思路&#xff1a;回溯算法&#xff0c;剪枝…

347. 前 K 个高频元素

题目 给你一个整数数组 nums 和一个整数 k &#xff0c;请你返回其中出现频率前 k 高的元素。你可以按 任意顺序 返回答案。 示例 1: 输入: nums [1,1,1,2,2,3], k 2 输出: [1,2] 示例 2: 输入: nums [1], k 1 输出: [1] 提示&#xff1a; 1 < nums.length < 1…

基于聚类与统计检验深度挖掘电商用户行为

1.项目背景 在当今竞争激烈的电商市场中,了解用户的行为和需求对于制定成功的市场策略至关重要,本项目通过建立RFM模型、K-Means聚类模型,将1000个用户进行划分,针对不同类的用户,提出不同的营销策略,最后通过统计检验来探究影响用户消费行为的因素和影响用户上网行为的…

DBeaver连接Oracle报错:ORA-12514

Listener refused the connection with the following error:ORA-12514, TNS:listener does not currently know of service requested inconnect descriptor ———————————————— 1.报错信息2.配置正确结语 ———————————————— 如果是第一次连接Or…

Spring 使用SSE(Server-Sent Events)学习

什么是SSE SSE 即服务器发送事件&#xff08;Server-Sent Events&#xff09;&#xff0c;是一种服务器推送技术&#xff0c;允许服务器在客户端建立连接后&#xff0c;主动向客户端推送数据。 SSE 基于 HTTP 协议&#xff0c;使用简单&#xff0c;具有轻量级、实时性和断线重…

Go微服务: 基于rocketmq:5.2.0搭建RocketMQ环境,以及示例参考

概述 参考最新官方文档&#xff1a;https://rocketmq.apache.org/zh/docs/quickStart/03quickstartWithDockercompose以及&#xff1a;https://rocketmq.apache.org/zh/docs/deploymentOperations/04Dashboard综合以上两个文档来搭建环境 搭建RocketMQ环境 1 ) 基于 docker-c…

速通数据挖掘课程

速通 数据挖掘课程 大的分类 标签预测&#xff08;分类&#xff09; 和 数值预测&#xff08;预测呀&#xff09; 监督 非监督 是否 需要预先训练模型 然后预测 聚类&#xff1a;拿一个比一个&#xff0c;看看相似否&#xff0c;然后归一类 数据四种类型 数据属性有四种&…

simplicity studio 5 修改设备电压

工装板的soc额定输入电压为1.5v&#xff0c;而常态下ttl高电平为5v/3.3v&#xff0c;所以需要设定烧录程序时的设备电压。 确保连接设备&#xff0c;并且被识别。 进入管理员模式。 烧录.hex文件快捷方法。

人工智能芯片封装技术及应用趋势分析

简介人工智能&#xff08;AI&#xff09;、物联网&#xff08;IoT&#xff09;和大数据的融合正在开创全新的智能时代&#xff0c;以智能解决方案改变各行各业。人工智能芯片在支持人工智能学习和推理计算方面发挥着非常重要的作用&#xff0c;可实现各行各业的多样化应用。 本…

HTML+CSS+JS 动态登录表单

效果演示 实现了一个登录表单的背景动画效果,包括一个渐变背景、一个输入框和一个登录按钮。背景动画由多个不同大小和颜色的正方形组成,它们在页面上以不同的速度和方向移动。当用户成功登录后,标题会向上移动,表单会消失。 Code <!DOCTYPE html> <html lang=&q…

电阻、电容和电感测试仪设计

在现代化生产、学习、实验当中,往往需要对某个元器件的具体参数进行测量,在这之中万用表以其简单易用,功耗低等优点被大多数人所选择使用。然而万用表有一定的局限性,比如:不能够测量电感,而且容量稍大的电容也显得无能为力。所以制作一个简单易用的电抗元器件测量仪是很…

智能视频监控平台LntonCVS视频汇聚共享平台智慧楼宇应用方案

随着城市经济的迅速发展&#xff0c;大中型城市的写字楼数量不断增加。在像香港、台北、上海、北京等大城市&#xff0c;写字楼的安保成本相当高。为了降低这一成本&#xff0c;越来越多的物业公司开始采用技术手段。写字楼安防监控系统便是其中之一&#xff0c;它利用安全防范…