Comments (4)
Hi @ytkang
This library does not have instrumentation specific to gorilla websocket. Nonetheless, you can use this library to monitor your application: The API is designed to be flexible enough to instrument anything.
If you post a snippet example of how you are using gorilla websocket I would be happy to provide instrumentation direction.
from go-agent.
@willnewrelic
I used StartTransaction function for each request.
This is an example.
func readPump() {
for {
err := ReadLine(Conn)
if err != nil {
break
}
}
}
func ReadLine(conn *websocket.Conn) (err error) {
var r io.Reader
err = nil
_, r, err = conn.NextReader()
if err != nil {
fmt.Println("reader error ", err.Error())
return err
}
nr := bufio.NewReader(r)
for err == nil {
message, readErr := nr.ReadSlice('\n')
err = readErr
if message != nil {
processMessage(message)
}
}
if err == io.EOF {
err = nil
}
return err
}
func processMessage(message []byte) {
req := Request{}
err := req.UnmarshalJSON(message)
if err == nil {
var txn newrelic.Transaction = nil
if NewRelicApp != nil {
txn = NewRelicApp.StartTransaction(req.Path, nil, nil)
defer txn.End()
}
f := getHandler(req.Path)
if f != nil{
f(req.Path, message, c, txn)
}
}
}
from go-agent.
Hi @ytkang
That code looks reasonable to me! You might want to create the transaction in the readPump
for loop so that you can time all the time spent in ReadLine
.
If you have more questions about instrumentation, please don't hesitate to open a support ticket.
from go-agent.
@willnewrelic yes, you're right. but I needed to check time for each line. It will be case by case.
from go-agent.
Related Issues (20)
- Remove fasthttp dependency from main module HOT 2
- Update google.golang.org/grpc from 1.54.0 to 1.56.3 HOT 2
- transaction.go reqBody(req *http.Request) turn nil body into non Nil body for request.Body == http.NoBody HOT 1
- Add support to CopyFrom method in pgx integration HOT 1
- fmt.Stringer support for user attributes (especially for SQL query parameters)
- UNKNOWN log levels when using the native log package HOT 2
- `.Ignore()` not ignoring transaction (go-agent + nrgin) HOT 6
- Integration for gqlgen HOT 2
- nrpgx5 data-race HOT 5
- Changelog Go agent EOL Policy link is broken HOT 1
- agent with nrzap is not forwarding logs to newrelic HOT 3
- WrapBackgroundCore background logger is not sending logs to new relic but transaction logger is HOT 12
- zap logger.With log message properties are not sent to new relic HOT 4
- Attributes are not forwarded to NewRelic for logs HOT 16
- go agent , but not see span, please help me ,thanks HOT 3
- Specify service version during initial newrelic configuration HOT 6
- Possible memory leak in Go agent HOT 11
- How to use AWS Lambda Web Adapter in golang app
- uber/zap WithField(...) not showing up in NR APM logs HOT 2
- potential bug in newAppRun HOT 2
Recommend Projects
-
React
A declarative, efficient, and flexible JavaScript library for building user interfaces.
-
Vue.js
🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.
-
Typescript
TypeScript is a superset of JavaScript that compiles to clean JavaScript output.
-
TensorFlow
An Open Source Machine Learning Framework for Everyone
-
Django
The Web framework for perfectionists with deadlines.
-
Laravel
A PHP framework for web artisans
-
D3
Bring data to life with SVG, Canvas and HTML. 📊📈🎉
-
Recommend Topics
-
javascript
JavaScript (JS) is a lightweight interpreted programming language with first-class functions.
-
web
Some thing interesting about web. New door for the world.
-
server
A server is a program made to process requests and deliver data to clients.
-
Machine learning
Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.
-
Visualization
Some thing interesting about visualization, use data art
-
Game
Some thing interesting about game, make everyone happy.
Recommend Org
-
Facebook
We are working to build community through open source technology. NB: members must have two-factor auth.
-
Microsoft
Open source projects and samples from Microsoft.
-
Google
Google ❤️ Open Source for everyone.
-
Alibaba
Alibaba Open Source for everyone
-
D3
Data-Driven Documents codes.
-
Tencent
China tencent open source team.
from go-agent.