...
Overview
Usage Engine Private Edition now supports horizontal scaling of batch scaling, making it possible to increase or decrease workflows, increasing or decreasing processing capacity as needed without manual intervention. As a general concept, batch scaling is a way to speed up processes by splitting the workload between multiple “workers” or resources‘workers,’ enabling them to complete tasks in parallel rather than sequentially. Usage Engine’s solution consists of three two new agents, A Scalable File a Scalable Inter Workflow Forwarding agent and a Scalable Inter Workflow Collection agent and (Scalable InterWF Forwarder and Collector agents. A new profile has ). Two new profiles have also been created - the Partition Profile and the Scalable Inter Workflow Profile. The feature uses the existing agents, Data Aggregator and DeduplicationDuplicate UDR, which have been updated to include support a Kafka storage profiletype. Kafka must be configured for all storage within your scalable batch scaling solution. Add something here about recommended use cases as per the note above?
How it works
Scalable workflows operate by splitting batch data into partitions so that multiple workflows can cooperate to process a batch. Each scaled workflow is assigned one or more partitions and will process all the data assigned to them. When workflows are started or stopped, a rebalance is performed where partitions are reassigned to the new set of workflows.
This example shows a batch processing setup where you collect files and perform duplication checks and aggregation. We want to make this solution scalable to improve the processing times of our data during periods of high usage. We need to have set up two to three workflows in our batch scaling solution. In this example, we use three.
...
I think we should add something here to explain what a partition is… also may be helpful to link to this Doc..Automatic Scale Out and Rebalancing (4.3).
...
For example, if you have a huge list of data to process, a partitioned system could split that list into sections and process each one in parallel, speeding up the work and allowing the system to handle more data without slowing down.
...
...
In the File collection workflow the Scalable InterWF Forwarding agent sends data to the partitions. It uses one or more unique ID Fields (e.g. customer ID) to determine which partition a UDR belongs to.
The number of partitions created is determined by the Max Scale Factor parameter . This is configured in …in the Partition Profile.
Note!
The number of partitions will be the same across all storage buckets/caches/ topics. The points of storage will occur, for example,
With the passing of UDRs between workflows.
When duplicate UDR keys are detected.
For aggregated sessions.
The Duplication Check workflow(s) will check for duplicates across all partitions. Checked UDRs are placed in an additional topic with the same partitions as the corresponding Collection workflow topic. (The Duplicate keys are saved in a separate topic with the same number of partitions having the same ID fields.)
The Aggregation workflow(s) will collect data from an inter-workflow topic and use a separate aggregation session storage topic.
Prerequisites for Kafka?
...
Processing workflow isthe workflow that scales, that is, you can run from one up to the Max Scale Factor of WFs that will cooperate to do the processing. In this example, records go through a duplication check and are aggregated. Persistent storage for Duplicate UDR check and aggregation is also partitioned.
Subsections
This section contains the following subsections:
Child pages (Children Display) |
---|
...
|
...
...
Scalable Inter-workflow profile
you use the new agent InterWF Collector, to pick up the files from the external system/ IF storage (InterWF partition). You also need to have Duplication checks after which you will use the InterWF Forwarder to take the non-duplicated files and feed them to the Aggregation partitions on the data (pretty common processes in any workflow group) You will use the current agents Deduplicate and Data Aggregator, however, they will have a new storage profile option for Kafka, which you need to configure. Finally you would use the other new agent
...
|