[Webinaire] La reprise après sinistre des systèmes basés sur Kafka | Inscrivez-vous dès maintenant
ETL stands for “Extract, Transform, and Load.” It is a set of common processes for collecting, integrating, and distributing data to make it available for additional purposes, such as analytics, machine learning, reporting, or other business purposes. ETL enables an organization to carry out data-driven analysis and decision-making using operational data.
Built by the original creators of Apache Kafka, Confluent powers scalable, reliable, real-time streaming ETL across 120+ data sources.
At its core, ETL is a three-step process: (1) Data is collected from one or more sources, then (2) is transformed to apply the required business logic to the data, including cleaning it, remodeling it, and joining it to other data. (3) Finally, it is stored in its new destination (such as a data warehouse or non-relational database). This process is essential for effective data integration and accurate data analysis.
(Note: A common subvariant of ETL is ELT (extract load transform). ETL performs the transformation step before loading the data, while ELT performs the transformation step after loading the data.)
ETL is not new. In fact, it’s evolved quite a bit from the 1970s and 1980s, where the process was sequential, data was more static, systems were monolithic, and reporting was only needed on a weekly or monthly basis.
In the first step of ETL, the focus is on understanding where useful original data is stored, and what form or format it is in. This data can be in different formats and structures, including databases, files, applications, and real-time data streams. Then, processes are implemented to access it, through recurring batch processes, in real-time or triggered by specific events or actions.
This step involves:
In this step, the original data is cleaned, restructured, and aggregated to ensure it is in the correct format for storage in a data warehouse or other sources. This transformation process prepares the data for analysis, reporting, and use by various business applications.
Some of the key transformation processes include:
In this step, the transformed data is stored in one or more locations where it can be accessed by applications, reporting tools, and other business processes. This storage can include unstructured object stores, text files, or complex data warehouses.
The loading process varies widely depending on the nature of the business requirements and the applications and users the data serves.
Some of the key considerations in this step include:
ETL offers several key benefits that support data integration, business intelligence, and broader data management strategies:
ETL enables organizations to gather data from multiple data sources, combine it, and then distribute it where it’s needed. This allows different types of data to work together and supports data-driven analysis and decision-making using operational data.
ETL plays a critical role in getting the right data to the right place for business intelligence. By consolidating data from various sources, ETL processes enable more comprehensive and accurate reporting, allowing businesses to make informed decisions.
Common use cases for ETL include moving data from transactional or operational databases into a data warehouse or data lake for analysis and reporting. This process makes it easier and more efficient to analyze large amounts of data than would otherwise be possible in an operational database.
ETL processes clean and transform data to make it easier to work with. This involves removing inconsistencies, standardizing formats, and ensuring data quality, which is essential for accurate analysis.
Reverse ETL (rETL), also known as “Operational Analytics,” reverses the traditional ETL flow by sending cleaned and transformed data from a data warehouse into a business application. This allows organizations to access analytical data in an operational context, enabling better data-driven decisions.
ELT (Extract, Load, and Transform) is a variation of ETL where data is extracted from one or more sources, loaded into a destination database, and then transformed in place using the destination’s processing capabilities. This process is used to quickly load and integrate data from multiple sources without the need for extensive preprocessing.
The main difference between ETL and ELT is the order of data transformation and loading steps. ETL transforms data before loading, while ELT performs the transformation after loading the data into the destination.
EtLT is a sub-variation of ELT where data undergoes some basic transformations between the Extract and Load stages. However, major transformations supporting business logic or data modeling are reserved for the final transform stage. This approach balances initial data processing with the comprehensive transformations required for end-use.
Over the years, many ETL tools have been developed, each with its own unique strengths and perspectives. ETL tool developers include database vendors, cloud service providers, business intelligence/reporting vendors, and independent providers focusing exclusively on data integration.
Database vendors often provide ETL tools to enable better data integration within their product suite. Examples of database ETL tools include:
Cloud Service Providers provide ETL capabilities within their offering to facilitate loading data into their services and integration of data amongst their services. Examples include:
Business Intelligence and Enterprise Reporting vendors provide ETL tools designed to provide data for business intelligence and reporting operations. Examples include:
Data integration is an industry segment of its own. A large subset of that is ETL. Examples of ETL data integration tools include:
In our experience, a significant amount of ETL is performed without tools. Instead, custom ETL processes are often hand-written in code using a mix of SQL queries, database triggers, stored procedures, and scripting in languages such as Python, Perl, Java, server-side JavaScript, or Bash. As data volumes have expanded and data variety has increased, we’ve also seen custom ETL implemented with combinations of Apache Hadoop MapReduce or Apache Spark.
Implementing a reliable, robust, and secure ETL process is challenging. This involves accessing, transforming, and storing data from multiple sources.
Here are some of the key challenges:
Apache Kafka® is a distributed streaming platform that is the core of modern enterprise architectures. Kafka is a flexible and scalable foundation for building ETL pipelines that connect distributed systems and event-driven applications, allowing businesses to process data in real-time and at scale:
Kafka Connectors run within the Kafka Connect framework and enable developers to extract data from one system and load it into another
Kafka Streams API gives applications the stream processing capabilities to transform data, one message or event at a time. These transformations can include joining multiple data sources, filtering data, and aggregating data over a period of time
Confluent Schema Registry provides data governance with Avro and other schemas
Confluent Control Center provides central data management
ksqlDB is a database purpose-built for stream processing applications, providing a familiar, lightweight syntax to capture, process, and serve queries using only SQL.
Stream Designer provides a graphical canvas to build pipelines powered by Apache Kafka®, with SQL extensibility.
In contrast to Batch ETL, Kafka enables ETL pipelines that are streaming, allowing real-time transformation and distribution of data at large scale.