fx
Rudderstack
Our great sponsors
fx | Rudderstack | |
---|---|---|
31 | 83 | |
5,091 | 3,897 | |
4.4% | 1.3% | |
8.2 | 9.8 | |
12 days ago | 2 days ago | |
Go | Go | |
MIT License | GNU General Public License v3.0 or later |
Stars - the number of stars that a project has on GitHub. Growth - month over month growth in stars.
Activity is a relative number indicating how actively a project is being developed. Recent commits have higher weight than older ones.
For example, an activity of 9.0 indicates that a project is amongst the top 10% of the most actively developed projects that we are tracking.
fx
-
I write HTTP services in Go after 13 years (Mat Ryer, 2024)
I found fx(https://github.com/uber-go/fx) to be a super simple yet versatile tool to design my application around.
All the advice in the article is still helpful, but it takes the "how do I make sure X is initialized when Y needs it" part completely out of the equation and reduces it from an N*M problem to an N problem, ie I only have to worry about how to initialize individual pieces, not about how to synchronize initialization between them.
I've used quite a few dependency injection libraries in various languages over the years (and implemented a couple myself) and the simplicity and versatility of fx makes it my favorite so far.
-
go-ecommerce-microservices: A practical e-commerce microservices, built with cqrs, event sourcing, vertical slice architecture, event-driven architecture.
Some of the features: - ✅ Using Vertical Slice Architecture as a high level architecture - ✅ Using Event Driven Architecture on top of RabbitMQ Message Broker with a custom [Event Bus](pkg/messaging/bus/) - ✅ Using Event Sourcing in Audit Based services like [Orders Service](services/orders/) - ✅ Using CQRS Pattern and Mediator Patternon top of Go-MediatR library - ✅ Using Dependency Injection and Inversion of Controlon top of uber-go/fx library - ✅ Using RESTFul api with Echo framework and using swagger with swaggo/swag library - ✅ Using Postgres and EventStoreDB to write databases with fully supports transactions(ACID) - ✅ Using MongoDB and Elastic Search for read databases (NOSQL) - ✅ Using OpenTelemetry for collection Distributed Tracing with using Jaeger and Zipkin - ✅ Using OpenTelemetry for collection Metrics with using Prometheus and Grafana - ✅ Using Unit Test for testing small units with mocking dependent classes and using Mockery for mocking dependencies - ✅ Using End2End Test and Integration Test for testing features with all of their real dependeinces using docker containers (cleanup tests) and testcontainers-go library
-
Gorilla,wow
any take on https://github.com/uber-go/fx?
-
App init and graceful watch lib recommendations ?
I’m not sure of much that can do all of that - maybe it’s a use case for https://github.com/uber-go/fx
-
Zerolog printing logs multiple times
Hello gophers, I am using https://github.com/uber-go/fx and https://github.com/rs/zerolog for logging.
-
Does this project structure make sense?
Also, I like to use Uber FX for my DI stuff. You can check it out here:https://github.com/uber-go/fx
-
As a Go programmer, what design pattern, programming techniques have you actually used, implemented regularly in your workplace which made your life much easier?
I only have private and work repos... But I use Uber fx. https://github.com/uber-go/fx
-
Does Golang has any framework like Springboot?
Spring Boot is notable for its dependency injection / inversion of control. The closest Go has to this is Uber's Fx which also includes some lifecycle management.
-
Config for production and mocking (db connections, http parsers etc)
If you have such a complex and deep dependency graph, and you don't want to manually maintain it, you could use some DI library to handle that for you. Something like https://github.com/google/wire for small-medium size stuff, or https://github.com/uber-go/fx for larger scale, more enterprise projects.
-
my office want to migrate to go programming language, what framework is recommended between chi or fiber?
I've been looking into fx by Uber. Looks pretty cool, but I haven't had the chance to do anything more than a hello, world with it.
Rudderstack
-
Google Analytics 4 Has Me So Frustrated, We Built Our Own Analytics Service
In bigger setups, all you want is a data collector and router so that you can feed the data into multiple destinations, depending on the use case. Analytics is just one. Example: https://www.rudderstack.com/ & https://www.rudderstack.com/replace-google-analytics-4-guide...
-
I want to contribute to open source but don't know where to start
Check out RudderStack, a Go project to build data pipeline. Our slack is quite active. The best way to contribute is by creating a new integration with your favorite tool. You do not need to rely to too much on existing knowledge about inner workings of the project to do so, so it is beginner friendly.
-
Writing few lines of open-source js/python code can get ₹8k-80k. Is it a good reward for an oss challenge? Last day, more prizes than the participants until now :)
I thought, start the challenge, they will come. I was wrong. This is the last day of the Transformations challenge at RudderStack. If you compare the # of submissions with the # of prizes, there are good chances that your submission may get a prize (lowest ₹8k and highest ₹80k).
The challenge is over. Winners have been announced. When we are ready for the next one, will announce on RudderStack GitHub repo
-
Project showcase: sample Data Lakehouse
Super. This is amazing. Sharing your project with the community. If you get a chance, try out RudderStack to build your pipeline.
-
Entire tech industry right now
P.S. If you're here, do support open-source project - RudderStack
RudderStack?
-
Go doesn’t do any magical stuff and I love that
RudderStack (open-source event streaming, alternative to Segment) processed 1 trillion+ events last year and has 400+ integrations with different services. It would have been nightmare if it was not built in Go.
-
Interview Prep - Senior Data Integration role
RudderStack, dbt, Kafka, Headless CDP, etc. on top of my mind
-
Can we take a moment to appreciate how much of dataengineering is open source?
It takes a village to build an open-source project. Grateful to 170+ contributors who contributed to RudderStack
What are some alternatives?
dig - A reflection based dependency injection toolkit for Go.
wire - Compile-time Dependency Injection for Go
wire - Strict Runtime Dependency Injection for Golang
Snowplow - The enterprise-grade behavioral data engine (web, mobile, server-side, webhooks), running cloud-natively on AWS and GCP
PostHog - 🦔 PostHog provides open-source product analytics, session recording, feature flagging and A/B testing that you can self-host.
Socioboard - Socioboard is world's first and open source Social Technology Enabler. Socioboard Core is our flagship product.
unomi - Apache Unomi
container - A lightweight yet powerful IoC dependency injection container for the Go programming language
Elasticsearch - Free and Open, Distributed, RESTful Search Engine
captcha - :sunglasses:Package captcha provides an easy to use, unopinionated API for captcha generation
Apache Kafka - Mirror of Apache Kafka
wild-workouts-go-ddd-example - Go DDD example application. Complete project to show how to apply DDD, Clean Architecture, and CQRS by practical refactoring.