消息队列学习基础MOM就是面向消息中间件(Messageorientedmiddleware),是用于以分布式应用

MOM思想就是A和B两个应用程序不直接发送消息。之前A和B直接发送消息有很多效率问题,如A发送之后B没有及时接受,那么A就一直再在那里堵塞并发性不好,A必须等B接受完之后有返结果了A才可以结束。而MOM就是为了解决这样的问题,不让A与B之间交互,在A和B之间加一个消息中间件,A把消息放到消息中间上,就可以走了,去做别的事情,B什么时候来消息中间件取消息A不用知道也不用管。这样就提高了效率提供并发性,等B去走后可以通过状态,通知,回调等方式通知A就可以。市面上实现这种思想的技术有很多,IBM(MQSEVICES)、Microsoft(MSMQ)以及BEA的MessageMQ等。处于百家争鸣阶段都是各自实现各自的,没有统一实现标准。此时SUN为了实现统一标准就出现了JMS统一实现规范。JMS主要有2种消息模型,点到点和发布订阅两种。

消息队列是在消息的传输过程中保存消息的容器,用于接收消息并以文件的方式存储,一个消息队列可以被一个也可以被多个消费者消费。

消息队列中间件是分布式系统中重要的组件,主要解决应用耦合、异步消息、流量削锋等问题。实现高性能、高可用、可伸缩和最终一致性架构。是大型分布式系统不可缺少的中间件。

目前在生产环境,使用较多的消息队列有ActiveMQ、RabbitMQ、ZeroMQ、Kafka、MetaMQ、RocketMQ等。

下面详细介绍一下消息队列在实际应用中常用的使用场景。场景分为异步处理、应用解耦、流量削锋和消息通讯四个场景。

场景说明用户注册后,需要发送注册邮件和发送注册信息,传统的做法有两种:串行方式并行方式

串行方式

将注册信息写入数据库成功后,发送注册邮件,然后发送注册短信,而所有任务执行完成后,返回信息给客户端

并行方式

由上可以看出,传统串行和并行的方式会受到系统性能的局限,那么如何解决这个问题?我们需要引入消息队列,将不是必须的业务逻辑,异步进行处理,由此改造出来的流程为

场景说明用户下单后,订单系统需要通知库存系统。

传统的做法为:订单系统调用库存系统的接口。如下图所示:

如何解决上述的缺点呢?需要引入消息队列,引入消息队列后的架构如下图所示:

假如在下单时库存系统不能正常使用。也不影响正常下单,因为下单后,订单系统写入消息队列就不再关心其后续操作了。由此实现了订单系统与库存系统的应用解耦。

流量削峰也是消息对列中的常用场景,一般在秒杀或团抢活动中使用广泛。

应用场景秒杀活动,一般会因为流量过大,导致流量暴增,应用挂掉。为解决这个问题,一般需要在应用前端加入消息队列。

流量削锋处理方式系统图如下:

日志处理是指将消息队列用在日志处理中,比如Kafka的应用,解决大量日志传输的问题。

日志处理是指将消息队列用在日志处理中,比如Kafka的应用,解决大量日志传输的问题。架构简化如下:

消息通讯是指,消息队列一般都内置了高效的通信机制,因此也可以用在纯的消息通讯。比如实现点对点消息队列、聊天室等。

在点对点通讯架构设计中,客户端A和客户端B共用一个消息队列,即可实现消息通讯功能。

客户端A、客户端B、直至客户端N订阅同一消息队列,进行消息的发布与接收,即可实现聊天通讯方案架构设计。

讲消息队列就不得不提JMS。JMS(JavaMessageService,Java消息服务)JMS叫做Java消息服务(JavaMessageService),是Java平台上有关面向MOM的技术规范,旨在通过提供标准的产生、发送、接收和处理消息的API简化企业应用的开发,类似于JDBC和关系型数据库通信方式的抽象。

API是一个消息服务的标准/规范,允许应用程序组件基于JavaEE平台创建,发送,接收和读取消息。他是分布式通信耦合度更低,消息服务更加可靠以及异步性。

在EJB架构中,有消息bean可以无缝的与JM消息服务集成。在J2EE架构模式中,有消息服务者模式,用于实现消息与应用直接的解耦。

在JMS标准中,有两种消息模型P2P(PointtoPoint),Publish/Subscribe(Pub/Sub)

