Skip to content

This repository is the work for my final project from the Udacity Data Engineering with AWS Nanodegree Program.

Notifications You must be signed in to change notification settings

dhuy237/sparkify-airflow

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

4 Commits
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Sparkify

This repository is the work for my final project from the Udacity Data Engineering with AWS Nanodegree Program. In this project, I will build data pipeline on Amazon Redshift and Apache Airflow.

A music streaming company, Sparkify, has decided that it is time to introduce more automation and monitoring to their data warehouse ETL pipelines and come to the conclusion that the best tool to achieve this is Apache Airflow.

The source data resides in S3 and needs to be processed in Sparkify's data warehouse in Amazon Redshift. The source datasets consist of JSON logs that tell about user activity in the application and JSON metadata about the songs the users listen to.

🚀 Table of contents

  1. Prerequisites
  2. Project Motivation
  3. Instructions
  4. Results
  5. Acknowledgements

Prerequisites

These are libraries that is used in this project:

  • airflow

Instructions

  1. Connect Airflow and AWS
  2. Connect Airflow to AWS Redshift Serverless

Results

The graph view follows the flow shown in the image below. Figure: DAG with correct task dependencies

Acknowledgements

  1. For this project, I'll be working with two datasets. Here are the s3 links for each:

    • Log data: s3://udacity-dend/log_data
    • Song data: s3://udacity-dend/song_data
  2. The code is inspired by Udacity Data Engineering with AWS Nanodegree Program.

  3. For the SQL queries in this project, it is based on my prior project sparkify-data-warehouse.

🔨 Contributing

Contributions are what make the open source community such an amazing place to be learn, inspire, and create. Any contributions you make are greatly appreciated.

  1. Fork the Project.
  2. Create your Feature Branch (git checkout -b feature/Feature).
  3. Commit your Changes (git commit -m 'Add some feature').
  4. Push to the Branch (git push origin feature/Feature).
  5. Open a Pull Request.

📫 Contact

About

This repository is the work for my final project from the Udacity Data Engineering with AWS Nanodegree Program.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages