Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
C
caddy
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
Łukasz Nowak
caddy
Commits
8bdd13b5
Commit
8bdd13b5
authored
Mar 22, 2018
by
Matthew Holt
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
telemetry: Honor the server's request to toggle certain metrics
parent
52316952
Changes
2
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
45 additions
and
6 deletions
+45
-6
telemetry/collection.go
telemetry/collection.go
+15
-6
telemetry/telemetry.go
telemetry/telemetry.go
+30
-0
No files found.
telemetry/collection.go
View file @
8bdd13b5
...
@@ -104,7 +104,7 @@ func Reset() {
...
@@ -104,7 +104,7 @@ func Reset() {
// go keyword after the call to SendHello so it
// go keyword after the call to SendHello so it
// doesn't block crucial code.
// doesn't block crucial code.
func
Set
(
key
string
,
val
interface
{})
{
func
Set
(
key
string
,
val
interface
{})
{
if
!
enabled
{
if
!
enabled
||
isDisabled
(
key
)
{
return
return
}
}
bufferMu
.
Lock
()
bufferMu
.
Lock
()
...
@@ -123,10 +123,8 @@ func Set(key string, val interface{}) {
...
@@ -123,10 +123,8 @@ func Set(key string, val interface{}) {
// If key is new, a new list will be created.
// If key is new, a new list will be created.
// If key maps to a type that is not a list,
// If key maps to a type that is not a list,
// a panic is logged, and this is a no-op.
// a panic is logged, and this is a no-op.
//
// TODO: is this function needed/useful?
func
Append
(
key
string
,
value
interface
{})
{
func
Append
(
key
string
,
value
interface
{})
{
if
!
enabled
{
if
!
enabled
||
isDisabled
(
key
)
{
return
return
}
}
bufferMu
.
Lock
()
bufferMu
.
Lock
()
...
@@ -161,7 +159,7 @@ func Append(key string, value interface{}) {
...
@@ -161,7 +159,7 @@ func Append(key string, value interface{}) {
// that is not a counting set, a panic is logged,
// that is not a counting set, a panic is logged,
// and this is a no-op.
// and this is a no-op.
func
AppendUnique
(
key
string
,
value
interface
{})
{
func
AppendUnique
(
key
string
,
value
interface
{})
{
if
!
enabled
{
if
!
enabled
||
isDisabled
(
key
)
{
return
return
}
}
bufferMu
.
Lock
()
bufferMu
.
Lock
()
...
@@ -204,7 +202,7 @@ func Increment(key string) {
...
@@ -204,7 +202,7 @@ func Increment(key string) {
// atomicAdd adds amount (negative to subtract)
// atomicAdd adds amount (negative to subtract)
// to key.
// to key.
func
atomicAdd
(
key
string
,
amount
int
)
{
func
atomicAdd
(
key
string
,
amount
int
)
{
if
!
enabled
{
if
!
enabled
||
isDisabled
(
key
)
{
return
return
}
}
bufferMu
.
Lock
()
bufferMu
.
Lock
()
...
@@ -225,3 +223,14 @@ func atomicAdd(key string, amount int) {
...
@@ -225,3 +223,14 @@ func atomicAdd(key string, amount int) {
buffer
[
key
]
=
intVal
+
amount
buffer
[
key
]
=
intVal
+
amount
bufferMu
.
Unlock
()
bufferMu
.
Unlock
()
}
}
// isDisabled returns whether key is
// a disabled metric key. ALL collection
// functions should call this and not
// save the value if this returns true.
func
isDisabled
(
key
string
)
bool
{
disabledMetricsMu
.
RLock
()
_
,
ok
:=
disabledMetrics
[
key
]
disabledMetricsMu
.
RUnlock
()
return
ok
}
telemetry/telemetry.go
View file @
8bdd13b5
...
@@ -155,6 +155,18 @@ func emit(final bool) error {
...
@@ -155,6 +155,18 @@ func emit(final bool) error {
continue
continue
}
}
// update the list of enabled/disabled keys, if any
for
_
,
key
:=
range
reply
.
EnableKeys
{
disabledMetricsMu
.
Lock
()
delete
(
disabledMetrics
,
key
)
disabledMetricsMu
.
Unlock
()
}
for
_
,
key
:=
range
reply
.
DisableKeys
{
disabledMetricsMu
.
Lock
()
disabledMetrics
[
key
]
=
struct
{}{}
disabledMetricsMu
.
Unlock
()
}
// make sure we didn't send the update too soon; if so,
// make sure we didn't send the update too soon; if so,
// just wait and try again -- this is a special case of
// just wait and try again -- this is a special case of
// error that we handle differently, as you can see
// error that we handle differently, as you can see
...
@@ -259,6 +271,18 @@ type Response struct {
...
@@ -259,6 +271,18 @@ type Response struct {
// Error will be populated with an error message, if any.
// Error will be populated with an error message, if any.
// This field should be empty if the status code is < 400.
// This field should be empty if the status code is < 400.
Error
string
`json:"error,omitempty"`
Error
string
`json:"error,omitempty"`
// DisableKeys will contain a list of keys/metrics that
// should NOT be sent until further notice. The client
// must NOT store these items in its buffer or send them
// to the telemetry server while they are disabled. If
// this list and EnableKeys have the same value (which is
// not supposed to happen), this field should dominate.
DisableKeys
[]
string
`json:"disable_keys,omitempty"`
// EnableKeys will contain a list of keys/metrics that
// MAY be sent until further notice.
EnableKeys
[]
string
`json:"enable_keys,omitempty"`
}
}
// Payload is the data that gets sent to the telemetry server.
// Payload is the data that gets sent to the telemetry server.
...
@@ -335,6 +359,12 @@ var (
...
@@ -335,6 +359,12 @@ var (
updateTimer
*
time
.
Timer
updateTimer
*
time
.
Timer
updateTimerMu
sync
.
Mutex
updateTimerMu
sync
.
Mutex
// disabledMetrics is a list of metric keys
// that should NOT be saved to the buffer
// or sent to the telemetry server.
disabledMetrics
=
make
(
map
[
string
]
struct
{})
disabledMetricsMu
sync
.
RWMutex
// instanceUUID is the ID of the current instance.
// instanceUUID is the ID of the current instance.
// This MUST be set to emit telemetry.
// This MUST be set to emit telemetry.
// This MUST NOT be openly exposed to clients, for privacy.
// This MUST NOT be openly exposed to clients, for privacy.
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment