This document outlines the main directions on the Kubeflow Pipelines (KFP) project in 2019.
We will continue developing capabilities for better reliability, scaling, and maintenance of production ML systems built with Kubeflow Pipelines.
- Ability to easily upgrade KFP system components to new versions and applying fixes to a live cluster without losing state
- Ability to externalize the critical metadata state to a data store outside of cluster lifetime
- Ability to configure a standard cluster wide persistent storage that all pipelines can share, connected to any cloud or on-prem storage system
- Easy deployment of KFP system services
To make it easy to use KFP within an ecosystem of other cloud services, and take advantage of scale and other capabilities of job scheduling services, data processing services - KFP components will build a framework for reliable connection to other services. Google will extend the framework and contribute a few specific connector components:
- Connectors to DataProc (Spark), DataFlow (Beam), BigQuery, Cloud ML Engine
As a foundational layer in the ML system, KFP will introduce an extensible and scalable metadata store for tracking versioning, dependencies, and provenance of artifacts and executables. The metadata store can be used from any other KF component to help users easily connect artifacts to its origins, its metrics, and its effects and consumption points.
- Metadata Store and API
- Automatic tracking of pipelines, pipeline steps, parameters and artifacts
- Extensible Type System and Standard Types for most common ML artifacts (models, datasets, metrics, visualizations)
To make it easy for users to share and consume KFP components within and outside of an organization, KFP will improve the sharing capabilities in the KFP SDK:
- Component configuration for easy sharing of components through file sharing and source control
- Ability to represent a pipeline as a component for other pipeline
KPF UI will continue to improve to make it more intuitive to operate KFP cluster and manage KFP resources:
- Metadata UI to allow exploration and search experience over artifacts and types
- Ability to use Notebooks outside of the K8S cluster to build and control pipeline execution
- Controls for viewing pipeline topology and execution results within Notebooks
To make it more efficient to run ML experiments KFP will add features for faster iteration over experiments, better control and transparency of the execution engine: Support for caching of pipeline artifacts and ability to use the artifacts cache to accelerate pipeline re-execution. Steps that have already executed can be skipped on subsequent runs.
- Ability to stop/restart pipeline jobs
- Ability to track pipeline dependencies and resources created/used by a pipeline job
Many ML workflows are better to be expressed as triggered by data availability or by external events. KFP will have native support for data driven and event driven workflows. KFP will provide the ability to configure pipeline execution upon appearance of certain entries in the metadata store, making it easy to create complex CI pipelines orchestrated around key artifacts, such as models.
KFP SDK for defining the pipeline topologies and component dependencies will add more advanced control operators for organizing workflow loops, parallel for-each, and enhanced conditions support.