2023-05-19 16:23:55 -04:00
|
|
|
# :unicorn: Fx [data:image/s3,"s3://crabby-images/6f1b4/6f1b452476ed5751a8fec826f5e480d228142bc7" alt="GoDoc"](https://pkg.go.dev/go.uber.org/fx) [data:image/s3,"s3://crabby-images/6db3d/6db3d2b8985a2f8dfe6d34e1ded24bbe34aba920" alt="Github release"](https://github.com/uber-go/fx/releases) [data:image/s3,"s3://crabby-images/ae1e0/ae1e095da4cc47452770360ba7bff4c3a18dbfc3" alt="Build Status"](https://github.com/uber-go/fx/actions/workflows/go.yml) [data:image/s3,"s3://crabby-images/54df7/54df76251e4a2a5e084a658cb7a61281f2c84339" alt="Coverage Status"](https://codecov.io/gh/uber-go/fx/branch/master) [data:image/s3,"s3://crabby-images/40d1b/40d1b22fb6fb0394cb84080d7da3dc0b619497a0" alt="Go Report Card"](https://goreportcard.com/report/go.uber.org/fx)
|
2023-02-22 17:58:17 -04:00
|
|
|
|
2023-05-19 16:23:55 -04:00
|
|
|
Fx is a dependency injection system for Go.
|
2023-02-22 17:58:17 -04:00
|
|
|
|
2023-05-19 16:23:55 -04:00
|
|
|
**Benefits**
|
|
|
|
|
|
|
|
- Eliminate globals: Fx helps you remove global state from your application.
|
|
|
|
No more `init()` or global variables. Use Fx-managed singletons.
|
|
|
|
- Code reuse: Fx lets teams within your organization build loosely-coupled
|
|
|
|
and well-integrated shareable components.
|
|
|
|
- Battle tested: Fx is the backbone of nearly all Go services at Uber.
|
|
|
|
|
|
|
|
See our [docs](https://uber-go.github.io/fx/) to get started and/or
|
|
|
|
learn more about Fx.
|
2023-02-22 17:58:17 -04:00
|
|
|
|
|
|
|
## Installation
|
|
|
|
|
2023-05-19 16:23:55 -04:00
|
|
|
Use Go modules to install Fx in your application.
|
2023-02-22 17:58:17 -04:00
|
|
|
|
|
|
|
```shell
|
|
|
|
go get go.uber.org/fx@v1
|
|
|
|
```
|
|
|
|
|
2023-05-19 16:23:55 -04:00
|
|
|
## Getting started
|
|
|
|
|
|
|
|
To get started with Fx, [start here](https://uber-go.github.io/fx/get-started/).
|
|
|
|
|
2023-02-22 17:58:17 -04:00
|
|
|
## Stability
|
|
|
|
|
2023-08-22 16:02:01 +05:30
|
|
|
This library is `v1` and follows [SemVer](https://semver.org/) strictly.
|
2023-02-22 17:58:17 -04:00
|
|
|
|
|
|
|
No breaking changes will be made to exported APIs before `v2.0.0`.
|
|
|
|
|
2023-05-19 16:23:55 -04:00
|
|
|
This project follows the [Go Release Policy](https://golang.org/doc/devel/release.html#policy). Each major
|
2023-02-22 17:58:17 -04:00
|
|
|
version of Go is supported until there are two newer major releases.
|
|
|
|
|
2023-05-19 16:23:55 -04:00
|
|
|
## Stargazers over time
|
|
|
|
|
|
|
|
[data:image/s3,"s3://crabby-images/92f42/92f422dc69fa4b5823f773c90385954d3b9758ec" alt="Stargazers over time"](https://starchart.cc/uber-go/fx)
|
|
|
|
|