互联网全景消息(1)之RabbitMq基础入门

news2025/1/14 1:14:59

一、消息中间件

1.1消息队列回顾

        消息队列中间件是分布式系统中重要的组件,主要解决应用解耦,异步消息,流量削锋等问题,实 现高性能,高可用,可伸缩和最终一致性架构。目前使用较多的消息队列有ActiveMQ  RabbitMQZeroMQ  Kafka  MetaMQ  RocketMQ

        消息中间件利用高效可靠的消息传递机制进行平台无关的数据交流,并基于数据通信来进行分布式 系统的集成。通过提供消息传递和消息排队模型,它可以在分布式环境下扩展进程间的通信。对于消息 中间件,常见的角色大致也就有 Producer(生产者)  Consumer(消费者) 

1.2 消息队列特性

   1.2.1 先进先出

        消息队列的顺序在入队的时候就基本已经确定了,  一般是不需 人工干预的。而且,最重要的是, 数据是只有一条数据在使用中。 这也是MQ在诸多场景被使用的原因。

   1.2.2 发布订阅

         一般是MQ的广播模式,类似于java的观察者模式。

        发布订阅是一种很高效的处理方式,如果不发生阻塞,基本可以当做是同步操作。这种处理方式能 非常有效的提升服务器利用率,这样的应用场景非常广泛。

1.2.3 持久化

        持久化确保MQ的使用不只是一个部分场景的辅助工具,而是让MQ能像数据库一样存储核心的数 据。

1.2.4 分布式

        在现在大流量、大数据的使用场景下,只支持单体应用的服务器软件基本是无法使用的,支持分布 式的部署,才能被广泛使用。而且, MQ的定位就是一个高性能的中间件。

1.3 为什么需要使用消息队列

 其实就是问问你消息队列都有哪些使用场景,然后你项目里具体是什么场景,说说你在这个场景里 用消息队列是什么?

1.3.1 应用解耦 

        在快递柜业务流程中,快递员投柜后需要经历扣减系统费、短信通知用户和推送通知快递公司三个 业务动作。传统做法需要依次执行这些业务东西,如果其中某一步异常(例如用户手机未开机或者快递 公司接口故障),将会延迟甚至中断整个投柜流程,严重影响用户体验。

         如果接口层收到投柜数据后,写入消息到MQ,后续三个子系统各自消费处理,将可以完美解决该问题,并且子系统故障不影响上游系统!此为 解耦

1.3.2  异步

        比如快递投柜后,用户马上就结束了,不会等待到发送短信或者通知快递公司结束的,直接将消息 投递到MQ,然后就直接结束,具体到扣减系统费以及后续的通知,都是异步操作的,不需要用户关心的,着就是将用户的同步操作转换为异步操作。

        如果全部同步操作需要15S,而发送到MQ后交给系统异步处理用户只需要1S就可以完成操作。

1.3.3 流量削峰 

就像用户投递快递,高峰到40W每秒,但是我们的后续处理业务每秒能处理20W,还剩下20W MQ进行堆积,这就是MQ很重要的流量削峰的能力,将用户的洪峰流量,让后台慢慢来处理,MQ承担一个缓冲的左右

 

        就像这个波形图一样,如果用户请求的并发量的最高峰时40W,系统的承载能力只能达到30W,就 可以使用MQ进行削峰,将系统最高40W的并发削峰为最高只有20万,就是时间换空间的做法。 

1.4 消息队列的缺点

1.4.1 系统可用性降低

         消息队列在系统中充当一个中间人的身份,如果该中间人突然失联了,那其他两方就不知所措了, 最后也就导致系统之间无法互动。

        如果MQ出现了故障就可能会导致系统故障。

1.4.2 系统复杂性提高 

         在使用消息队列的过程中,难免会出现生产者、  MQ、消费者宕机不可用的情况,那么随之带来的 问题就是消息重复、消息乱序、消息堆积等等问题都需要我们来控制。

1.4.3 数据一致性问题

         如下图所示,系统需要保证快递投递,扣减系统费,通知等之间的数据一致性,如果系统短信通 知,快递通知执行成功,扣减系统费执行失败时,就会出现数据不一致问题。

         如果出现这种问题,我们需要有应对方案,比如重试等方案。

        所以消息队列实际是一种非常复杂的架构,你引入它有很多好处,但是也得针对它带来的坏处做各 种额外的技术方案和架构来规避掉,做好之后,你会发现,妈呀,系统复杂度提升了一个数量级,也许 是复杂了 10 倍。但是关键时刻,用,还是得用的。

二、常用的消息中间件

         消息队列是分布式应用间交换信息的重要组件,消息队列可驻留在内存或磁盘上, 队列可以存储消息 直到它们被应用程序读走。

        通过消息队列,应用程序可以在不知道彼此位置的情况下独立处理消息,或者在处理消息前不需要 等待接收此消息。

        所以消息队列可以解决应用解耦、异步消息、流量削锋等问题,是实现高性能、高可用、可伸缩和 最终一致性架构中不可以或缺的一环。

      现在比较常见的消息队列产品主要有ActiveMQ RabbitMQZeroMQ Kafka RocketMQ

2.1 ActiveMQ

          

ActiveMQ Apache出品,最流行的,能力强劲的开源消息总线。 ActiveMQ 是一个完全支持JMS1.1J2EE 1.4规范的 JMS Provider实现,尽管JMS规范出台已经是很久的事情了,但是JMS当今的J2EE应用中间仍然扮演着特殊的地位。

2.1.1 特性 

1.. 多种语言和协议编写客户端。语言: Java,C,C++,C#,Ruby,Perl,Python,PHP。应用协议: OpenWire,Stomp REST,WS Notification,XMPP,AMQP;

2. 完全支持JMS1.1J2EE 1.4规范 (持久化, XA消息,事务);

3. Spring的支持, ActiveMQ可以很容易内嵌到使用Spring的系统里面去,而且也支持Spring2.0 特性;

4. 通过了常见J2EE服务器(如 Geronimo,JBoss 4,GlassFish,WebLogic)的测试,其中通过JCA 1.5   resource adaptors的配置,可以让ActiveMQ可以自动的部署到任何兼容J2EE 1.4 商业服务器上

5. 支持多种传送协议: in-VM,TCP,SSL,NIO,UDP,JGroups,JXTA;

6. 支持通过JDBCjournal提供高速的消息持久化;

7. 从设计上保证了高性能的集群,客户端-服务器,点对点;

8. 支持Ajax;

9. 支持与Axis的整合;

10. 可以很容易得调用内嵌JMS provider,进行测试;

2.1.2 使用建议 

         一般的业务系统要引入 MQ,最早大家都用 ActiveMQ,但是现在确实大家用的不多了,没经过大 规模吞吐量场景的验证,社区也不是很活跃,所以大家还是算了吧,我个人不推荐用这个了;

2.2 RabbitMQ 

 

 RabbitMQ是流行的开源消息队列系统,用erlang语言开发。 RabbitMQAMQP (高级消息队列 协议)的标准实现。支持多种客户端,如:  Python Ruby .NETJavaJMSC PHPActionScript、XMPPSTOMP等,支持AJAX,持久化。用于在分布式系统中存储转发消息,在易 用性、扩展性、高可用性等方面表现不俗

2.2.1 特性 

 erlang语言开发,性能极其好,延时很低

吞吐量到万级, MQ功能比较完备

开源提供的管理界面非常棒,用起来很好用

社区相对比较活跃,几乎每个月都发布几个版本分

在国内一些互联网公司近几年用rabbitmq也比较多一些

2.2.2 使用建议 

 大家开始用 RabbitMQ,但是确实 erlang 语言阻止了大量的 Java工程师去深入研究和掌控它,对  公司而言,几乎处于不可控的状态,但是确实人家是开源的,比较稳定的支持,活跃度也高,所以中小  型公司,技术实力较为一般,技术挑战不是特别高,用 RabbitMQ 是不错的选择,对自家技术没有过高自信的话,可以使用RabbitMQ,人家有活跃的开源社区,绝对不会黄。

2.3 Kafka

 

