Skip to content

End-to-end data engineering pipeline for tracking daily changes in flight prices

Notifications You must be signed in to change notification settings

MarcusLe02/google-flights-etl

Repository files navigation

Google Flights ETL Project

Overview

This repository contains the source code and documentation for the Google Flight ETL project. The project involves daily crawling of flight data using Selenium, storing the data in MySQL, processing it with Apache Spark, storing in HDFS as a data lake, and warehousing the data with Hive. The entire environment is containerized and deployed using Docker.

System Architecture

System Architecture

Project Structure

Components

  • Selenium: Web scraping tool used for extracting flight data from Google Flights.
  • MySQL: Relational database used for storing raw flight data.
  • Apache Spark: Distributed data processing engine for data transformation.
  • HDFS: Distributed file system used as a data lake for storing processed data.
  • Hive: Data warehousing tool for querying and analyzing structured data.

Prerequisites

  • Docker installed on your machine.
  • Python and necessary libraries for Selenium web scraping.

Getting Started

  1. Clone the repository:

    git clone https://github.com/your-username/google_flight_etl.git
    cd google_flight_etl
  2. Build and run the Docker containers:

    cd docker-configuration
    docker-compose up -d
  3. Execute the data crawling process:

    python flight_selenium.py
  4. Execute the Hadoop ingestion process, remember to change execution date parameter to your current date:

    docker exec -it namenode bash
    spark-submit --master spark://spark-master:7077 --py-files pyspark-jobs/ingestion.py --tblName "flights" --executionDate "YYYY-MM-DD"
  5. Execute the Hive transformation process:

    docker exec -it namenode bash
    spark-submit --master spark://spark-master:7077 --py-files pyspark-jobs/transformation.py --executionDate "YYYY-MM-DD"
  6. Deploy Superset, connect Hive to Superset dashboard, and design with your own style:

    export SUPERSET_VERSION=<latest_version>
    
    docker pull apache/superset:$SUPERSET_VERSION
    
    docker run -d -p 8088:8088 \
             -e "SUPERSET_SECRET_KEY=$(openssl rand -base64 42)" \
             -e "TALISMAN_ENABLED=False" \
             --name superset apache/superset:$SUPERSET_VERSION

Superset Dashboard Example

System Architecture

Acknowledgments

This project is inspired by the Data Lake & Warehousing demo by Mr. Canh Tran (Data Guy Story). The architecture design, ingestion, and transformation scripts in Spark (Scala) were outlined in a video available here. I adapted the scripts to use PySpark for implementation.

Contact

For questions or support, please contact [[email protected]].

About

End-to-end data engineering pipeline for tracking daily changes in flight prices

Topics

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published