Hybrid Analytic Flows-the Case for Optimization

  • Authors:
  • Alkis Simitsis;Kevin Wilkinson;Umeshwar Dayal

  • Affiliations:
  • HP Labs, Palo Alto, CA 94304, USA. alkis@hp.com/ kevin.wilkinson@hp.com/ umeshwar.dayal@hp.com;HP Labs, Palo Alto, CA 94304, USA. alkis@hp.com/ kevin.wilkinson@hp.com/ umeshwar.dayal@hp.com;HP Labs, Palo Alto, CA 94304, USA. alkis@hp.com/ kevin.wilkinson@hp.com/ umeshwar.dayal@hp.com

  • Venue:
  • Fundamenta Informaticae - Scalable Workflow Enactment Engines and Technology
  • Year:
  • 2013

Quantified Score

Hi-index 0.00

Visualization

Abstract

To remain competitive, enterprises are evolving in order to quickly respond to changing market conditions and customer needs. In this new environment, a single centralized data warehouse is no longer sufficient. Next generation business intelligence involves data flows that span multiple, diverse processing engines, that contain complex functionality like data/text analytics, machine learning operations, and that need to be optimized against various objectives. A common example is the use of Hadoop to analyze unstructured text and merging these results with relational database queries over the data warehouse. We refer to these multi-engine analytic data flows as hybrid flows. Currently, it is a cumbersome task to create and run hybrid flows. Custom scripts must be written to dispatch tasks to the individual processing engines and to exchange intermediate results. So, designing correct hybrid flows is a challenging task. Optimizing such flows is even harder. Additionally, when the underlying computing infrastructure changes, existing flows likely need modification and reoptimization. The current, ad-hoc design approach cannot scale as hybrid flows become more commonplace. To address this challenge, we are building a platform to design and manage hybrid flows. It supports the logical design of hybrid flows in which implementation details are not exposed. It generates code for the underlying processing engines and orchestrates their execution. But the key enabling technology in the platform is an optimizer that converts the logical flow to an executable form that is optimized for the underlying infrastructure according to user-specified objectives. In this paper, we describe challenges in designing the optimizer and our solutions. We illustrate the optimizer through a real-world use case. We present a logical design and optimized designs for the use case. We show how the performance of the use case varies depending on the system configuration and how the optimizer is able to generate different optimized flows for different configurations.