Delunch

A child charity project that aims to provide daily meals to mountainous area childrens for 9 months, costing only $0.5per meal.
Position
Creator
Type
Software
Date
2023
Source

Description

Delunch

Delights chilrens' future

Delunch is a child charity project that utilizes a full stack of technologies to provide a seamless user experience for both the donors and the beneficiaries. The project aims to provide free lunches to children in underprivileged areas, especially those who cannot afford to have a healthy meal every day.

Note: This is an ongoing project, more detail will be updated daily

Overview
Delunch is a child charity project that aims to provide daily meals for underprivileged mountainous area children, especially those who cannot afford to have a healthy meal every day, at the affordable cost of only 0.5 dollars per meal for 9 months. Here is the firstlook of the project:


Detail

The project's backend is built with Flask, a micro web framework in Python, and uses Kafka, an open-source event streaming platform, to allow communication between various microservices. The Flask backend exposes RESTful APIs through the routes, which accept donations from sponsors, and sends the data to Kafka topics for further processing.

Flink is used for stream processing, which consumes data from Kafka topics and generates real-time analytics. The generated analytics include real-time counts of received donations, the total amount donated, the number of active sponsorships, and much more. Flink is also used to validate the received data, ensuring that the data received from the Kafka topic is not corrupted or duplicated.

The project uses MySQL as its primary database for storing data such as sponsor information, sponsorship plans, and donations received. The Python connector package "mysql-connector-python" is used to connect to the database and execute queries. The database is set up in a containerized environment through Docker.

The project also utilizes Google Cloud's infrastructure for scalability, reliability, and security. Google Kubernetes Engine (GKE) is used for container orchestration, which allows for dynamic scaling of resources and high availability. Google Cloud Load Balancing is used to distribute traffic to the backend instances, while Google Cloud Security Scanner provides vulnerability scanning of the deployed application.

Finally, the project uses Google Cloud Pub/Sub to provide messaging services for asynchronous communication between different microservices. Pub/Sub also allows for scalability and reliable delivery of messages.

System Design

Primary Event Streaming Design


Tech Stack

Python

Flask

React

JavaScript

MySQL

Redis

Git

Kafka

GCP

Docker

(back to top)