GoFr

logo

GoFr: An Opinionated Microservice Development Framework

godoc gofr-docs Maintainability Code Coverage Go Report Card Apache 2.0 License discord

Listed in the CNCF Landscape

## 🎯 **Goal** GoFr is designed to **simplify microservice development**, with a key focus on **Kubernetes deployment** and **out-of-the-box observability**. While capable of building generic applications, **microservices** remain at its core. --- ## 💡 **Key Features** 1. **Simple API Syntax** 2. **REST Standards by Default** 3. **Configuration Management** 4. **[Observability](https://gofr.dev/docs/quick-start/observability)** (Logs, Traces, Metrics) 5. **Inbuilt [Auth Middleware](https://gofr.dev/docs/advanced-guide/http-authentication)** & Custom Middleware Support 6. **[gRPC Support](https://gofr.dev/docs/advanced-guide/grpc)** 7. **[HTTP Service](https://gofr.dev/docs/advanced-guide/http-communication)** with Circuit Breaker Support 8. **[Pub/Sub](https://gofr.dev/docs/advanced-guide/using-publisher-subscriber)** 9. **[Health Check](https://gofr.dev/docs/advanced-guide/monitoring-service-health)** for All Datasources 10. **[Database Migration](https://gofr.dev/docs/advanced-guide/handling-data-migrations)** 11. **[Cron Jobs](https://gofr.dev/docs/advanced-guide/using-cron)** 12. **Support for [Changing Log Level](https://gofr.dev/docs/advanced-guide/remote-log-level-change) Without Restarting** 13. **[Swagger Rendering](https://gofr.dev/docs/advanced-guide/swagger-documentation)** 14. **[Abstracted File Systems](https://gofr.dev/docs/advanced-guide/handling-file)** 15. **[Websockets](https://gofr.dev/docs/advanced-guide/websocket)** --- ## 🚀 **Getting Started** ### **Prerequisites** - GoFr requires **[Go](https://go.dev/)** version **[1.24](https://go.dev/doc/devel/release#go1.24.0)** or above. ### **Installation** To get started with GoFr, add the following import to your code and use Go’s module support to automatically fetch dependencies: ```go import "gofr.dev/pkg/gofr" ``` Alternatively, use the command: ```bash go get -u gofr.dev/pkg/gofr ``` --- ## 🏃 **Running GoFr** Here's a simple example to get a GoFr application up and running: ```go package main import "gofr.dev/pkg/gofr" func main() { app := gofr.New() app.GET("/greet", func(ctx *gofr.Context) (any, error) { return "Hello World!", nil }) app.Run() // listens and serves on localhost:8000 } ``` To run this code: ```bash $ go run main.go ``` Visit [`localhost:8000/greet`](http://localhost:8000/greet) to see the result. --- ## 📂 **More Examples** Explore a variety of ready-to-run examples in the [GoFr examples directory](https://github.com/gofr-dev/gofr/tree/development/examples). --- ## 👩‍💻 **Documentation** - **[GoDoc](https://pkg.go.dev/gofr.dev)**: Official API documentation. - **[GoFr Documentation](https://gofr.dev/docs)**: Comprehensive guides and resources. --- ## 👍 **Contribute** Join Us in Making GoFr Better **Share your experience**: If you’ve found GoFr helpful, consider writing a review or tutorial on platforms like **[Medium](https://medium.com/)**, **[Dev.to](https://dev.to/)**, or your personal blog. Your insights could help others get started faster! **Contribute to the project**: Want to get involved? Check out our **[CONTRIBUTING.md](CONTRIBUTING.md)** guide to learn how you can contribute code, suggest improvements, or report issues. --- ## 🔒 **Secure Cloning** To securely clone the GoFr repository, you can use HTTPS or SSH: ### Cloning with HTTPS ```bash git clone https://github.com/gofr-dev/gofr.git ``` ### Cloning with SSH ```bash git clone git@github.com:gofr-dev/gofr.git ``` ### 🎁 **Get a GoFr T-Shirt & Stickers!** If your PR is merged, or if you contribute by writing articles or promoting GoFr, we invite you to fill out [this form](https://forms.gle/R1Yz7ZzY3U5WWTgy5) to claim your GoFr merchandise as a token of our appreciation! ### Partners JetBrains logo