Skip to content

Commit

Permalink
ObservedQuery,ObservedBatch: pass the address of the node (apache#1101)
Browse files Browse the repository at this point in the history
We can now have the address of the cassandra node which made the
query/batch.
  • Loading branch information
zllak authored and Zariel committed Jun 2, 2018
1 parent 1730c76 commit beb14e3
Show file tree
Hide file tree
Showing 2 changed files with 13 additions and 5 deletions.
4 changes: 2 additions & 2 deletions query_executor.go
Original file line number Diff line number Diff line change
Expand Up @@ -6,7 +6,7 @@ import (

type ExecutableQuery interface {
execute(conn *Conn) *Iter
attempt(keyspace string, end, start time.Time, iter *Iter)
attempt(keyspace string, end, start time.Time, iter *Iter, address string)
retryPolicy() RetryPolicy
GetRoutingKey() ([]byte, error)
Keyspace() string
Expand All @@ -23,7 +23,7 @@ func (q *queryExecutor) attemptQuery(qry ExecutableQuery, conn *Conn) *Iter {
iter := qry.execute(conn)
end := time.Now()

qry.attempt(q.pool.keyspace, end, start, iter)
qry.attempt(q.pool.keyspace, end, start, iter, conn.Address())

return iter
}
Expand Down
14 changes: 11 additions & 3 deletions session.go
Original file line number Diff line number Diff line change
Expand Up @@ -807,7 +807,7 @@ func (q *Query) execute(conn *Conn) *Iter {
return conn.executeQuery(q)
}

func (q *Query) attempt(keyspace string, end, start time.Time, iter *Iter) {
func (q *Query) attempt(keyspace string, end, start time.Time, iter *Iter, address string) {
q.attempts++
q.totalLatency += end.Sub(start).Nanoseconds()
// TODO: track latencies per host and things as well instead of just total
Expand All @@ -819,6 +819,7 @@ func (q *Query) attempt(keyspace string, end, start time.Time, iter *Iter) {
Start: start,
End: end,
Rows: iter.numRows,
Host: address,
Err: iter.err,
})
}
Expand Down Expand Up @@ -1523,7 +1524,7 @@ func (b *Batch) WithTimestamp(timestamp int64) *Batch {
return b
}

func (b *Batch) attempt(keyspace string, end, start time.Time, iter *Iter) {
func (b *Batch) attempt(keyspace string, end, start time.Time, iter *Iter, address string) {
b.attempts++
b.totalLatency += end.Sub(start).Nanoseconds()
// TODO: track latencies per host and things as well instead of just total
Expand All @@ -1543,7 +1544,8 @@ func (b *Batch) attempt(keyspace string, end, start time.Time, iter *Iter) {
Start: start,
End: end,
// Rows not used in batch observations // TODO - might be able to support it when using BatchCAS
Err: iter.err,
Host: address,
Err: iter.err,
})
}

Expand Down Expand Up @@ -1692,6 +1694,9 @@ type ObservedQuery struct {
// Rows is not used in batch queries and remains at the default value
Rows int

// Host is the informations about the host that performed the query
Host string

// Err is the error in the query.
// It only tracks network errors or errors of bad cassandra syntax, in particular selects with no match return nil error
Err error
Expand All @@ -1714,6 +1719,9 @@ type ObservedBatch struct {
Start time.Time // time immediately before the batch query was called
End time.Time // time immediately after the batch query returned

// Host is the informations about the host that performed the batch
Host string

// Err is the error in the batch query.
// It only tracks network errors or errors of bad cassandra syntax, in particular selects with no match return nil error
Err error
Expand Down

0 comments on commit beb14e3

Please sign in to comment.