106 lines
5.2 KiB
Markdown
106 lines
5.2 KiB
Markdown
|
<p align="center">
|
|||
|
<a href="https://sentry.io/?utm_source=github&utm_medium=logo" target="_blank">
|
|||
|
<picture>
|
|||
|
<source srcset="https://sentry-brand.storage.googleapis.com/sentry-logo-white.png" media="(prefers-color-scheme: dark)" />
|
|||
|
<source srcset="https://sentry-brand.storage.googleapis.com/sentry-logo-black.png" media="(prefers-color-scheme: light), (prefers-color-scheme: no-preference)" />
|
|||
|
<img src="https://sentry-brand.storage.googleapis.com/sentry-logo-black.png" alt="Sentry" width="280">
|
|||
|
</picture>
|
|||
|
</a>
|
|||
|
</p>
|
|||
|
|
|||
|
# Official Sentry SDK for Go
|
|||
|
|
|||
|
[data:image/s3,"s3://crabby-images/a6656/a66563c988fd79468439b6f43756adffe39dce43" alt="Build Status"](https://github.com/getsentry/sentry-go/actions?query=workflow%3Ago-workflow)
|
|||
|
[data:image/s3,"s3://crabby-images/3ab01/3ab0190858aeba08d394c722eeade122e2b78d1c" alt="Go Report Card"](https://goreportcard.com/report/github.com/getsentry/sentry-go)
|
|||
|
[data:image/s3,"s3://crabby-images/04da8/04da8164d8764c4f952fc3b9d834ebe23c57ffd2" alt="Discord"](https://discord.gg/Ww9hbqr)
|
|||
|
[data:image/s3,"s3://crabby-images/e0a6f/e0a6fe614c824f83c77a4d7aede132fd1ff5d02b" alt="GoDoc"](https://godoc.org/github.com/getsentry/sentry-go)
|
|||
|
[data:image/s3,"s3://crabby-images/ee7e3/ee7e33b27c2a4f930ea943468faebbf58fca217f" alt="go.dev"](https://pkg.go.dev/github.com/getsentry/sentry-go)
|
|||
|
|
|||
|
`sentry-go` provides a Sentry client implementation for the Go programming
|
|||
|
language. This is the next generation of the Go SDK for [Sentry](https://sentry.io/),
|
|||
|
intended to replace the `raven-go` package.
|
|||
|
|
|||
|
> Looking for the old `raven-go` SDK documentation? See the Legacy client section [here](https://docs.sentry.io/clients/go/).
|
|||
|
> If you want to start using `sentry-go` instead, check out the [migration guide](https://docs.sentry.io/platforms/go/migration/).
|
|||
|
|
|||
|
## Requirements
|
|||
|
|
|||
|
The only requirement is a Go compiler.
|
|||
|
|
|||
|
We verify this package against the 3 most recent releases of Go. Those are the
|
|||
|
supported versions. The exact versions are defined in
|
|||
|
[`GitHub workflow`](.github/workflows/test.yml).
|
|||
|
|
|||
|
In addition, we run tests against the current master branch of the Go toolchain,
|
|||
|
though support for this configuration is best-effort.
|
|||
|
|
|||
|
## Installation
|
|||
|
|
|||
|
`sentry-go` can be installed like any other Go library through `go get`:
|
|||
|
|
|||
|
```console
|
|||
|
$ go get github.com/getsentry/sentry-go@latest
|
|||
|
```
|
|||
|
|
|||
|
Check out the [list of released versions](https://pkg.go.dev/github.com/getsentry/sentry-go?tab=versions).
|
|||
|
|
|||
|
## Configuration
|
|||
|
|
|||
|
To use `sentry-go`, you’ll need to import the `sentry-go` package and initialize
|
|||
|
it with your DSN and other [options](https://pkg.go.dev/github.com/getsentry/sentry-go#ClientOptions).
|
|||
|
|
|||
|
If not specified in the SDK initialization, the
|
|||
|
[DSN](https://docs.sentry.io/product/sentry-basics/dsn-explainer/),
|
|||
|
[Release](https://docs.sentry.io/product/releases/) and
|
|||
|
[Environment](https://docs.sentry.io/product/sentry-basics/environments/)
|
|||
|
are read from the environment variables `SENTRY_DSN`, `SENTRY_RELEASE` and
|
|||
|
`SENTRY_ENVIRONMENT`, respectively.
|
|||
|
|
|||
|
More on this in the [Configuration section of the official Sentry Go SDK documentation](https://docs.sentry.io/platforms/go/configuration/).
|
|||
|
|
|||
|
## Usage
|
|||
|
|
|||
|
The SDK supports reporting errors and tracking application performance.
|
|||
|
|
|||
|
To get started, have a look at one of our [examples](example/):
|
|||
|
- [Basic error instrumentation](example/basic/main.go)
|
|||
|
- [Error and tracing for HTTP servers](example/http/main.go)
|
|||
|
|
|||
|
We also provide a [complete API reference](https://pkg.go.dev/github.com/getsentry/sentry-go).
|
|||
|
|
|||
|
For more detailed information about how to get the most out of `sentry-go`,
|
|||
|
checkout the official documentation:
|
|||
|
|
|||
|
- [Sentry Go SDK documentation](https://docs.sentry.io/platforms/go/)
|
|||
|
- Guides:
|
|||
|
- [net/http](https://docs.sentry.io/platforms/go/guides/http/)
|
|||
|
- [echo](https://docs.sentry.io/platforms/go/guides/echo/)
|
|||
|
- [fasthttp](https://docs.sentry.io/platforms/go/guides/fasthttp/)
|
|||
|
- [gin](https://docs.sentry.io/platforms/go/guides/gin/)
|
|||
|
- [iris](https://docs.sentry.io/platforms/go/guides/iris/)
|
|||
|
- [martini](https://docs.sentry.io/platforms/go/guides/martini/)
|
|||
|
- [negroni](https://docs.sentry.io/platforms/go/guides/negroni/)
|
|||
|
|
|||
|
## Resources
|
|||
|
|
|||
|
- [Bug Tracker](https://github.com/getsentry/sentry-go/issues)
|
|||
|
- [GitHub Project](https://github.com/getsentry/sentry-go)
|
|||
|
- [data:image/s3,"s3://crabby-images/e0a6f/e0a6fe614c824f83c77a4d7aede132fd1ff5d02b" alt="GoDoc"](https://godoc.org/github.com/getsentry/sentry-go)
|
|||
|
- [data:image/s3,"s3://crabby-images/ee7e3/ee7e33b27c2a4f930ea943468faebbf58fca217f" alt="go.dev"](https://pkg.go.dev/github.com/getsentry/sentry-go)
|
|||
|
- [data:image/s3,"s3://crabby-images/3119f/3119f5853aa0507d2080da5d609928d024494806" alt="Documentation"](https://docs.sentry.io/platforms/go/)
|
|||
|
- [data:image/s3,"s3://crabby-images/1bde6/1bde67955488f71bd8899743a4a95b8311a982c8" alt="Discussions"](https://github.com/getsentry/sentry-go/discussions)
|
|||
|
- [data:image/s3,"s3://crabby-images/04da8/04da8164d8764c4f952fc3b9d834ebe23c57ffd2" alt="Discord"](https://discord.gg/Ww9hbqr)
|
|||
|
- [data:image/s3,"s3://crabby-images/61b56/61b566a075b99c8e368b4ee914179569e8d8ddad" alt="Stack Overflow"](http://stackoverflow.com/questions/tagged/sentry)
|
|||
|
- [data:image/s3,"s3://crabby-images/c0c7d/c0c7d11aab21616c0bc90df45c65301ee51c3f1a" alt="Twitter Follow"](https://twitter.com/intent/follow?screen_name=getsentry)
|
|||
|
|
|||
|
## License
|
|||
|
|
|||
|
Licensed under
|
|||
|
[The 2-Clause BSD License](https://opensource.org/licenses/BSD-2-Clause), see
|
|||
|
[`LICENSE`](LICENSE).
|
|||
|
|
|||
|
## Community
|
|||
|
|
|||
|
Join Sentry's [`#go` channel on Discord](https://discord.gg/Ww9hbqr) to get
|
|||
|
involved and help us improve the SDK!
|