Found these recommendations
Feature or Setting
Effect
DataFlux Software Environment
Cleansing Transformations
Some transformations done for cleansing purposes can slow down processing times if used incorrectly. For example, as discussed in more detail below, certain processes like standardization may parse data (depending on the data type) prior to generating a standardized version of the data. You can use a “Parsing” node to parse the data first (or maybe the data is already parsed in the input) and then pass tokens directly to the “Standardization (Parsed)” node, side-stepping the parse.
Similarly, there is no need to standardize data prior to generating a match code for it. Match codes have standardizations built into them unique to each data type. However, if you are performing the standardization because you want to transform the data and persist the change, there may be no way to avoid the standardization.
The number of standardizations, gender guesses, and identification processes you do directly affects performance. Limit their uses as much as you can. You may also choose to use simple “Expression” node functions to perform actions like uppercasing a value or trimming a trailing space rather than using a “Change Case” or “Standardization” node if the transformations are simple and don’t need to be “locale aware.”
Parse Resource Level and Depth
Parsing data elements into smaller tokens (turning a full name field into a given name and surname field) can be resource intensive. Longer input data elements—addresses for example—take longer to process.
To improve parsing performance, you can adjust the resource level and scoring depth for each job node that uses parsing. This includes the “Parsing” node, the “Identification Analysis” node, the “Standardization” node, and the “Match Code” node.
Lowering the resource level will instruct DataFlux to uses less memory thereby freeing it up for other processes. The scoring depth setting can be set lower so that the parsing engine will not consider as many parsing “solutions” and that will reduce the overall time needed to complete parsing operations.
For relatively clean data, both of the steps can be taken to improve performance. For “dirtier” data or more complex data, making these adjustments can lead to incorrectly parsed data elements.
Parse Strategy
As we have learned, data parsing is resource intensive. However there are steps that can be taken to reduce the burden of parsing on system resources.
If you plan to parse a data element and then generate a match code for it, you are better off parsing the data element first and then use the “Match Codes (Parsed)” node in DataFlux. Otherwise, the data element will be parsed twice. The first pass will parse the element into tokens and the second pass will parse the element again when generating the match code. If you use the “Match Codes (Parsed)” node, you can pass already parsed data into the standard match code node and side-step the second parse action.
This advice holds true for gender analysis and standardization processing as well. The both have “Parsed” input options and should be considered if your data is already parsed or if you plan to parse it first in your DataFlux work-flow.
Match Criteria Complexity
Matching criteria refer to the combination of fields chosen for generating match codes bound for clustering and the clustering conditions themselves. Clustering is a word used to describe the action of finding similar data elements in rows of data and grouping those rows together using a unique key to signify that they have a relationship.
If you decide that you need to generate match codes for many fields (match codes get you the “fuzzy” match in DataFlux), your DataFlux jobs will run more slowly than if you choose not to use match codes. However, match codes are integral to DataFlux matching so you will want to take advantage of them but plan their use wisely
Clustering conditions are those rules you define that indicate what constitutes a matching record. For example, a common clustering condition for customer data would take into consideration a full name and uniquely identifying parts of an address. The more “AND” and “OR” conditions you use, the harder DataFlux will work to find the matches. This slows performance down and uses more resources.
Survivorship Rule Complexity
Once matching data rows have been identified and clustered, a common activity is creating a single best record (survivor) out of those matching rows. In DataFlux, you can author as complex survivorship rules as you wish but as they grow in number and complexity, performance will decrease.
DataFlux Process Memory Allocation
If lots of physical memory is available on the computer hosting DataFlux, allocating a good portion of the memory to DataFlux can really increase performance. For example, if you allocate 512MB RAM to DataFlux cluster processing, DataFlux can do a lot more of the work (and in some cases, all of the work) in memory which is very efficient. When DataFlux runs out of memory for the clustering, sorting, and joining of data (three memory intensive processes), it will then begin to write temporary files to disk. This process is much slower than in-memory processing.
The caveat to allocating lots of memory to these kinds of processes is that you can over allocate the memory by accident. If you give two nodes in the same work-flow each 600MB of memory and you only have 1G available, the DataFlux job will not complete because it can’t allocate the specified amount of memory.
Delaying Memory Allocation
One way to deal with accidental over allocation of memory is to use the “delay memory allocation” option in “Clustering” nodes. If you have several clustering nodes in a single work-flow, you can instruct DataFlux to only allocate the memory when data gets to each clustering node rather than pre-allocating the memory for both nodes prior to job execution. In this way, the same memory can be used for multiple clustering processes. The downside to using this option is that if data gets to the second clustering node while the first is still processing, your job will show an error except the error will occur mid-run instead of prior to execution as would be the case if you were not using this option.
Multi-Threaded Sorting/Joining/Clustering
One of the best ways to improve performance of DataFlux processes that use clustering, sorting, and joining is to enable multi-threaded processing. Data processing can be distributed across cores and across threads so that processing can be done simultaneously, breaking the main process into smaller more efficient chunks of work.
In some cases we have seen 10x to 20x performance improvements using these options with joining, sorting, and clustering nodes.
It’s suggested to set the number of threads to 2 times the number of cores. Then you can allocate how much memory can be used by each thread. Depending on resources of the computer hosting DataFlux, it may be possible to allocate quite a bit of memory for each thread.
Process Log and Debug Log Disablement
While they can be very useful when designing DataFlux work-flows, various logs generated by DataFlux (and by database drivers) can slow performance. When you are ready to move things into performance test phase or ready to move things into production, only enable the logging level needed for the project.
Certain log items like database driver traces can really reduce performance. Additionally, if you are using DataFlux “dac” logging (data access logging), this can slow performance as well. It should be turned off when not needed for debugging.
Memory Loading Small Tables
Inside DataFlux work-flows you may often find it necessary to join two branches of your work-flow together. When one side of the branch is relatively small and is being joined with a much larger set, you can choose to load the smaller data set fully into memory. This should improve performance for these types of activities. This option is available in the “Data Joining” node of DataFlux.
SQL Query Inputs and Parameterized SQL Queries
Where possible, you should take advantage of most databases’ ability to sort and join very efficiently. While you can certainly sort and join data in DataFlux, using the database to do this has real benefits.
For example, if your data input to a DataFlux work‑flow entails reading a subset of data from the database, you could either use a “Data Source” node in DataFlux that reads in all rows of data into your work-flow and then filter that data with a “Data Validation” node; or you could use a “SQL Query” node and write a SQL statement that selects and sub-sets the data. The latter approach is much more efficient and performs much faster.
Using these nodes successfully means that a certain amount of performance tuning is required in the database itself. Proper indexing, partitioning (as needed), compression, and table analysis/statistics are all crucial to solution performance. With Oracle specifically, hints and related features may be embedded in queries issued from DataFlux nodes.
Text File Outputs
Where possible, significant performance gains can be had under certain circumstance by writing results ultimately bound for a database table to a text file first. Use of the procedure depends on the context but, for example, if you process 500K rows of data and then plan to update a database table with those 500K rows, you can first write those rows to a text file in the first page of your batch work-flow. In the second page you can read from that text file and write the updates to the table.
There are several reasons why writing to text files may improve performance but one significant reason is that memory is released and reallocated for each page of a work-flow. If you are performing lots of complex operations on one page, you can spread the processing out to several pages and use more memory per process giving DataFlux a better chance of being able to do more work in memory without resorting to temporary file creation on disk.
Bulk Loading Database Table Inserts
In some cases where many rows of data need to be loaded or updated into a database, you can use a bulk loading feature built into the “Data Target (Insert)” node to drastically improve performance. It does not work with all database types but it is supported on Oracle to name one option.
You can set the maximum number of rows to bulk load to “50000” and set the commit interval to “1.” This will bulk load batches of 50000 rows of data into the database very quickly because the frequent communication with the database server as would happen with smaller packets of data can be avoided.
Pass-Thru Field Reduction
This is common sense but sometimes forgotten: the more data that passes through your work-flow, the slower it will perform. If you have 20 fields in an input table, it is easy to select all those rows and pass them through your entire work-flow. But do you really need all those rows? If you do not plan to output a row or do not need it for an operation in the work-flow, be sure to clear it from your input step. A work-flow that only uses 10 fields will perform more quickly than one with 20 fields.
Expression Code Complexity
The “Expression” node in DataFlux is a great utility tool but can also lead to performance bottlenecks. Inefficiently written expression code can slow down overall job performance. There certainly may be times when you need to use it but you should rely on the other nodes to do the heavy processing where possible since they were designed for performance with specific purposes in mind.
Some common “Expression” node actions that can perform slowly:
Regular expressions
Grouping
The print() function used for each row
Inadvertent use of the pushrow() function
Reading and writing to/from text file objects incorrectly
Work-Flow Branching
Work-flow branching is a necessary part of building complex batch jobs and real-time services. If these braches can remain independent then there is minimal performance implication (see below). However, it is often the case that data in branches need to be joined back together and this can decrease performance if done too much.
The problem can become more acute when working with real-time services or embedded jobs. Because services can only pass back data from one branch to a calling job or application, a join or union is often required to bring back together all desired output in one branch. Try to design your jobs to avoid this performance hit if possible.
It is possible to allocate extra memory for the “Branch” node itself. Similar to other nodes, this node will use physical memory to separate data into individual work‑flow segments in DataFlux. When the allocated physical memory is used up, DataFlux will begin to write temporary files to disk. By allocating more memory to branching operations, you should be able to improve performance. But like most suggestions here, this requires a balancing act. You would have to add up memory allocations for all sort, join, cluster, and branch nodes in a single page of your work-flow to understand how much you have to work with for each individual process.
Alternating Union Rows
There is an advanced option in the “Data Union” node called “Alternate” that can be set to “true” to improve performance. If it is set to “false,” all rows from one side are cached in memory (and then to disk is memory runs out) and the other side are added to the bottom of the complete set. With this set to “true” rows are alternated in the output of the node and caching can be avoided.
Database Environment
Database Bulk Loading
Testing has shown that certain bulk load utilities as can be found in Oracle and other database can be very useful when loading large amounts of data into database tables. Oracle has a utility called “SQL Loader” that can load data very quickly. For initial loading of the Customer MDM hub, you might consider processing data through DataFlux to clean, cluster and survive it but then write that output to text files as previously described. Then those text files can be used as input for SQL Loader and the data can be loaded in to the database at top speeds.
Hub Optimization
Depending on the entities that are tracked in the Customer MDM hub, you may end up with many tables and views to support those entities. It will be critical to set indexes correctly to get the best performance for lookups into the hub both for data updates and for “suppression” type processing.
Setting up entity metadata will also play a part here. Look closely at how data types are defined for each attribute and see that the right type and size are being used for each. Avoid defaulting to string(255) if possible – be more specific with the expected size of data coming into the hub. Use data profiling techniques to help set these numbers.
Check to see that attribute relationships (how certain attributes will be transformed into others, for matching purposes for example) are set up correctly as well so no extra attributes are being carried around in the work-flows or the hub database itself.
Database Drivers
Look closely at the way the database drivers are set up for your database type. Certain drivers for Oracle and other databases have settings for optimized performance. For example, you can set a larger “array size” and turn off “enable scrollable cursors” in the Oracle Wire Protocol driver to get some performance benefits. Native drivers will have similar performance settings as well and it is worth reviewing the documentation to see what the optimal settings are.
Don’t forget to disable driver logging and tracing at runtime as leaving them on can dramatically decrease performance.
... View more