Skip to content

Latest commit

 

History

History
90 lines (55 loc) · 2.31 KB

File metadata and controls

90 lines (55 loc) · 2.31 KB

Open-Source FastAPI Celery Email Service

This project is an open-source email service built with Celery, RabbitMQ, and Redis. It's designed to be easy to use and highly scalable. We welcome contributions from anyone interested in improving the service.

Prerequisites

You need to have the following installed on your machine:

  • Docker
  • Docker Compose

Getting Started

These instructions will get you a copy of the project up and running on your local machine for development and testing purposes.

Installation

  1. Clone the repository to your local machine:
git clone https://github.com/gustavosett/fastapi-celery-email-service-rabbitmq-redis.git
  1. Navigate to the project directory:
cd fastapi-celery-email-service-rabbitmq-redis

Setting up the Environment Variables

Before starting the service, you need to set up the environment variables that the application needs. These variables are stored in a .env file.

  1. Create a .env file in the root directory of the project:
touch .env
  1. Open the .env file and add the environment variables:
nano .env

The .env file should look something like this:

CELERY_BROKER_URL=amqp://guest:guest@localhost:5672//
CELERY_RESULT_BACKEND=redis://localhost:6379/0
EMAIL_HOST=your-email-host
EMAIL_PORT=your-email-port
EMAIL_HOST_USER=your-email-user
EMAIL_HOST_PASSWORD=your-email-password

Replace your-email-host, your-email-port, your-email-user, and your-email-password with your actual email service provider's SMTP server details.

  1. Save and close the file.

Now, you can start the service as described in the Installation section. The application will automatically use the environment variables from the .env file.

Start the service:

You can start the service by running the start.sh script:

./start.sh

Or you can use Docker Compose:

docker-compose up -d

Contributing

We welcome contributions from anyone. If you're interested in contributing to this project.

License

This project is licensed under the MIT License - see the LICENSE.md file for details.

Acknowledgments

  • Thanks to all the contributors who invest their time and effort to make this project better.
  • Any other acknowledgments, inspirations, and resources used for this project.