This project involves creating a basic URL shortener using Go and Redis. The purpose is to convert lengthy URLs into shorter links, exploring key concepts of web development, API handling, and database management.
You can use this project to learn, explore, and implementing the technical concepts and best practices of web development using Go.
π‘ This project may not be the best way
to create a URL shortener. The main idea
of this project is to learn and explore the concepts of web development, API handling, and database management using Go.
π― The primary goal of this project is to assess and contrast the performance
of the API under two conditions: with and without Redis caching.
π¬ Feel free to open an issue or a pull request if you have any ideas or suggestions. Contributions are always welcome.
- β Store the shortened URLs in MongoDB
- β Redirect to the original URL
- β Get all the shortened URLs information
- β Get a single shortened URL information
- β Delete a single shortened URL
- β Cache the shortened URLs in Redis
- β Add a simple web interface
- β Store the statistics of the shortened URLs
- β Add a simple Dockerfile
- β Create toggle to enable/disable the URL shortener
- β Create toggle to enable/disable caching in Redis
β
: Completed | β: Not Implemented | βοΈ: In Progress
GO
- Main programming language used to build the APIMongoDB
- Database to store the shortened URLsRedis
- Database to cache the shortened URLsGin
- HTTP web framework written in Go to build the APIMongo-go-driver
- MongoDB driver for GoViper
- Go configuration library
.
βββ LICENSE
βββ README.md
βββ controller
βΒ Β βββ ... (controllers)
βββ dev-logs.yml
βββ go.mod
βββ go.sum
βββ main.go
βββ model
βΒ Β βββ ... (models)
βββ router
βΒ Β βββ ... (routers)
βββ util
βββ ... (utilities)
Directory | Description |
---|---|
controller |
Contains the controllers of the API |
model |
Contains the models of the API |
router |
Contains the routers of the API |
util |
Contains the utilities of the API |
Will be added soon
If you have any ideas or suggestions, feel free to open an issue or a pull request.π€ I would be happy to hear your thoughts.
π This project is licensed under the MIT License.