Kafka是一种高吞吐量的分布式发布订阅消息系统,它可以处理消费者规模的网站中的所有动作流 数据。 这种动作(网页浏览,搜索和其他用户的行动)是在现代网络上的许多社会功能的一个关键因素,这些数据通常是由于吞吐量的要求而通过处理日志和日志聚合来解决。   对于像Hadoop  的一样的日志数据和离线分析系统,但又要求实时处理的限制,这是一个可行的解决方案。 Kafka的目的是通过Hadoop的并行加载机制来统一线上和离线的消息处理,也是为了通过集群机来提供实时的消费。

 2.3.1 特性

通过O(1)的磁盘数据结构提供消息的持久化,这种结构对于即使数以TB的消息存储也能够保持长时间的稳定性能。(文件追加的方式写入数据,过期的数据定期删除)

高吞吐量:即使是非常普通的硬件Kafka也可以支持每秒数百万的消息 

支持通过Kafka服务器和消费机集群来分区消息

支持Hadoop并行数据加载

2.3.2 使用建议 

         如果是大数据领域的实时计算、日志采集等场景,用 Kafka 是业内标准的,绝对没问题,社区活跃 度很高,绝对不会黄,何况几乎是全世界这个领域的事实性规范。

2.4 RocketMQ

RocketMQ是阿里开源的消息中间件,纯Java开发,具有高吞吐量、高可用性、适合大规模分布式 系统应用的特点。 RocketMQ思路起源于Kafka,但并不是简单的复制,它对消息的可靠传输及事  务性做了优化,目前在阿里集团被广泛应用于交易、充值、流计算、消息推送、日志流式处理、binglog分发等场景,支撑了阿里多次双十一活动。

因为是阿里内部从实践到产品的产物,因此里面很多接口、  api并不是很普遍适用。可靠性毋庸置 疑,而且与Kafka一脉相承(甚至更优),性能强劲,支持海量堆积。

2.4.1 特性 

接口简单易用,源码是阿里出品,可自定义MQ

topic可以达到几百,几千个的级别,吞吐量会有较小幅度的下降 

消息可用性极高,经过参数优化配置,可以做0丢失

MQ功能较为完善,还是分布式的,扩展性好

2.4.2 使用建议 

         现在确实越来越多的公司会去用 RocketMQ,确实很不错,毕竟是阿里出品,但社区可能有突然黄 掉的风险(目前 RocketMQ 已捐给 Apache,但 GitHub 上的活跃度其实不算高)对自己公司技术实力  有绝对自信的,推荐用 RocketMQ,否则回去老老实实 RabbitMQ 吧,大型公司,基础架构研发实力 较强,用 RocketMQ 是很好的选择。

三、RabbitMQ的基本使用

         RabbitMQ AMQP 遵循相同的模型架构,其架构示例图如下:

3.1重要概念 

3.1.1 Pulisher 

         消息生产者,就是投递消息的程序,发布者 (或称为生产者) 负责生产消息并将其投递到指定的交换器上。

3.1.2 Message

         消息由消息头和消息体组成。消息头用于存储与消息相关的元数据:如目标交换器的名字

(exchange_name) 、路由键 (RountingKey)和其他可选配置 (properties) 息。消息体为实际需要传递 的数据。

3.1.3 Exchange

 交换器负责接收来自生产者的消息,并将将消息路由到一个或者多个队列中,如果路由不到,则返 回给生产者或者直接丢弃,这取决于交换器的 mandatory 属性:

  1.  mandatory true 时:如果交换器无法根据自身类型和路由键找到一个符合条件的队列,则会 将该消息返回给生产者;
  2.  mandatory false 时:如果交换器无法根据自身类型和路由键找到一个符合条件的队列,则 会直接丢弃该消息。

3.1.4 BindingKey

         交换器与队列通过 BindingKey 建立绑定关系。

3.1.5 RoutingKey

        基于交换器类型的规则相匹配时,消息被路由到对应的队列中 

         生产者将消息发给交换器的时候, 一般会指定一个 RountingKey,用来指定这个消息的路由规则。当 RountingKey  BindingKey匹配那会发送到对应的队列中。

3.1.6 Queue

 消息队列载体,每个消息都会被投入到一个或多个队列。

         用于存储路由过来的消息。多个消费者可以订阅同一个消息队列,此时队列会将收到的消息将以轮 (round-robin)的方式分发给所有消费者。即每条消息只会发送给一个消费者,不会出现一条消息被多个消费者重 复消费的情况。

