摘要:類是一個模板類,用戶可以指定需要通過創(chuàng)建的對象的類型,以及創(chuàng)建對象時需要傳入的參數(shù)類型。它的職責(zé)是提供通過創(chuàng)建相應(yīng)對象的具體策略。后記本文主要是講解從創(chuàng)建的實例過程,所以不對作過多講解,這兒只給出所處位置接口位于模塊中的命名空間下。
背景
broker.xml中有這么一段:
tcp://localhost:61618
那么,artemis中是如何將URI“tcp://localhost:61618”解析成ServerLocator的呢?
URI工廠在artemis中,URI的處理,是通過URIFactory類進行加工的。
URIFactory類位于artemis-commons包中的org.apache.activemq.artemis.utils.uri命名空間下,它的主要功能是注冊URISchema、委托URISchema創(chuàng)建相應(yīng)的對象。URIFactory類是一個模板類,用戶可以指定需要通過URI創(chuàng)建的對象的類型T,以及創(chuàng)建對象時需要傳入的參數(shù)類型P。比如我們想要通過URI創(chuàng)建ServerLocator類型的對象,則T傳入ServerLocator接口類型,P傳入String類型。如其名稱,它采用的是工廠方法設(shè)計模式。同時它還隱藏了策略模式,通過注冊URISchema方法,引入包含通過URI創(chuàng)建相應(yīng)對象的策略的URISchema,將創(chuàng)建對象的策略委托給了URISchema。
具體注冊URISchema策略的執(zhí)行者是ServerLocatorParser類。該類位于artemis-core-client模塊中的org.apache.activemq.artemis.uri命名空間下。該類的構(gòu)造函數(shù),直接注冊了4中策略:InVM、TCP、UDP、JGroup四種SchemaURI解析及策略。
public ServerLocatorParser() { registerSchema(new InVMServerLocatorSchema()); registerSchema(new TCPServerLocatorSchema()); registerSchema(new UDPServerLocatorSchema()); registerSchema(new JGroupsServerLocatorSchema()); }
策略的載體——URISchema類,位于artemis-commons包中的org.apache.activemq.artemis.utils.uri命名空間下。它也是一個模板類,,用戶可以指定需要通過URI創(chuàng)建的對象的類型T,以及創(chuàng)建對象時需要傳入的參數(shù)類型P。它的職責(zé)是提供通過URI創(chuàng)建相應(yīng)對象的具體策略。
URISchema類是策略接口的定義,其實現(xiàn)類InVMServerLocatorSchema、TCPServerLocatorSchema、UDPServerLocatorSchema、JGroupsServerLocatorSchema,是具體策略的實現(xiàn)。四個具體策略的實現(xiàn)類,位于artemis-commons包中的org.apache.activemq.artemis.uri.schema.serverLocator命名空間下。
URI策略-TCP策略的實現(xiàn)URISchema類采用了模板方法模式,其中要求子類必須實現(xiàn)internalNewObject抽象方法。我們以TCPServerLocatorSchema這個子類為例來看看它是如何實現(xiàn)internalNewObject抽象方法的。代碼如下:
ConnectionOptions options = newConnectionOptions(uri, query); Listconfigurations = TCPTransportConfigurationSchema.getTransportConfigurations(uri, query, TransportConstants.ALLOWABLE_CONNECTOR_KEYS, name, NettyConnectorFactory.class.getName()); TransportConfiguration[] tcs = new TransportConfiguration[configurations.size()]; configurations.toArray(tcs); if (options.isHa()) { return ActiveMQClient.createServerLocatorWithHA(tcs); } else { return ActiveMQClient.createServerLocatorWithoutHA(tcs); }
可見它主要是利用了TCPTransportConfigurationSchema的靜態(tài)方法getTransportConfigurations,來根據(jù)uri解析得到TransportConfiguration對象列表,然后使用ActiveMQClient工具類的createServerLocatorWithHA或createServerLocatorWithoutHA類創(chuàng)建ServerLocator接口實例的。
后記本文主要是講解從URI創(chuàng)建artemis core的ServerLocator實例過程,所以不對ServerLocator作過多講解,這兒只給出ServerLocator所處位置:
ServerLocator接口位于artemis-core-client模塊中的org.apache.activemq.artemis.api.core.client命名空間下。
兩個實現(xiàn)類,ServerLocaorInternal類和ServerLocatorImpl類,位于artemis-core-client模塊中的org.apache.activemq.artemis.api.core.client.impl命名空間下。
artemis-commons
org.apache.activemq.artemis.utils.uri URIFactory URISchema org.apache.activemq.artemis.uri.schema.serverLocator InVMServerLocatorSchema TCPServerLocatorSchema UDPServerLocatorSchema JGroupsServerLocatorSchema
artemis-core-client
org.apache.activemq.artemis.uri ServerLocatorParser org.apache.activemq.artemis.api.core TransportConfiguration org.apache.activemq.artemis.api.core.client ServerLocator ActiveMQClient org.apache.activemq.artemis.api.core.client.impl ServerLocaorInternal ServerLocatorImpl
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/35805.html
摘要:還自動配置發(fā)送和接收消息所需的基礎(chǔ)設(shè)施。支持是一個輕量級的可靠的可伸縮的可移植的消息代理,基于協(xié)議,使用通過協(xié)議進行通信。 32. 消息傳遞 Spring框架為與消息傳遞系統(tǒng)集成提供了廣泛的支持,從使用JmsTemplate簡化的JMS API到使用完整的基礎(chǔ)設(shè)施異步接收消息,Spring AMQP為高級消息隊列協(xié)議提供了類似的特性集。Spring Boot還為RabbitTempla...
摘要:在公開的方法中,為的設(shè)置了繼承于回調(diào)句柄。如此看來,如果想要異步通信完畢后,處理一些回調(diào),則只需實現(xiàn),并在適當(dāng)?shù)奈恢迷O(shè)置到的的里。在其保護方法里,創(chuàng)建了對象,并傳入了。 ActiveMQChannelHandler NettyConnector在公開的start方法中,為Channel的pipeline設(shè)置了ActiveMQChannelHandler(繼承于io.netty.chan...
摘要:本文旨在指出中集成的一些性能陷阱,在另一篇文章各組件詳解里有組件介紹及如何正確使用的內(nèi)容。因此的做法會大大降低性能,并且將大部分的時間都花在反復(fù)重建這些對象上。提供的可以讓使用避免頻繁創(chuàng)建的問題。至于使用的性能測試則留給同學(xué)自己做了。 Github 本文旨在指出Spring/Spring Boot中集成JMS的一些性能陷阱,在另一篇文章Spring JMS各組件詳解里有Spring J...
閱讀 2447·2021-11-15 11:36
閱讀 1189·2019-08-30 15:56
閱讀 2252·2019-08-30 15:53
閱讀 1049·2019-08-30 15:44
閱讀 663·2019-08-30 14:13
閱讀 1004·2019-08-30 10:58
閱讀 485·2019-08-29 15:35
閱讀 1306·2019-08-29 13:58