P2P(点对点)模式包含三个角色:消息队列(Queue),发送者(Sender),接收者(Receiver)。每个消息都被发送到一个特定的队列,接收者从队列中获取消息。队列保留着消息,知道他们被消费或者超时。

P2P消息域使用queue作为Destination,消息可以被同步或异步的发送和接收,每个消息只会给一个Consumer传送一次。Consumer可以使用MessageConsumer.receive()同步地接收消息,也可以通过使用MessageConsumer.setMessageListener()注册一个MessageListener实现异步接收。

多个Consumer可以注册到同一个queue上,但一个消息只能被一个Consumer所接收,然后由该Consumer来确认消息。并且在这种情况下,Provider对所有注册的Consumer以轮询的方式发送消息。

P2P的特点

包含三个角色:主题(Topic),发布者(Publisher),订阅者(Subscriber)。多个发布者将消息发送到Topic,系统将这些消息传递给多个订阅者。

除非显式指定,否则topic不会为订阅者保留消息。当然,这可以通过持久化(Durable)订阅来实现消息的保存。这种情况下,当订阅者与Provider断开时,Provider会为它存储消息。当持久化订阅者重新连接时,将会受到所有的断连期间未消费的消息。

Pub/Sub的特点

在JMS中,消息的产生和消费都是异步的。对于消费来说,JMS的消息者可以通过两种方式来小消费消息。

1.ConnectionFactory

创建Connection对象的工厂,针对两周不同的JMS消息模型,分别有QueueConnectionFactory和TopicConnectionFactory两种。可以通过JNDI来查找ConnectionFactory对象。

2.Destination

所以,Destination实际上就是两种类型的对象:Queue,Topic可以通过JNDI来查找Destination

3.Connection

Connection表示在客户端和JMS系统之间建立的链接(对TCP/IPSocket的包装)。Connection可以产生一个或多个Session。跟ConnectionFactory一样,Connection也有两种类型:QueueConnection和TopicConnection。

4.Session

Session是操作消息的接口。可以通过session创建生产者、消费者、消息等。Session提供了事务的功能。当需要使用session发送/接收多个消息时,可以将这些发送/接收动作放到一个事务中。同样,也分QueueSession和TopicSession。

5.消息的生产者

消息生产者由Session创建,并用于将消息发送到Destination。同样,消息生产者分两种类型:QueueSender和TopicPublisher。可以调用消息生产者的方法(send或publish方法)发送消息。

6.消息消费者

消息消费者由Session创建,用于接收被发送到Destination的消息。两种类型:QueueReceiver和TopicSubscriber。可分别通过session的createReceiver(Queue)或createSubscriber(Topic)来创建。当然,也可以session的creatDurableSubscriber方法来创建持久化的订阅者。

7.MessageListener

消息监听器。如果注册了消息监听器,一旦消息到达,将自动调用监听器的onMessage方法。EJB中的MDB(Message-DrivenBean)就是一种MessageListener。

