System and method for dynamic clustered jms in an application server environment
US-2016094625-A1 · Mar 31, 2016 · US
US10715472B2 · US · B2
| Field | Value |
|---|---|
| Publication number | US-10715472-B2 |
| Application number | US-201816027616-A |
| Country | US |
| Kind code | B2 |
| Filing date | Jul 5, 2018 |
| Priority date | Aug 22, 2017 |
| Publication date | Jul 14, 2020 |
| Grant date | Jul 14, 2020 |
A practical reading order for non-experts. Skip the full description unless you need deep technical detail.
What the patent document calls the invention.
A short plain-language summary of the technical disclosure.
Who owns or filed the patent and who is credited as inventor.
Filing, priority, publication, and grant dates set the timeline.
The legal scope of protection — read this for what is actually claimed.
Technology tags used to group this patent with similar filings.
Prior art links and similar publications in this corpus.
Official abstract text for this publication.
In accordance with an embodiment, a system and method provides a messaging service implementing a unit-of-order guarantee in a multitenant application server environment. The system and method of implementing unit-of-order utilizes an improved path service for routing all messages having a particular unit-of-order to the same member of the cluster. The improved path service allows for scalability of the cluster and reduced resource utilization, thereby improving the performance of a clustered computing system providing the messaging service.
Opening claim text (preview).
What is claimed is: 1. A system for supporting unit-of-order (UOO) messaging in an application server environment, comprising: a cluster having a first member count of cluster members, wherein the cluster is scaled to have a second member count of cluster members; wherein each cluster member comprises an application server operating on a computer comprising a processor and memory, and wherein each cluster member is connected to each other cluster member by a network; a path service in the cluster; wherein the path service creates a first routing table for the cluster which includes routes for UOO which correspond to a value calculated by a modulo operation applied to a hash of a UOO string over the first member count; wherein the path service creates a second routing table for the scaled cluster which includes routes for UOO which correspond to a value calculated by a modulo operation applied to a hash of a UOO string over the second member count; wherein when messages in a particular UOO are routed to different members by the path service using the first routing table and the second routing table, the path service operates to pause message consumption at a member of the different members. 2. The system of claim 1 , wherein the different members includes a first member in the original cluster, and a second member in the scaled cluster, and wherein the member where message consumption is paused is the second member. 3. The system of claim 1 , wherein the second member count is greater than the first member count. 4. The system of claim 1 , wherein the paused message consumption is unpaused when message consumption for the particular UOO is completed at another member. 5. The system of claim 1 , wherein the path service deletes the first routing table after messages routed using the first routing tables are consumed. 6. The system of claim 1 , wherein each of the plurality of members in the cluster is a queue or a topic. 7. The system of claim 1 , wherein the cluster is a Java Message Service (JMS) cluster. 8. The system of claim 1 , wherein the plurality of members in the cluster is provided in a distributed destination. 9. The system of claim 1 , wherein the path service is a singleton service. 10. A method for supporting unit-of-order (UOO) messaging in an application server environment, comprising: providing a path service in a cluster having a first member count of cluster members, wherein the cluster is scaled to have a second member count of cluster members, wherein, the path service creates a first routing table for the cluster, wherein the first routing table includes routes for UOO messages, wherein each of the routes in the first routing table corresponds to a value calculated by a modulo operation applied to a hash of a UOO string over the first member count, and the path service creates a second routing table for the cluster after the clustered is scaled, wherein the second routing table includes routes for UOO messages, wherein each of the routes in the second routing table corresponds to a value calculated by a modulo operation applied to a hash of a UOO string over the second member count; routing, by the path service, messages in a particular UOO to different members using the first routing table and the second routing table; and pausing, by the path service, message consumption at a member of the different members. 11. The method of claim 10 , wherein the different members includes a first member in the original cluster, and a second member in the scaled cluster, and wherein the member where message consumption is paused is the second member. 12. The method of claim 10 , wherein the second member count is greater than the first member count. 13. The method of claim 10 , wherein the paused message consumption is unpaused when message consumption for the particular UOO is completed at another member. 14. The method of claim 10 , wherein the path service deletes the first routing table after messages routed using the first routing tables are consumed. 15. The method of claim 10 , wherein each of the plurality of members in the cluster is a queue or a topic. 16. The method of claim 10 , wherein the cluster is a Java Message Service (JMS) cluster. 17. The method of claim 10 , wherein the plurality of members in the cluster is provided in a distributed destination. 18. The method of claim 10 , wherein the path service is a singleton service. 19. A non-transitory computer-readable storage medium storing a set of instructions for supporting unit-of-order (UOO) messaging in an application server environment, said instructions, when executed by one or more processors, causing the one or more processors to perform steps comprising: providing a path service in a cluster having a first member count of cluster members, wherein the cluster is scaled to have a second member count of cluster members, wherein, the path service creates a first routing table for the cluster, wherein the first routing table includes routes for UOO messages, wherein each of the routes in the first routing table corresponds to a value calculated by a modulo operation applied to a hash of a UOO string over the first member count, and the path service creates a second routing table for the cluster after the clustered is scaled, wherein the second routing table includes routes for UOO messages, wherein each of the routes in the second routing table corresponds to a value calculated by a modulo operation applied to a hash of a UOO string over the second member count; routing, by the path service, messages in a particular UOO to different members using the first routing table and the second routing table; and pausing, by the path service, message consumption at a member of the different members. 20. The non-transitory computer-readable storage medium of claim 19 , wherein the different members includes a first member in the original cluster, and a second member in the scaled cluster, and wherein the member where message consumption is paused is the second member.
Application servers providing network services (systems providing special services to telephonic subscribers H04M3/42) · CPC title
Storing data temporarily at an intermediate stage, e.g. caching · CPC title
for distributed storage of data in networks, e.g. transport arrangements for network file system [NFS], storage area networks [SAN] or network attached storage [NAS] · CPC title
in the application layer [OSI layer 7] · CPC title
based on web technology, e.g. hypertext transfer protocol [HTTP] · CPC title
Related publications grouped by family.
Answers are generated from the same data shown on this page.