request-id
Request ID
原文:https://echo.labstack.com/docs/middleware/request-id
Request ID middleware generates a unique id for a request.
Usage
1
| e.Use(middleware.RequestID())
|
Custom Configuration
Usage
1
2
3
4
5
| e.Use(middleware.RequestIDWithConfig(middleware.RequestIDConfig{
Generator: func() string {
return customGenerator()
},
}))
|
Configuration
1
2
3
4
5
6
7
8
9
10
11
| RequestIDConfig struct {
// Skipper defines a function to skip middleware.
Skipper Skipper
// Generator defines a function to generate an ID.
// Optional. Default value random.String(32).
Generator func() string
// TargetHeader defines what header to look for to populate the id
TargetHeader string
}
|
Default Configuration
1
2
3
4
5
| DefaultRequestIDConfig = RequestIDConfig{
Skipper: DefaultSkipper,
Generator: generator,
TargetHeader: echo.HeaderXRequestID,
}
|
Set ID
You can set the id from the requester with the X-Request-ID
-Header
Request
1
| curl -H "X-Request-ID: 3" --compressed -v "http://localhost:1323/?my=param"
|
Log
1
| {"time":"2017-11-13T20:26:28.6438003+01:00","id":"3","remote_ip":"::1","host":"localhost:1323","method":"GET","uri":"/?my=param","my":"param","status":200, "latency":0,"latency_human":"0s","bytes_in":0,"bytes_out":13}
|