3.1.7 Comsumer

         消费者订阅感兴趣的队列,并负责消费存储在队列中的消息。为了保证消息能够从队列可靠地到达消费者, RabbitMQ 提供了消息确认机制 (messageacknowledgement),并通过autoAck 参数来进行 控制。

  • autoAck true 时:此时消息发送出去 (写入TCP套接字) 后就认为消费成功,而不管消费者是 否真正消费到这些消息。当 TCP 连接或 channel 因意外而关闭,或者消费者在消费过程之中意外 宕机时,对应的消息就丢失。因此这种模式可以提高吞吐量,但会存在数据丢失的风险。
  • autoAck false 时:需要用户在数据处理完成后进行手动确认,只有用户手动确认完成后,RabbitMQ 才认为这条消息已经被成功处理。这可以保证数据的可靠性投递,但会降低系统的吞吐量。

3.1.8 Connection

         用于传递消息的 TCP 连接。

3.1.9 Channel

         消息通道,在客户端的每个连接里,可建立多个channel,每个channel代表一个会话任务。

         RabbitMQ 采用类似 NIO (非阻塞式 IO ) 的设计,通过 Channel 来复用 TCP 连接,并确保每个Channel的隔离性,就像是拥有独立的 Connection 连接。当数据流量不是很大时,采用连接复用技术可以避免创建过多的 TCP 连接而导致昂贵的性能开销。

3.1.10  Virtual Host

 虚拟主机, 一个broker里可以开设多个vhost,用作不同用户的权限分离

     RabbitMQ 通过虚拟主机来实现逻辑分组和资源隔离, 一个虚拟主机就是一个小型的 RabbitMQ 务器,拥有独立的队列、交换器和绑定关系。用户可以按照不同业务场景建立不同的虚拟主机,虚拟主 机之间是完全独立的,你无法将 vhost1上的交换器与vhost2 上的队列进行绑定,这可以极大的保证业 务之间的隔离性和数据安全。默认的虚拟主机名为 /。    

3.1.11 Broker 

         简单来说就是消息队列服务器实体。

3.2 消息怎么路由 

         从概念上来说,消息路由必须有三部分: 交换器路由绑定。生产者把消息发布到交换器上;绑 定决定了消息如何从路由器路由到特定的队列;消息最终到达队列,并被消费者接收。

        消息发布到交换器时,消息将拥有一个路由键(routing key),在消息创建时设定,通过队列路由 键,可以把队列绑定到交换器上。

        消息到达交换器后, RabbitMQ会将消息的路由键与队列的路由键进行匹配(针对不同的交换器有  不同的路由规则)。如果能够匹配到队列,则消息会投递到相应队列中;如果不能匹配到任何队列,消 息将进入 黑洞

3.3 常用的交换器

         交换器是消息被发送的 AMQP 实体。交换器拿到消息然后把它路由给0或多个队列。路由算法基 于交换器的类型和 bindings

         常用的交换器主要分为一下三种:

Exchange type(交换器类型)

Default pre-declared names(预声明默认名称)

Direct exchange(直连交换器)

(Empty string) and amq.direct

Fanout exchange(扇形交换器)

amq.fanout

Topic exchange(主题交换器)

amq.topic

Headers exchange(头信息交换器)

amq.match (and amq.headers in RabbitMQ)

 3.3.1 直接交换机

 如果路由键完全匹配,消息就被投递到相应的队列

         直连型交换机(direct exchange)是根据消息携带的路由键(routing key)将消息投递给对应绑 定键的队列。

        直连交换机是一种带路由功能的交换机, 一个队列会和一个交换机绑定,除此之外再绑定一个routing_key,当消息被发送的时候,需要指定一个binding_key,这个消息被送达交换机的时候,就会 被这个交换机送到指定的队列里面去。同样的一个binding_key也是支持应用到多个队列中的。

        直连型交换机图例: 

 

         当生产者(P)发送消息时 Rotuing key=booking 时,这时候将消息传送给 Exchange  Exchange 获取到生产者发送过来消息后,会根据自身的规则进行与匹配相应的 Queue,这时发现 Queue1Queue2 都符合,就会将消息传送给这两个队列。

         如果我们以 Rotuing key=create Rotuing key=confirm 发送消息时,这时消息只会被推送到Queue2 队列中,其他 Routing Key 的消息将会被丢弃。

