introduce
Sentry-go SDK Chinese Practice Guide
The installation
Sentry captures data by using the SDK at run time of the application.
With Go Modules, you don’t need to install any software to start using Sentry with the Go program. Import the SDK, and then the next time you build the program, Go Tool will automatically download the latest version of the SDK.
import (
"github.com/getsentry/sentry-go"
)
Copy the code
To use the latest version of the SDK without or without Go Modules, run:
go get github.com/getsentry/sentry-go
Copy the code
For more information on how to manage dependencies, see the Go documentation on Modules.
configuration
Configuration should occur early in the application lifecycle.
package main
import (
"log"
"time"
"github.com/getsentry/sentry-go"
)
func main(a) {
err := sentry.Init(sentry.ClientOptions{
// Set your DSN here or set the SENTRY_DSN environment variable.
Dsn: "https://[email protected]/0".// We can set environment and release here,
SENTRY_ENVIRONMENT and SENTRY_RELEASE environment variables can also be set.
Environment: "",
Release: "".// Allows SDK debug messages to be printed.
// Useful when getting started or trying to solve something.
Debug: true,})iferr ! =nil {
log.Fatalf("sentry.Init: %s", err)
}
Flush buffered events before program terminates.
// Set the timeout to the maximum duration the program can wait.
defer sentry.Flush(2 * time.Second)
}
Copy the code
validation
This code snippet contains an intentional error, so you can test everything immediately after setting it up:
package main
import (
"log"
"time"
"github.com/getsentry/sentry-go"
)
func main(a) {
err := sentry.Init(sentry.ClientOptions{
Dsn: "https://[email protected]/0",})iferr ! =nil {
log.Fatalf("sentry.Init: %s", err)
}
defer sentry.Flush(2 * time.Second)
sentry.CaptureMessage("It works!")}Copy the code
To view and resolve recorded errors, log in to sentry. IO (or your privately deployed Sentry) and open your project. Clicking on the error title opens a page where you can view the details and mark them as resolved.
Processing Panics
The way to catch unhandled emergencies (panics) in the Go SDK is through the Recover method. It can be used directly through the defer keyword or as part of the implementation.
usage
As shown below, when using Sentry directly, it recovers from the emergency and decides internally whether to use the CaptureException or CaptureMessage method based on the type of input received. Since the occurrence of the string Panic is not common, it is recommended to use the AttachStacktrace option during SDK initialization, which will also attempt to provide a useful stack trace for messages.
func(a) {
defer sentry.Recover()
// do all of the scary things here ^_^} ()Copy the code
By default, the Sentry Go SDK uses asynchronous transports, and in the following code example, the sentry.Flush method is used to explicitly wait for event delivery to complete. This is necessary because otherwise the program will not wait for the asynchronous HTTP call to return a response and will exit the process as soon as the end of main is reached. It is not required in a running Goroutine or when using HTTPSyncTransport (as you can see in the Transports section).
If you want to control the delivery of a single defer call, or perform other operations prior to capture, you must use the Recovery method directly on the Hub instance because it can accept err itself.
func(a) {
defer func(a) {
err := recover(a)iferr ! =nil {
sentry.CurrentHub().Recover(err)
sentry.Flush(time.Second * 5)}} ()// do all of the scary things here} ()Copy the code
Use the Context
In addition to the normal Recover method, another method that can be used in an emergency is RecoverWithContext. It allows you to pass an instance of context. context as the first argument. This gives us two additional capabilities.
The first is to extract the Hub instance from the context and use it instead of the global instance — this is used for each HTTP/Server package integration because it allows context separation to be performed. You can see it in action in our HTTP integration source code.
The second function is access to context. context itself inside the beforeSend method, which can be used to extract any additional information about what happened under Panic:
type contextKey int
const SomeContextKey = contextKey(1)
func main(a) {
sentrySyncTransport := sentry.NewHTTPSyncTransport()
sentrySyncTransport.Timeout = time.Second * 3
sentry.Init(sentry.ClientOptions{
Dsn: "https://[email protected]/0",
Transport: sentrySyncTransport,
BeforeSend: func(event *sentry.Event, hint *sentry.EventHint) *sentry.Event {
ifhint.Context ! =nil {
// hint.context.value (SomeContextKey) gives you the stored string, which you can now append to the event
}
return event
},
})
ctx := context.WithValue(context.Background(), SomeContextKey, "some details about your panic")
func(a) {
defer sentry.RecoverWithContext(ctx)
// do all of the scary things here(1)}}Copy the code
concurrent
Concurrent Go programs use Goroutines, a lightweight form of threading managed by the Go runtime. Because Goroutines run concurrently, each Goroutine must track its sentry-related data locally. Otherwise, Data Races introduce subtle errors into your program, with consequences ranging from obvious changes to unexpected crashes, or even worse, accidentally mixing together data stored in Scope. Learn more about this in the Scopes and Hubs section.
The easiest way to handle this is to create a new Hub for each Goroutine you start, but that requires you to rebind the current Client and handle the Scope yourself. This is why we provide a helper method called Clone. It is responsible for creating the hub, cloning the existing Scope, and reassigning it to the newly created instance along with the Client.
After cloning, the Hub is completely isolated and can be used safely in concurrent calls. However, instead of using methods that are exposed globally, you should call them directly on the Hub.
Here are two examples:
- Suggestions for
Hub
Make a safe deterministic call
// Example of __CORRECT__ use of scopes inside a Goroutine
// Use it correctly
go func(localHub *sentry.Hub) {
// as goroutine argument
localHub.ConfigureScope(func(scope *sentry.Scope) {
scope.SetTag("secretTag"."go#1")
})
localHub.CaptureMessage("Hello from Goroutine! # 1")
}(sentry.CurrentHub().Clone())
go func(a) {
// or created locally
localHub := sentry.CurrentHub().Clone()
localHub.ConfigureScope(func(scope *sentry.Scope) {
scope.SetTag("secretTag"."go#2")
})
localHub.CaptureMessage("Hello from Goroutine! # 2")
}()
Copy the code
- Stop in
Hub
A nondeterministic call that leaks information between threads
// Example of __INCORRECT__ use of scopes inside a Goroutine - DON'T USE IT!
// Incorrect usage
go func(a) {
sentry.ConfigureScope(func(scope *sentry.Scope) {
scope.SetTag("secretTag"."go#1")
})
sentry.CaptureMessage("Hello from Goroutine! # 1")
}()
go func(a) {
sentry.ConfigureScope(func(scope *sentry.Scope) {
scope.SetTag("secretTag"."go#2")
})
sentry.CaptureMessage("Hello from Goroutine! # 2")
}()
// at this point, both events can have tags like 'go#1' or 'go#2'. We'll never know.
Copy the code
Configuration items
- The basic options
Learn more about how to configure the SDK. These options are set when the SDK is first initialized and passed as objects to init().
- Releases & Health
Learn how to configure your SDK to tell Sentry your version.
- Transports
With Transports, you can change the way events are passed to Sentry.
- Environments
Learn how to configure your SDK to tell Sentry about your environment.
- Filter and sample events
Learn more about how to configure your SDK to filter and sample events reported to Sentry.
- Shutdown and Draining
If an application is unexpectedly shut down, take a closer look at the default behavior of our SDK.
The basic options
You can configure the SDK with a variety of options. These options are largely standardized in the SDK, but there are some differences to better fit platform features. Options are set when the SDK is first initialized.
The options are passed to the Init() method as an instance of sentry.clientOptions:
sentry.Init(sentry.ClientOptions{
Dsn: "https://[email protected]/0",
Debug: true,})Copy the code
// ClientOptions is used to configure SDK clients
type ClientOptions struct {
// The DSN to use. If DSN is not set, the client is effectively disabled.
Dsn string
// In debug mode, debug information is printed to stdout to help you understand what sentry is doing.
Debug bool
// Configure whether the SDK should generate a stack trace and attach it to a pure capture message call.
AttachStacktrace bool
// Sample rate of event submissions (0.0-1.0, default 1.0)
SampleRate float64
// List of regular expression strings used to match event messages, if applicable,
Error types and values are caught. If a match is found, the entire event is deleted.
IgnoreErrors []string
// Before sending the callback.
BeforeSend func(event *Event, hint *EventHint) *Event
// Add the callback before the breadcrumbs.
BeforeBreadcrumb func(breadcrumb *Breadcrumb, hint *BreadcrumbHint) *Breadcrumb
// The integration to be installed on the current client accepts the default integration
Integrations func([]Integration) []Integration
// IO.Writer implementation should be used with 'Debug' mode
DebugWriter io.Writer
/ / transport use
// This is an example of a structure that implements the 'Transport' interface.
// Default 'httpTransport' from 'transport.go'
Transport Transport
// The server name to be reported.
// The name of the server to report.
ServerName string
// The version sent with the event.
Release string
// Dist sent with the event.
Dist string
// The environment that is sent with the event.
Environment string
// The maximum number of crumbs.
MaxBreadcrumbs int
// Optional pointer to 'http.Client', which will be used with the default HTTPTransport.
// Using your own client will ignore the HTTPTransport, HTTPProxy, HTTPSProxy and CaCerts options.
HTTPClient *http.Client
// Optional pointer to 'http.Transport', which will be used with the default HTTPTransport.
// Using your own transport will make HTTPProxy, HTTPSProxy, and CaCerts options ignored.
HTTPTransport *http.Transport
// An optional HTTP proxy to use.
// This defaults to the 'http_proxy' environment variable.
// or 'https_proxy' (if present).
HTTPProxy string
// An optional HTTPS proxy to use.
// This defaults to the 'HTTPS_PROXY' environment variable
// or 'http_proxy' (if present).
HTTPSProxy string
// Optional CaCert to use.
// The default is' gocertifi.cacerts () '.
CaCerts *x509.CertPool
}
Copy the code
Providing an SSL Certificate
By default, TLS uses the host’s root CA setting. If you don’t have CA-certificates (which should be the preferred way to solve the problem of missing certificates) and want to use GoCertifi, you can provide pre-loaded certificate files as one of the options for the sentry.init call:
package main
import (
"log"
"github.com/certifi/gocertifi"
"github.com/getsentry/sentry-go"
)
sentryClientOptions := sentry.ClientOptions{
Dsn: "https://[email protected]/0",
}
rootCAs, err := gocertifi.CACerts()
iferr ! =nil {
log.Println("Could not load CA Certificates: %v\n", err)
} else {
sentryClientOptions.CaCerts = rootCAs
}
sentry.Init(sentryClientOptions)
Copy the code
Deleting the Default integration
The Sentry-Go SDK has few built-in integrations that can enhance events with other information or manage them in one way or another.
If you want to learn more about them, look directly at the source code.
However, in some cases, you may want to disable some of these features. To do this, you can use the Integrations configuration option and filter unwanted Integrations. Such as:
sentry.Init(sentry.ClientOptions{
Integrations: func(integrations []sentry.Integration) []sentry.Integration {
var filteredIntegrations []sentry.Integration
for _, integration := range integrations {
if integration.Name() == "ContextifyFrames" {
continue
}
filteredIntegrations = append(filteredIntegrations, integration)
}
return filteredIntegrations
},
})
Copy the code
Releases & Health
A distribution is the version of code that is deployed into the environment. When you provide Sentry with information about your distribution, you can:
- Identify issues and regressions introduced in the new release
- Predict which submission caused the problem and who might be responsible
- Resolve the problem by including the problem number in the commit message
- Receive email notifications after deploying code
Binding version
When configuring the client SDK, include the release ID (usually called “version”). This ID is usually git SHA or a custom version number.
Distribution names cannot:
- Contains newlines or Spaces
- Use forward slashes (“/”), backslashes (” \ “), and periods (“. ) or double period (“..” )
- More than 200 characters
Each organization’s version is global; They are prefixed with a specific item to make them easier to distinguish.
sentry.Init(sentry.ClientOptions{
Release: "[email protected]",})Copy the code
How you make the version available to your code is up to you. For example, you can use environment variables that you set during the build process.
This marks each event with a published value. We recommend that you tell Sentry a new version before deploying it, as this will unlock more features, as discussed in our documentation. If you don’t, Sentry will automatically create a Release entity in the system the first time it sees an event with that release ID.
After configuring the SDK, you can install the repository integration or manually provide your own commit metadata to Sentry. Please read our documentation on builds for more information on integration, associated commits, and telling Sentry when you deploy builds.
Transports
With Transports, you can change the way events are passed to Sentry.
The Sentry Go SDK itself provides two built-in transports. HTTPTransport, which is non-blocking, is used by default. And HTTPSyncTransport are blocked. Each transport provides slightly different configuration options.
usage
To configure Transport, provide a sentry.Transport instance to ClientOptions
package main
import (
"time"
"github.com/getsentry/sentry-go"
)
func main(a) {
sentrySyncTransport := sentry.NewHTTPSyncTransport()
sentrySyncTransport.Timeout = time.Second * 3
sentry.Init(sentry.ClientOptions{
Dsn: "https://[email protected]/0",
Transport: sentrySyncTransport,
})
}
Copy the code
Each mode of transportation provides its own factory function. NewHTTPTransport and NewHTTPSyncTransport.
options
HTTPTransport
// HTTPTransport is the default implementation of the 'Transport' interface used by 'Client'.
type HTTPTransport struct {
// Transfer buffer size. The default value is 30.
BufferSize int
// The HTTP client request timed out. The default value is 30 seconds.
Timeout time.Duration
}
Copy the code
HTTPSyncTransport
// HTTPSyncTransport is an implementation of the 'Transport' interface, which blocks after each captured event.
type HTTPSyncTransport struct {
// The HTTP client request timed out. The default value is 30 seconds.
Timeout time.Duration
}
Copy the code
Environments
Sentry automatically creates the environment when it receives an event with an environment label. The environment is case sensitive. The environment name cannot contain newlines, Spaces, or slashes, the string “None”, or exceed 64 characters. You cannot delete environments, but you can hide them.
sentry.Init(sentry.ClientOptions{
Environment: "production",})Copy the code
In sentry. IO’s problem details page, the environment helps you better filter issues, releases, and user feedback. You can learn more about using the environment in our documentation.
Filter and sample events
Adding Sentry to your application will give you a lot of valuable information about errors and performance that you didn’t have access to before. And a lot of the information is good – as long as it’s the right information and in a reasonable amount.
The Sentry SDK has several configuration options to help you control this, allowing you to filter out the events you don’t want and pick a representative example from the ones you do want.
Note: Sentry UI also provides a way to filter events using inbound filters. However, we recommend that you filter at the client level, because it eliminates the overhead of sending events that you don’t really need.
Filtering error events
Configure your SDK to filter error events by using the beforeSend callback method and configuring, enabling, or disabling the integration.
Using beforeSend
All Sentry SDKS support the beforeSend callback method. BeforeSend is called immediately before the event is sent to the server, so it is the final place where you can edit its data. It receives the event object as a parameter, so you can use this parameter to modify the event data or delete it completely (by returning NULL) based on the custom logic and data available on the event.
In Go, functions can be used to modify an event or return an entirely new event. If nil is returned, the SDK discards the event.
sentry.Init(sentry.ClientOptions{
BeforeSend: func(event *sentry.Event, hint *sentry.EventHint) *sentry.Event {
// Modify the event here
event.User.Email = "" // Don't send user's email address
return event
},
})
Copy the code
Also note that breadcrumbs can be filtered, as discussed in the breadcrumb document.
Event Hints
The before-send callback passes both the Event and the second parameter hint, which contains one or more Hints.
Typically, a HINT saves the original exception so that it can extract additional data or affect the grouping. In this example, if some type of exception is caught, the fingerprint is forced to a common value:
sentry.Init(sentry.ClientOptions{
BeforeSend: func(event *sentry.Event, hint *sentry.EventHint) *sentry.Event {
if ex, ok := hint.OriginalException.(DatabaseConnectionError); ok {
event.Fingerprint = []string{"database-connection-error"}}return event
},
})
Copy the code
For information about available prompts, see EventHint Implementation.
When an SDK creates an event or breadcrumb for a transport, the transport is usually created from some source object. For example, error events are typically created from logging or exception instances. For better customization, the SDK sends these objects to specific callbacks (beforeSend, beforeBreadcrumb, or the event handler system in the SDK).
Use the Hints
There are two places to offer Hints:
beforeSend / beforeBreadcrumb
eventProcessors
Event and breadCrumb Hints are objects that contain various information for combining events or breadcrumb. Typically, Hints saves raw exceptions so you can extract additional data or influence groups.
For events such as Event_id, originalException, syntheticException(internally used to generate a cleaner stack trace), and any other arbitrary data attached.
For crumbs, the use of Hints is implementation dependent. For XHR requests, the hint contains the XHR object itself; For user interaction, hints contain DOM elements, event names, and so on.
In this example, if some type of exception is caught, the fingerprint is forced to a common value:
Hints for Events
originalException
The original exception that causes the Sentry SDK to create the event. This is useful for changing the way the Sentry SDK groups events or extracting additional information.
syntheticException
When a string or non-error object is thrown, Sentry creates a synthetic exception so that you can get a basic stack trace. The exception is stored here for further data extraction.
Hints for Breadcrumbs
event
For a breadcrumb created from a browser event, the Sentry SDK typically provides the event as a hint to the breadcrumb. For example, this can be used to extract data from the target DOM element into the breadcrumb.
level / input
For intercepting the breadcrumbs created from the console log. This preserves the raw input data for the original console log level and logging functionality.
response / input
Breadcrumbs used to create from HTTP requests. It holds the response object (from the FETCH API) and the input parameters of the FETCH function.
request / response / event
Breadcrumbs used to create from HTTP requests. It contains request and response objects (from the node HTTP API) and node events (response or error).
xhr
For breadcrumbs created via HTTP requests through the older VERSION of the XMLHttpRequest API. This will preserve the original XHR object.
Sampling error event
To send a representative sample of errors to Sentry, set the SampleRate option in your SDK configuration to a number between 0(sending 0% errors) and 1(sending 100% errors). This is a static rate, and it also applies to all errors. For example, sampling 25% of errors:
Note: Error sampling rate is not dynamic; Changing it requires redeployment. In addition, setting the SDK sample rate limits visibility to the event source. Setting a rate limit for your project (reducing events only when volume is high) may be more appropriate for your needs.
Shutdown and Draining
The default behavior of most SDKS is to send events asynchronously in the background over the network. This means that some events may be lost if the application is unexpectedly shut down. The SDK provides a mechanism to handle this situation.
To avoid unexpected deletion events when the program terminates, arrange for sentry.Flush to be called, usually using defer.
If you use multiple clients, schedule each corresponding client refresh.
Flush waits until any buffered event is sent to the Sentry server until it blocks for at most a given timeout. If timeout occurs, false is returned. In this case, some events may not have been sent yet.
func main(a) {
// err := sentry.Init(...)
defer sentry.Flush(2 * time.Second)
sentry.CaptureMessage("my message")}Copy the code
Serverless
Source Context
The Sentry-Go SDK comes with support for the Serverless solution. However, to use the source context properly, you need to bundle the source with the binary itself.
For example, when using AWS Lambda and given this tree structure:
.├ ─ bin │ ├─ ├─ New Year │ ├─ New Year │ ├─ New Year │ ├─ New Year │functions├─ im-press, im-press, im-press, im-press, im-press, im-press, im-press, im-press, im-press, im-press, im-press ├ ─ ─ foo go │ └ ─ ─ bar. Go ├ ─ ─ util │ ├ ─ ─ baz. Go │ └ ─ ─ qux. GoCopy the code
You can build one of the binaries and bundle it with the necessary source files using the following command:
GOOS=linux go build -o bin/upload-image functions/upload-image/main.go && zip -r handler.zip bin/upload-image functions/upload-image/ helper/ util/
Copy the code
The only requirement is that you find the source code on the deployed machine. The SDK does everything else automatically.
Events Delivery
Most, if not all, serverless solutions do not wait for a network response before shutting down the process. Therefore, we need to ensure that events are passed to Sentry’s server.
You can achieve this dual purpose using the sentry.Flush method or by swapping the transport to HTTPSyncTransport.
usage
Sentry’s SDK hooks into your runtime environment and automatically reports errors, exceptions, and rejections.
Key terms:
- An event is an instance of sending data to a Sentry. Typically, this data is an error or exception.
- One problem is a similar set of events.
- The reporting of events is called capture. When an event is captured, it is sent to Sentry.
The most common form of catching is catching errors. What can be caught as an error varies from platform to platform. In general, if you have something that looks like an exception, you can catch it. For some SDKS, you can also omit the capture_exception argument, and Sentry will attempt to catch the current exception. Manually reporting errors or messages to Sentry is also useful.
In addition to capturing, you can also record the breadcrumbs that led to the event. Breadcrumbs are different from events: they do not create events in Sentry, but are buffered until the next event is sent. Learn more about breadcrumbs in our breadcrumbs document.
Capture the error
To catch events in Go, any structure that implements the Error interface can be passed to CaptureException(). If we use a third-party library instead of the native Errors package, we will try to extract the stack trace.
The SDK is fully compatible with (but not limited to):
- github.com/pkg/errors
- github.com/go-errors/errors
- github.com/pingcap/errors
Let us know if there are error packages that are not available immediately!
f, err := os.Open("filename.ext")
iferr ! =nil {
sentry.CaptureException(err)
}
Copy the code
Capture the message
Another common operation is to catch a pure message. A message is a text message that should be sent to Sentry. Typically, messages are not sent, but for some teams they can be useful.
sentry.CaptureMessage("Something went wrong")
Copy the code
By default, Sentry’s Go SDK uses asynchronous transports. This means that calls to CaptureException, CaptureEvent, and CaptureMessage can return without waiting for network action. Instead, events are buffered in a background Goroutine and sent over the network. Call sentry.Flush to wait for the event to pass, and then the program terminates. You can change the default behavior using other transport methods, such as HTTPSyncTransport. More details are available in the Transports section.
Set the level
Levels – similar to log levels – are usually added by default based on the integration. You can also override it in an event.
sentry.ConfigureScope(func(scope *sentry.Scope) {
scope.SetLevel(sentry.LevelWarning)
})
Copy the code
Migration guide
How do I transfer from Raven-Go to Sentry-Go
The installation
raven-go
go get github.com/getsentry/raven-go
Copy the code
sentry-go
go get github.com/getsentry/sentry-go
Copy the code
configuration
raven-go
import "github.com/getsentry/raven-go"
func main(a) {
raven.SetDSN("https://[email protected]/0")}Copy the code
sentry-go
import (
"fmt"
"github.com/getsentry/sentry-go"
)
func main(a) {
err := sentry.Init(sentry.ClientOptions{
Dsn: "https://[email protected]/0",})iferr ! =nil {
fmt.Printf("Sentry initialization failed: %v\n", err)
}
}
Copy the code
raven-go
SetDSN()
SetDefaultLoggerName()
SetDebug()
SetEnvironment()
SetRelease()
SetSampleRate()
SetIgnoreErrors()
SetIncludePaths()
Copy the code
sentry-go
sentry.Init(sentry.ClientOptions{
Dsn: "https://[email protected]/0",
DebugWriter: os.Stderr,
Debug: true,
Environment: "environment",
Release: "release",
SampleRate: 0.5.// IgnoreErrors: TBD,
// IncludePaths: TBD
})
Copy the code
Available options: See the Configuration section.
Providing an SSL Certificate
By default, TLS uses the host’s root CA setting. If you don’t have CA-certificates (which should be the preferred way to solve the problem of missing certificates) and want to use GoCertifi, you can provide pre-loaded certificate files as one of the options for the sentry.init call:
package main
import (
"log"
"github.com/certifi/gocertifi"
"github.com/getsentry/sentry-go"
)
sentryClientOptions := sentry.ClientOptions{
Dsn: "https://[email protected]/0",
}
rootCAs, err := gocertifi.CACerts()
iferr ! = nil { log.Println("Couldn't load CA Certificates: %v\n", err)
} else {
sentryClientOptions.CaCerts = rootCAs
}
sentry.Init(sentryClientOptions)
Copy the code
usage
Capturing Errors
raven-go
f, err := os.Open("filename.ext")
iferr ! =nil {
raven.CaptureError(err, nil)}Copy the code
sentry-go
f, err := os.Open("filename.ext")
iferr ! =nil {
sentry.CaptureException(err)
}
Copy the code
Capturing Panics
raven-go
raven.CapturePanic(func(a) {
// do all of the scary things here
}, nil)
Copy the code
sentry-go
func(a) {
defer sentry.Recover()
// do all of the scary things here} ()Copy the code
Capturing Messages
raven-go
raven.CaptureMessage("Something bad happened and I would like to know about that")
Copy the code
sentry-go
sentry.CaptureMessage("Something bad happened and I would like to know about that")
Copy the code
Capturing Events
raven-go
packet := &raven.Packet{
Message: "Hand-crafted event",
Extra: &raven.Extra{
"runtime.Version": runtime.Version(),
"runtime.NumCPU": runtime.NumCPU(),
},
}
raven.Capture(packet)
Copy the code
sentry-go
event := sentry.NewEvent()
event.Message = "Hand-crafted event"
event.Extra["runtime.Version"] = runtime.Version()
event.Extra["runtime.NumCPU"] = runtime.NumCPU()
sentry.CaptureEvent(event)
Copy the code
Additional Data
See Context section.
Event Sampling
raven-go
raven.SetSampleRate(0.25)
Copy the code
sentry-go
sentry.Init(sentry.ClientOptions{
SampleRate: 0.25,})Copy the code
Awaiting the response (not recommended)
raven.CaptureMessageAndWait("Something bad happened and I would like to know about that")
Copy the code
sentry-go
sentry.CaptureMessage("Something bad happened and I would like to know about that")
if sentry.Flush(time.Second * 2) {
// event delivered
} else {
// timeout reached
}
Copy the code
Context
Per-event
raven-go
raven.CaptureError(err, map[string]string{"browser": "Firefox"}, &raven.Http{
Method: "GET",
URL: "https://example.com/raven-go"
})
Copy the code
sentry-go
sentry.WithScope(func(scope *sentry.Scope) {
scope.SetTag("browser"."Firefox")
scope.SetContext("Request".map[string]string{
"Method": "GET"."URL": "https://example.com/raven-go",
})
sentry.CaptureException(err)
})
Copy the code
Globally
SetHttpContext
raven-go
raven.SetHttpContext(&raven.Http{
Method: "GET",
URL: "https://example.com/raven-go",})Copy the code
sentry-go
sentry.ConfigureScope(func(scope *sentry.Scope) {
scope.SetContext("Request".map[string]string{
"Method": "GET"."URL": "https://example.com/raven-go",})})Copy the code
SetTagsContext
raven-go
t := map[string]string{"day": "Friday"."sport": "Weightlifting"}
raven.SetTagsContext(map[string]string{"day": "Friday"."sport": "Weightlifting"})
Copy the code
sentry-go
sentry.ConfigureScope(func(scope *sentry.Scope) {
scope.SetTags(map[string]string{"day": "Friday"."sport": "Weightlifting"})})Copy the code
SetUserContext
raven-go
raven.SetUserContext(&raven.User{
ID: "1337",
Username: "kamilogorek",
Email: "[email protected]",
IP: "127.0.0.1",})Copy the code
sentry-go
sentry.ConfigureScope(func(scope *sentry.Scope) {
scope.SetUser(sentry.User{
ID: "1337",
Username: "kamilogorek",
Email: "[email protected]",
IPAddress: "127.0.0.1",})})Copy the code
ClearContext
raven-go
raven.ClearContext()
Copy the code
sentry-go
sentry.ConfigureScope(func(scope *sentry.Scope) {
scope.Clear()
})
Copy the code
WrapWithExtra
raven-go
path := "filename.ext"
f, err := os.Open(path)
iferr ! =nil {
err = raven.WrapWithExtra(err, map[string]string{"path": path, "cwd": os.Getwd()})
raven.CaptureError(err, nil)}Copy the code
sentry-go
// use `sentry.WithScope`, see "Context / Per-event Section"
path := "filename.ext"
f, err := os.Open(path)
iferr ! =nil {
sentry.WithScope(func(scope *sentry.Scope) {
scope.SetExtras(map[string]interface{} {"path": path, "cwd": os.Getwd()})
sentry.CaptureException(err)
})
}
Copy the code
Integrations
net/http
raven-go
mux := http.NewServeMux
http.Handle("/", raven.Recoverer(mux))
// or
func root(w http.ResponseWriter, r *http.Request) {}
http.HandleFunc("/", raven.RecoveryHandler(root))
Copy the code
sentry-go
go get github.com/getsentry/sentry-go/http
Copy the code
import sentryhttp "github.com/getsentry/sentry-go/http"
sentryHandler := sentryhttp.New(sentryhttp.Options{
Repanic: false,
WaitForDelivery: true,
})
mux := http.NewServeMux
http.Handle("/", sentryHandler.Handle(mux))
// or
func root(w http.ResponseWriter, r *http.Request) {}
http.HandleFunc("/", sentryHandler.HandleFunc(root))
Copy the code