THE END
1.MOM是什么?mom平台是什么MOM(制造运营管理)是一种企业管理系统,旨在协调和管理企业的人员、设备、物料和能源等资源,把原材料或零件转化为产品的活动。它是一种由多种软件构成的制造管理集成平台,通过整合和集成各种系统来提供更全面和准确的生产信息,以帮助企业做出更明智的决策。 https://blog.csdn.net/BLUETRON/article/details/138267536
2.MOM系统介绍,带你了解JMS规范51CTO博客JMS 是 Java 平台上的面向接口的消息规范,是一套 API 标准,并没有考虑异构系统。AMQP 是一个面向协议的,跟语言平台无关的消息传递应用层协议规范。STOMP 是流文本定向消息协议,是一种为MOM设计的简单文本协议。 基于MOM 的系统允许通过异步交换消息来进行通信 。 https://blog.51cto.com/javazyx/3135977
3.Java消息服务(JMS):在异步通信世界的引领者为了满足异步通信的需求,面向消息的中间件(Message Oriented Middleware,简称MOM)应运而生。MOM 通过消息传递实现了应用程序之间的通信,使它们能够以一种松耦合、可靠且异步的方式进行交互。JMS 作为 Java 平台上的 MOM API,成为了 Java 企业级开发中不可或缺的一环。 https://cloud.tencent.com/developer/article/2383568
4.MOM一体化智能制造平台 MOM平台核心能力 智能制造信息化建设不单单只是上一个项目,更重要的是选一个好的平台 产品功能成熟,覆盖全制造链 系统功能应覆盖机加工、钣金加工、PCB制造、表面处理、装配、包装发运、调试等制造过程全业务领域,并且功能完整、成熟 https://wethinks.com/lists/48.html
5.MOM制造运营管理平台MOMMOM系统MOM软件MOM厂商MES华天软件产品涉及PDM,PLM,CAD,MOM,MES,CAPP,SView,SVMAN,WMS,SRM,LES系统软件,拥有自主版权的三维CAD/CAM软件SINOVATION.作为以3D为核心的智能制造软件服务商,专注于制造业信息化领域,服务行业及领域有航空航天、汽车整车及零部件、重型机械、高科技电子、冲压模具、轴承、https://www.hoteamsoft.com/mom
6.MOM平台——智能工厂的灵魂西信信息iMOM分三步深化数字化价值实现。 建立企业“数字化制造主板”,引导各业务围绕企业目标高效协同运转。 此外,平台运营过程中积累的全量运营数据可以为企业管理提供“数字洞察”,基于全量数据的特定场景的“智能工业算法”可以提供超越人类经验的专业性能。 以智能套料算法为核心的钣金数字化车间,智能套料算法驱动运行,数控http://www.westinfosoft.com/hyzx/2189.html
7.工业数智化MOM平台工业数智化MOM平台 随着信息技术的快速发展和工业转型的加速推进,工业数智化成为了一个热门话题。而在这个领域中,MOM(Manufacturing Operations Management)平台的出现给工业企业带来了革命性的改变。 什么是工业数智化MOM平台? MOM平台是指基于先进的信息技术和互联网技术,通过整合企业内部各种生产运营系统和设备的数据,https://feixuns.cn/article/5421970105707559
8.产品服务制造运营平台MOM生产单元不再孤立,运用自主可控的ZQ-MOM核心平台,全面的业务协同,不再割裂业务链 工业大数据的驱动,改变工厂的运营模式 微服务重构系统架构,满足你的一切想象 微服务框架,松耦合的业务链接,实现前端业务的高效扩展 凭借强大的系统中台,进行系统开发、实施、API服务 https://www.xhzq.com/index.php/Index/service/sid/7.html
9.如何使用MOM资管平台进行投资管理?这种平台对资产管理有何优势1.多元化投资:通过将资金分配给多个专业的子管理人,MOM平台能够实现资产的多元化配置,降低单一资产或策略带来的风险。 2.专业管理:MOM平台汇集了多个专业的投资管理人,每个管理人都有其擅长的领域和策略,能够为投资者提供专业的资产管理服务。 3.风险分散:由于资金分散在多个管理人和策略中,MOM平台能够有效分散风险,减https://futures.hexun.com/2024-10-16/214999078.html
10.制造运营管理(MOM)软件MOM可以为企业提供包括制造数据管理、计划排程管理、生产调度管理、库存管理、质量管理、人力资源管理、工作中心/设备管理、工具工装管理、采购管理、成本管理、项目看板管理、生产过程控制、底层数据集成分析、上层数据集成分解等管理模块,为企业打造一个扎实、可靠、全面、可行的制造协同管理平台,帮助企业管理者掌握工厂的https://www.huasun-is.com/MOM
11.mom制造运营管理平台在如今竞争激烈的市场环境下,中小企业需要寻找一种能够提升生产效率的解决方案。mom制造运营管理平台就是为了满足这一需求而设计的一款saas产品。作为一家中小企业,您可能会问,什么是mom制造运营管理平台?它有什么亮点和优势呢? 首先,mom制造运营管理平台是由博诚经纬软件科技有限公司开发的一款基于.net core 3.1的跨平https://www.huaweicloud.com/zhishi/smart-18489484.html
12.探索MOM系统:革命性的管理和协作平台在当今数字时代,组织和企业不断寻求提高效率、协作和信息共享的方法。为满足这一需求,MOM系统(Management and Operations Management System)已经崭露头角,成为许多企业的首选工具。MOM系统是一种革命性的管理和协作平台,通过整合多个管理领域的功能,使企业能够更有效地管理资源、协作团队、提高生产力以及更好地满足客户需https://www.abestway.cn/45973/