3.3.2 扇形交换机 

 如果交换器收到消息,将会广播到所有绑定的队列上

       扇型交换机(fanout exchange)将消息路由给绑定到它身上的所有队列,而不理会绑定的路由键。如果 N 个队列绑定到某个扇型交换机上,当有消息发送给此扇型交换机时,交换机会将消息的拷贝 分别发送给这所有的 N 个队列。扇型用来交换机处理消息的广播路由(broadcast routing)。

         因为扇型交换机投递消息的拷贝到所有绑定到它的队列,所以他的应用案例都极其相似:

  • 大规模多用户在线(MMO)游戏可以使用它来处理排行榜更新等全局事件 
  • 体育新闻网站可以用它来近乎实时地将比分更新分发给移动客户端
  • 分发系统使用它来广播各种状态和配置更新
  •  在群聊的时候,它被用来分发消息给参与群聊的用户。(AMQP 没有内置 presence 的概念,因此 XMPP 可能会是个更好的选择)

         上图所示,生产者(P)生产消息 1 将消息 1 推送Exchange,由于 Exchange Type=fanout  时候会遵循 fanout 的规则将消息推送到所有与它绑定 Queue,也就是图上的两个 Queue 最后两个消 费者消费。

3.3.3 主题交换机 

         可以使来自不同源头的消息能够到达同一个队列。使用topic交换器时,可以使用通配符。

         基于消息的 routing key 与绑定到该交换器的队列的 pattern 进行匹配,路由消息到一个或多个队 列。常用于复杂的发布/订阅场景。

        当出现多消费者/应用的场景,消费者选择性地接收消息时,应该考虑使用topic exchange

        前面提到的 direct 规则是严格意义上的匹配,换言之 Routing Key 必须与 Binding Key 相匹配的时 候才将消息传送给 Queue.

        而Topic 的路由规则是一种模糊匹配,可以通过通配符满足一部分规则就可以传送。

匹配规则:

1. binding key 中可以存在两种特殊字符 “*” “#”,用于做模糊匹配,其中 “*” 于匹配一个单词, “#”用于匹配多个单词(可以是零个)

2. routing key 为一个句点号  .” 分隔的字符串(我们将被句点号  . ” 分隔开的每一段独立的字符串称 为一个单词),如stock.usd.nysenyse.vmwquick.orange.rabbit

binding key routing key 一样也是句点号  .” 分隔的字符串 

 主题交换机图例:

         当生产者发送消息 Routing Key=F.C.E 的时候,这时候只满足 Queue1,所以会被路由到 Queue    中,如果 Routing Key=A.C.E 这时候会被同是路由到 Queue1 Queue2 中,如果 Routing Key=A.F.B 时,这里只会发送一条消息到 Queue2 中。

         主题交换机拥有非常广泛的用户案例。无论何时,当一个问题涉及到那些想要有针对性的选择需要 接收消息的 多消费者 / 多应用(multiple consumers/applications) 的时候,主题交换机都可以被列   入考虑范围。

3.3.4 头交换机

 headers 类型的 Exchange 不依赖于 routing key binding key 的匹配规则来路由消息,而是根 据发送的消息内容中的 headers 属性进行匹配。

         头交换机可以视为直连交换机的另一种表现形式。但直连交换机的路由键必须是一个字符串,而头 属性值则没有这个约束,它们甚至可以是整数或者哈希值(字典)等。灵活性更强(但实际上我们很少 用到头交换机)。工作流程:

        传来的消息会携带header,以及会有一个 “x-match参数。当 “x-match设置为 any时,消息头的任意一个值被匹配就可以满足条件,而当 “x-match设置为 all的时候,就需要消息头的所有值都匹配成功。

3.3.5 交换机总结

类型名 

路由规则

Default

自动命名的直交换机

Direct

把消息路由到BindingKeyRoutingKey完全匹配的队列中, Routing Key==Binding Key,严格匹配

Fanout

发送到该交换机的消息都会路由到与该交换机绑定的所有队列上,可以用来做广播

Topic

topicdirect类似,也是将消息发送到RoutingKeyBindingKey相匹配的队列中, 只不过可以模糊匹配

Headers

根据发送的消息内容中的 headers 属性进行匹配,性能差,基本不会使用

         

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

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

相关文章

js插件-模糊搜索、自动补全下拉框

问题&#xff1a;一个老系统&#xff0c;让把所有jsp页面动态生成的<select>下拉选&#xff0c;选项过多的下拉选全部改为支持模糊搜索的下拉选的功能。系统框架只有 jq 和layui&#xff08;仅用于列表和弹窗&#xff09;&#xff0c; JQurey 首先想到的就是jQuery UI …

构建以数据为核心智慧型工业园区新架构方案

1. 项目背景与目标 智慧型工业园区新架构的构建旨在通过数据驱动实现节能、绿色、高效和安全的目标&#xff0c;以应对当前工业园区在基础数据收集、系统管理和操作复杂性方面的挑战。 2. 现状分析 当前工业园区的发展面临数据收集难题、系统分散、操作复杂以及孤岛效应&…

前端面试——八股文

一、Vue2篇 1. 关于生命周期 1.1 生命周期有哪些&#xff1f;发送请求在created还是mounted&#xff1f; 请求接口测试&#xff1a;https://fcm.52kfw.cn/index.php?_mall_id1&rapi/default/districtVue2.x系统自带有8个 beforeCreate created beforeMount mounted be…

电子签合同区块链存证合约小程序开源版开发

电子签合同区块链存证合约小程序开源版开发 电子合同底层对接的腾讯电子签接口&#xff0c;支持自定义模版发起合同和文件发起合同&#xff0c;支持骑缝章&#xff0c;多方签署&#xff0c;腾讯至信链提供区块链存证&#xff0c;安全高效签署合同文书。 特色功能 自定义合同模…

(计算机论文)基于SpringBoot和Vue的台球赛事服务网站的设计与实现

毕业设计&#xff08;论文&#xff09; 博主可接毕设论文&#xff01;&#xff01;&#xff01; 基于SpringBoot和Vue的台球赛事服务网站的设计与实现 摘 要 在快速发展的信息时代&#xff0c;体育竞赛作为群众文化娱乐的一部分&#xff0c;已日益受到广泛关注。台球&#xff…

Windows—线程基本知识和线程同步

线程 线程的组成 线程的内核对象&#xff0c;操作系统用它来对线程实施管理。内核对象也是系统用来存放线程统计信息的地方。线程堆栈&#xff0c;它用于维护线程在执行代码时需要的所有函数参数和局部变量 线程的进入点 每个线程必须拥有一个进入点函数&#xff0c;线程从…

备战2024年全国大学生数学建模竞赛:多波束测线问题的解题与优化

目录 一、引言 二、问题分析 三、解题思路与模型建立 问题1&#xff1a;覆盖宽度及重叠率计算 问题2&#xff1a;不同测线方向的覆盖宽度 问题3&#xff1a;最短测线的设计 问题4&#xff1a;基于单波束数据的测线设计 四、知识点解析 五、结果讨论与总结 六、模型的评…

X86架构(六)——硬盘访问与控制

在前面几节中&#xff0c;我们总是通过ROM-BIOS从硬盘的主引导扇区读取一段程序并加载到内存运行&#xff0c;但是处理器是如何访问硬盘呢&#xff1f;这是一个值得我们思考的问题 OK&#xff0c;我们先看一张图 所有这些和计算机主机连接的设备&#xff0c;叫做外围设备,也叫…

240831-Qwen2-VL-7B/2B部署测试

A. 运行效果 B. 配置部署 如果可以执行下面就执行下面&#xff1a; pip install githttps://github.com/huggingface/transformers accelerate否则分开执行 git clone https://github.com/huggingface/transformers cd transformers pip install . accelerate随后&#xff0…

8.27FLEX,BISON

RC ParseStage::handle_request(SQLStageEvent *sql_event) 这个意思是返回类型是RC&#xff0c;然后用到的函数来自 ParseStage&#xff0c;&#xff1a;&#xff1a;就是用来标识作用域的&#xff0c;函数名是handle_request&#xff0c;是ParseStage里的函数 FLEX BISON

vue.js项目实战案例详细源码讲解

​ 大家好&#xff0c;我是程序员小羊&#xff01; 前言&#xff1a; 为帮助大家更好地掌握Vue.js项目的开发流程&#xff0c;我将为你讲解一个完整的Vue.js实战案例&#xff0c;并提供详细的源码解析。这个案例将涵盖从项目创建到实现各种功能模块的全过程&#xff0c;适合用于…

组织培训如何分组?

在组织培训活动时&#xff0c;合理分组是提高效率和参与度的关键。云分组小程序提供了一个简单而有效的解决方案&#xff0c;帮助组织者快速、公平地将参与者分配到不同的小组中。以下是使用云分组小程序进行培训分组的详细步骤&#xff1a;一、创建分组 1. 打开云分组小程序。…

入坑大模型18个月的反思与贩私

前几天开完一个有高层参加的会议&#xff0c;会后组里的技术大佬直接就开喷“要规划没规划&#xff0c;整天只知道对着几个糊弄老板的榜使劲刷”。我下意识地赶紧去拉住他&#xff0c;低声对他讲“你声音太小了&#xff0c;老板听不到的&#xff0c;回头我领你去大厦的保安室&a…

Docker容器技术(下)超多好上手的实验,保姆级教程

文章目录 Docker数据卷管理及优化为什么要使用数据卷bind mount数据卷docker managed数据卷Data Volume Container&#xff08;数据卷容器&#xff09;bind mount数据卷 VS docker managed数据卷备份与迁移数据卷 Docker的安全优化Docker的资源限制限制CPU的使用限制CPU的使用量…

RAG重磅升级:DSF带来特定领域精准提升的全新方案!

检索增强生成&#xff08;Retrieval-Augmented Generation, RAG&#xff09;是一种结合了检索&#xff08;Retrieval&#xff09;和生成&#xff08;Generation&#xff09;能力的框架&#xff0c;通过从背景数据中检索相关信息来增强模型的生成输出。在当前的大型语言模型&…

Linux 安装mysql 数据库通用教程(rpm傻瓜安装)

通用教程&#xff1a;Centos7.9安装mysql8.0.39&#xff08;使用rpm 安装&#xff09; 目录 前言 下载镜像源 删除或查看旧版本 安装mysql 启动mysql mysql授权远程登录 前言 在本篇博客中&#xff0c;我将向您展示如何在CentOS 7.9系统上通过RPM包安装特定版本的MySQL…

神经网络搭建实战与Sequential的使用

一、需要处理的图像 二、对上述图片用代码表示&#xff1a; import torch from torch import nn from torch.nn import Conv2d, MaxPool2d, Flatten, Linearclass SUN(nn.Module):def __init__(self):super(SUN, self).__init__()self.conv1 Conv2d(3, 32, 5, padding2)self…

解决移动端使用Vant van-overlay 遮罩层导致的弹窗不可滚动问题

项目场景 在游戏门户网站需要根据弹出层列举出自己背包的饰品&#xff0c;然后进行选择置换。 问题描述 例如&#xff1a;在PC端的时候能物品过多的时候能正常左右滚动&#xff0c;而且启用Google的开发者工具进行查看的时候也是能正常滚动&#xff0c;但是在手机端访问的时候…

持续集成与持续部署(CI/CD)的深入探讨

在现代软件开发中&#xff0c;持续集成&#xff08;CI&#xff09;和持续部署&#xff08;CD&#xff09;已成为不可或缺的实践。这些方法旨在加快软件交付的速度&#xff0c;同时提高软件的质量和稳定性。通过CI/CD&#xff0c;开发团队可以频繁地将代码更改集成到主分支&…

Mate 60、Mate X5和Pocket 2新增AI修图功能:AI消除能力效果惊艳

你有没有试过拍照的时候不小心把路人拍进来&#xff0c;或者拍风景的时候有煞风景的事物闯入镜头中&#xff1f;有些美好的画面稍纵即逝、有些景点不复存在&#xff0c;看着略带瑕疵的照片&#xff0c;多少会感觉有点遗憾。 最近Mate 60、Mate X5和Pocket 2三款机型都进行了鸿…