Early Development Notice: Foundation is currently in an early development stage. While you're welcome to explore and experiment, it's not yet ready for production use.
Foundation is a Go-based microservices framework aimed to help developers write scalable, resilient, and highly available applications with ease. By providing a cohesive set of well-chosen tools and features, Foundation aims to minimize boilerplate and allow developers to focus on writing business logic.
Foundation is built upon several proven technologies including:
- gRPC: A high-performance, open-source RPC framework.
- gRPC Gateway: A gRPC to JSON reverse proxy.
- Protocol Buffers: A language-neutral extensible mechanism for serializing structured data, used for gRPC and Kafka message serialization.
- Kafka: A powerful distributed streaming platform.
- OAuth 2.0: An industry-standard authorization framework.
- PostgreSQL: A robust open-source relational database system.
- WebSockets: Enabling real-time, bi-directional, and full-duplex communication channels over TCP connections.
- 🌉 Running Modes: Adapt Foundation to cater to diverse operational requirements:
- Gateway Mode: Facilitate the exposure of gRPC services as HTTP endpoints, leveraging gRPC Gateway. This mode acts as a bridge, allowing HTTP clients to communicate with your gRPC microservices transparently.
- gRPC Mode: Operate as a standard gRPC server, enabling high-performance RPC communication, ideal for microservices interaction.
- HTTP Mode: Deploy as a traditional HTTP server, offering a more general-purpose approach for serving web requests.
- Spin Worker Mode: This is your background worker, designed to continuously execute tasks. It offers configurability in terms of processing functions and the interval between task iterations.
- Jobs Worker Mode: A mode to run background jobs with Gocraft Work. Support scheduled jobs, retrying, and concurrency.
- Events Worker Mode: Building on the Worker Mode, this variant is tailored for Kafka. It ingests messages from Kafka topics and triggers associated Go function handlers.
- Job Mode: Best suited for one-off operations. Think of tasks like initializing your database, running migrations, or seeding initial data.
- Cable gRPC Mode: Function as an AnyCable-compatible gRPC server, ideal for real-time WebSocket functionalities without sacrificing scalability.
- Cable Courier Mode: This mode specializes in reading events from Kafka and then broadcasting them to Redis, readying the events for AnyCable processing. Yeah, it would be much better if we could just use Kafka directly, but AnyCable doesn't support it.
- Outbox Courier Mode: A mode to run a Kafka producer that reads messages from the database and publishes them to Kafka. This is useful for implementing the transactional outbox pattern.
- 📬 Transactional Outbox: Implement the transactional outbox pattern for transactional message publishing to Kafka.
- ✏️ Unified Logging: Conveniently log with colors during development and structured logging in production using
logrus
. - 🔍 Tracing: Trace and log your requests in a structured format with OpenTracing.
- 📊 Metrics: Collect and expose service metrics to Prometheus.
- 💓 Health Check: Provide Kubernetes with health status of your service.
- 🔐 (m)TLS: TLS authentication for Kafka and mTLS for gRPC.
- ⏳ Graceful Shutdown: Ensure clean shutdown on
SIGTERM
signal reception. - 🛠️ Helpers: A variety of helpers for common tasks.
- 🖥️ CLI: A CLI tool to help you get started and manage your project.
Foundation comes with built-in support for:
- PostgreSQL: Easily connect to a PostgreSQL database.
- Dotenv: Load environment variables from .env files.
- ORY Hydra: Authenticate users on a gateway with ORY Hydra.
- gRPC Gateway: Expose gRPC services as JSON endpoints.
- Kafka: Produce and consume messages with Kafka (via
kafka-go
). - AnyCable: Implement real-time WebSocket functionalities with AnyCable.
- Gocraft Work: Run background jobs with Gocraft Work.
- Sentry: Report errors to Sentry.
Currently, the best way to get started is by exploring the examples directory. There is an example application called clubchat
that demonstrates how to use Foundation to create a simple event-driven microservices application.
To install the CLI tool, run:
go install github.com/foundation-go/foundation/cmd/foundation@main
There are several commands available:
foundation completion # Generate shell completion scripts (prints to stdout)
foundation db:migrate # Run database migrations
foundation db:rollback # Rollback database migrations
foundation start # Start the service (you will be prompted to choose a service to start)
foundation test # Run tests
foundation new # Create `--app` or `--service`
You can also run foundation
without any arguments to see a list of available commands, or run foundation <command> --help
to see the available options for a specific command.
We're always looking for contributions from the community! If you've found a bug, have a suggestion, or want to add a new feature, feel free to open an issue or submit a pull request.
Foundation is released under the MIT License.