Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/younesious/mailing-list-microservice
A microservice-based mailing list management system using Go, gRPC, Docker, and SQLite. It offers both HTTP and gRPC APIs for managing email entries, containerized for easy deployment and scalability.
https://github.com/younesious/mailing-list-microservice
docker-compose go grpc grpc-go micro-service sqlite
Last synced: 17 days ago
JSON representation
A microservice-based mailing list management system using Go, gRPC, Docker, and SQLite. It offers both HTTP and gRPC APIs for managing email entries, containerized for easy deployment and scalability.
- Host: GitHub
- URL: https://github.com/younesious/mailing-list-microservice
- Owner: younesious
- License: mit
- Created: 2024-05-21T16:10:32.000Z (8 months ago)
- Default Branch: master
- Last Pushed: 2024-06-06T20:22:49.000Z (8 months ago)
- Last Synced: 2024-11-11T00:38:05.102Z (3 months ago)
- Topics: docker-compose, go, grpc, grpc-go, micro-service, sqlite
- Language: Go
- Homepage:
- Size: 22.5 KB
- Stars: 3
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# Mailing List Microservice
## Description
This project is a microservice-based mailing list management system built with Go, gRPC, and Docker. It includes an HTTP API for handling JSON requests and a gRPC API for more efficient communication between microservices. The system uses SQLite as its database.
## Project Structure
```sh
├── db
│ └── db.go
├── docker-compose.yml
├── go.mod
├── go.sum
├── grpc_api
│ ├── grpc_client
│ │ ├── Dockerfile
│ │ └── grpc_client.go
│ └── grpc_server
│ └── grpc_server.go
├── json_api
│ └── handlers.go
├── LICENSE
├── mailinglist.db
├── proto
│ ├── email_grpc.pb.go
│ ├── email.pb.go
│ └── email.proto
├── README.md
└── server
├── Dockerfile
└── server.go7 directories, 16 files
```
## Getting Started
### Prerequisites
- Docker
- Docker Compose### Running the Project
1. Clone the repository:
```sh
git clone https://github.com/younesious/mailing-list-microservice.git
cd mailing-list-microservice
```2. Build and start the services using Docker Compose:
```sh
docker compose up --build
```3. The HTTP server will be available on `http://localhost:8080` and the gRPC server on `http://localhost:8081`.
### Interacting with the Services
#### HTTP API Endpoints
- Add Email: `POST /email/add`
- Get Email: `GET /email/get`
- Update Email: `PUT /email/update`
- Delete Email: `DELETE /email/delete`
- Get Email Batch: `GET /email/batch`#### gRPC API
The gRPC API can be accessed using any gRPC client. Refer to the `proto/email.proto` file for the service definitions.
### Building the Project
To build the project manually:
+ Build the server:
```sh
docker build -t myserver -f server/Dockerfile .
```
+ Build the client:```sh
docker build -t myclient -f grpc_api/grpc_client/Dockerfile .
```### Running the Project
To run the gRPC server and client:
```sh
docker compose up --build
```License
-------This project is licensed under the MIT License - see the [LICENSE](https://github.com/younesious/mailing-list-microservice/blob/master/LICENSE) file for details.
### Contributing
Feel free to contribute and I'll be happy to see you :)