Zillacode is the only platform on the internet where you can practice 50+ LeetCode like questions using PySpark, Spark, DBT and Snowflake. The entire platform spins up on any machine with one command using Docker Compose.
In addition to solving Zillacode problems you can also learn from the repo itself. Zillacode was once a live micro-serviced B2C SAAS platform deployed using the AWS serverless stack. All of the Infrastructure as Code files have been left in place for anyone who wants to learn about Devops or try to deploy it themselves.
git clone https://github.com/davidzajac1/zillacode.git
cd zillacode
docker compose up
Then navigate to http://localhost:5173
Make sure nothing is running on ports 5001, 5173, 8001, 8002, 8003 before running locally. See the commands below to kill anything running on these ports:
# Mac/Linux
sudo kill -9 $(sudo lsof -ti:5001,5173,8001,8002,8003)
# Windows
netstat -ano | findstr :5001 :5173 :8001 :8002 :8003
Zillacode previously used port 5000 which caused issues for many users and thus now uses port 5001 instead. If you are experiencing issues like problems endlessly loading please make sure you are using newest version of the master
branch and the newest images from the zillacode-backend and zillacode-frontend Docker Hub repos and that you have inspected the IDE page to make sure there are no requests going to port 5000.
Note Snowflake is not Open Source thus to solve problems with DBT/Snowflake you need to add a .env
file with Snowflake credentials in the backend
directory. All problems except for DBT/Snowflake problem will work normally without the .env
file.
SNOWFLAKE_USERNAME=<SNOWFLAKE_USERNAME>
SNOWFLAKE_PASSWORD=<SNOWFLAKE_PASSWORD>
SNOWFLAKE_ACCOUNT=<SNOWFLAKE_ACCOUNT>
SNOWFLAKE_WAREHOUSE=<SNOWFLAKE_WAREHOUSE>
You can set up your own Snowflake account, all queries run by Zillacode will not result in any spend as they all just compile as Common Table Expressions without querying any tables. Your Snowflake user must have permissions to use your Snowflake warehouse.
For any bugs/issues please make an Issue in GitHub. See the Contributing section on how to make a Pull Request if you want to fix the problem yourself.
Feel free to ask any questions about the project or anything Data Engineering, Spark, etc. related in a GitHub Discussion. All announcements about the project will be made in GitHub Discussions as well.
All contributions from Issues to Pull Requests are greatly appreciated!
Zillacode runs locally using Docker Compose and is divided into 5 microservices. The app can be run as is just by running make up
but if you want to make changes see the sections below for how development works with each service.
Note Zillacode at was originally a SAAS product but now the project is just designed to run locally with Docker Compose, but all of the Terraform/Zappa/GitHub Actions config files are left in the project for anyone who wants to try to deploy it to the cloud.
To make a Pull Request fork the project then make a Pull Request to the master
branch. Please be specific about the changes you are making.
For making frontend changes, spin up the backend in the background using Docker by running make up-backend
, this will spin up the backend on http://localhost:5000. Then run make serve-frontend
to serve the frontend on http://localhost:5173. The frontend will send requests to the backend hosted locally.
For adding new dependencies run make add package=<PACKAGE TO INSTALL>
.
To clean up run make down
to shut down the backend containers Docker is running.
The backend is comprised of 4 separate services hosted on AWS Lambda. To rebuild changes made to any of these services run make rebuild container=<backend|spark|scala-spark|db-lambda>
.
The Zillacode backend API is a Flask application that receives HTTP requests from the frontend. This service is contained in the backend
directory. All endpoints thus to create a new endpoint you only need to change the Python code in the ./backend/app.py
file.
The Spark Lambda is used to run PySpark code and is built from a Docker Image. It is contained in the spark-lambda
directory.
The Scala Spark Lambda is essentially the same as the Spark Lambda but is used to run Scala code. It is contained in the scala-spark-lambda
directory. The Scala Spark Lambda image is built using sbt
, a common Scala build framework. It is slow and may take about 15 minutes to build the Docker image.
This Lambda is used to run Python Pandas code. It is separated from the backend Flask App because it uses the Python exec()
function to remotely execute code thus it needs to be in its own service that has no permissions and can't make outbound connections.