Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Add Native-Specific Metrics to Prebid Server #930

Merged
merged 19 commits into from
Jul 18, 2019
Merged
Show file tree
Hide file tree
Changes from 12 commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
10 changes: 8 additions & 2 deletions endpoints/auction.go
Original file line number Diff line number Diff line change
Expand Up @@ -93,6 +93,12 @@ func (a *auction) auction(w http.ResponseWriter, r *http.Request, _ httprouter.P
CookieFlag: pbsmetrics.CookieFlagUnknown,
RequestStatus: pbsmetrics.RequestStatusOK,
}
impLabels := pbsmetrics.ImpLabels{
BannerImps: false,
VideoImps: false,
AudioImps: false,
NativeImps: false,
}
if ua := user_agent.New(r.Header.Get("User-Agent")); ua != nil {
name, _ := ua.Browser()
if name == "Safari" {
Expand All @@ -104,11 +110,11 @@ func (a *auction) auction(w http.ResponseWriter, r *http.Request, _ httprouter.P
defer func() {
if req == nil {
a.metricsEngine.RecordRequest(labels)
a.metricsEngine.RecordImps(labels, 0)
a.metricsEngine.RecordImps(impLabels)
} else {
// handles the case that ParsePBSRequest returns an error, so req.Start is not defined
a.metricsEngine.RecordRequest(labels)
a.metricsEngine.RecordImps(labels, len(req.AdUnits))
a.metricsEngine.RecordImps(impLabels)
a.metricsEngine.RecordRequestTime(labels, time.Since(req.Start))
}
}()
Expand Down
8 changes: 7 additions & 1 deletion endpoints/openrtb2/amp_auction.go
Original file line number Diff line number Diff line change
Expand Up @@ -96,9 +96,15 @@ func (deps *endpointDeps) AmpAuction(w http.ResponseWriter, r *http.Request, _ h
CookieFlag: pbsmetrics.CookieFlagUnknown,
RequestStatus: pbsmetrics.RequestStatusOK,
}
impLabels := pbsmetrics.ImpLabels{
BannerImps: false,
VideoImps: false,
AudioImps: false,
NativeImps: false,
}
defer func() {
deps.metricsEngine.RecordRequest(labels)
deps.metricsEngine.RecordImps(labels, 1)
deps.metricsEngine.RecordImps(impLabels)
deps.metricsEngine.RecordRequestTime(labels, time.Since(start))
deps.analytics.LogAmpObject(&ao)
}()
Expand Down
10 changes: 7 additions & 3 deletions endpoints/openrtb2/auction.go
Original file line number Diff line number Diff line change
Expand Up @@ -94,10 +94,15 @@ func (deps *endpointDeps) Auction(w http.ResponseWriter, r *http.Request, _ http
CookieFlag: pbsmetrics.CookieFlagUnknown,
RequestStatus: pbsmetrics.RequestStatusOK,
}
numImps := 0
impLabels := pbsmetrics.ImpLabels{
BannerImps: false,
VideoImps: false,
AudioImps: false,
NativeImps: false,
}
defer func() {
deps.metricsEngine.RecordRequest(labels)
deps.metricsEngine.RecordImps(labels, numImps)
deps.metricsEngine.RecordImps(impLabels)
deps.metricsEngine.RecordRequestTime(labels, time.Since(start))
deps.analytics.LogAuctionObject(&ao)
}()
Expand Down Expand Up @@ -144,7 +149,6 @@ func (deps *endpointDeps) Auction(w http.ResponseWriter, r *http.Request, _ http
}
}

numImps = len(req.Imp)
response, err := deps.ex.HoldAuction(ctx, req, usersyncs, labels, &deps.categories)
ao.Request = req
ao.Response = response
Expand Down
11 changes: 7 additions & 4 deletions endpoints/openrtb2/video_auction.go
Original file line number Diff line number Diff line change
Expand Up @@ -79,10 +79,15 @@ func (deps *endpointDeps) VideoAuctionEndpoint(w http.ResponseWriter, r *http.Re
CookieFlag: pbsmetrics.CookieFlagUnknown,
RequestStatus: pbsmetrics.RequestStatusOK,
}
numImps := 0
impLabels := pbsmetrics.ImpLabels{
BannerImps: false,
VideoImps: false,
AudioImps: false,
NativeImps: false,
}
defer func() {
deps.metricsEngine.RecordRequest(labels)
deps.metricsEngine.RecordImps(labels, numImps)
deps.metricsEngine.RecordImps(impLabels)
deps.metricsEngine.RecordRequestTime(labels, time.Since(start))
deps.analytics.LogAuctionObject(&ao)
}()
Expand Down Expand Up @@ -199,8 +204,6 @@ func (deps *endpointDeps) VideoAuctionEndpoint(w http.ResponseWriter, r *http.Re
}
}

numImps = len(bidReq.Imp)

//execute auction logic
response, err := deps.ex.HoldAuction(ctx, bidReq, usersyncs, labels, &deps.categories)
ao.Request = bidReq
Expand Down
10 changes: 10 additions & 0 deletions exchange/exchange.go
Original file line number Diff line number Diff line change
Expand Up @@ -85,6 +85,16 @@ func (e *exchange) HoldAuction(ctx context.Context, bidRequest *openrtb.BidReque
}
}

for _, impInRequest := range bidRequest.Imp {
guscarreon marked this conversation as resolved.
Show resolved Hide resolved
var impLabels pbsmetrics.ImpLabels = pbsmetrics.ImpLabels{
BannerImps: impInRequest.Banner != nil,
VideoImps: impInRequest.Video != nil,
AudioImps: impInRequest.Audio != nil,
NativeImps: impInRequest.Native != nil,
}
e.me.RecordImps(impLabels)
}

// Slice of BidRequests, each a copy of the original cleaned to only contain bidder data for the named bidder
blabels := make(map[openrtb_ext.BidderName]*pbsmetrics.AdapterLabels)
cleanRequests, aliases, errs := cleanOpenRTBRequests(ctx, bidRequest, usersyncs, blabels, labels, e.gDPR, e.UsersyncIfAmbiguous)
Expand Down
6 changes: 3 additions & 3 deletions pbsmetrics/config/metrics.go
Original file line number Diff line number Diff line change
Expand Up @@ -84,9 +84,9 @@ func (me *MultiMetricsEngine) RecordConnectionClose(success bool) {
}

// RecordImps across all engines
func (me *MultiMetricsEngine) RecordImps(labels pbsmetrics.Labels, numImps int) {
func (me *MultiMetricsEngine) RecordImps(implabels pbsmetrics.ImpLabels) {
for _, thisME := range *me {
thisME.RecordImps(labels, numImps)
thisME.RecordImps(implabels)
}
}

Expand Down Expand Up @@ -186,7 +186,7 @@ func (me *DummyMetricsEngine) RecordConnectionClose(success bool) {
}

// RecordImps as a noop
func (me *DummyMetricsEngine) RecordImps(labels pbsmetrics.Labels, numImps int) {
func (me *DummyMetricsEngine) RecordImps(implabels pbsmetrics.ImpLabels) {
return
}

Expand Down
24 changes: 22 additions & 2 deletions pbsmetrics/config/metrics_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -69,16 +69,30 @@ func TestMultiMetricsEngine(t *testing.T) {
CookieFlag: pbsmetrics.CookieFlagYes,
AdapterBids: pbsmetrics.AdapterBidPresent,
}
impTypeLabels := pbsmetrics.ImpLabels{
BannerImps: true,
VideoImps: false,
AudioImps: true,
NativeImps: true,
}
for i := 0; i < 5; i++ {
metricsEngine.RecordRequest(labels)
metricsEngine.RecordImps(labels, 2)
metricsEngine.RecordImps(impTypeLabels)
metricsEngine.RecordRequestTime(labels, time.Millisecond*20)
metricsEngine.RecordAdapterRequest(pubLabels)
metricsEngine.RecordAdapterRequest(apnLabels)
metricsEngine.RecordAdapterPrice(pubLabels, 1.34)
metricsEngine.RecordAdapterBidReceived(pubLabels, openrtb_ext.BidTypeBanner, true)
metricsEngine.RecordAdapterTime(pubLabels, time.Millisecond*20)
}
impTypeLabels.BannerImps = false
impTypeLabels.VideoImps = true
impTypeLabels.AudioImps = false
impTypeLabels.NativeImps = false
for i := 0; i < 3; i++ {
metricsEngine.RecordImps(impTypeLabels)
}
//Make the metrics engine, instantiated here with goEngine, fill its RequestStatuses[RequestType][pbsmetrics.RequestStatusXX] with the new boolean values added to pbsmetrics.Labels
VerifyMetrics(t, "RequestStatuses.OpenRTB2.OK", goEngine.RequestStatuses[pbsmetrics.ReqTypeORTB2Web][pbsmetrics.RequestStatusOK].Count(), 5)
VerifyMetrics(t, "RequestStatuses.Legacy.OK", goEngine.RequestStatuses[pbsmetrics.ReqTypeLegacy][pbsmetrics.RequestStatusOK].Count(), 0)
VerifyMetrics(t, "RequestStatuses.AMP.OK", goEngine.RequestStatuses[pbsmetrics.ReqTypeAMP][pbsmetrics.RequestStatusOK].Count(), 0)
Expand All @@ -87,8 +101,14 @@ func TestMultiMetricsEngine(t *testing.T) {
VerifyMetrics(t, "RequestStatuses.Video.BadInput", goEngine.RequestStatuses[pbsmetrics.ReqTypeVideo][pbsmetrics.RequestStatusBadInput].Count(), 0)
VerifyMetrics(t, "RequestStatuses.OpenRTB2.Error", goEngine.RequestStatuses[pbsmetrics.ReqTypeORTB2Web][pbsmetrics.RequestStatusErr].Count(), 0)
VerifyMetrics(t, "RequestStatuses.OpenRTB2.BadInput", goEngine.RequestStatuses[pbsmetrics.ReqTypeORTB2Web][pbsmetrics.RequestStatusBadInput].Count(), 0)

VerifyMetrics(t, "ImpsTypeBanner", goEngine.ImpsTypeBanner.Count(), 5)
VerifyMetrics(t, "ImpsTypeVideo", goEngine.ImpsTypeVideo.Count(), 3)
VerifyMetrics(t, "ImpsTypeAudio", goEngine.ImpsTypeAudio.Count(), 5)
VerifyMetrics(t, "ImpsTypeNative", goEngine.ImpsTypeNative.Count(), 5)

VerifyMetrics(t, "Request", goEngine.RequestStatuses[pbsmetrics.ReqTypeORTB2Web][pbsmetrics.RequestStatusOK].Count(), 5)
VerifyMetrics(t, "ImpMeter", goEngine.ImpMeter.Count(), 10)
VerifyMetrics(t, "ImpMeter", goEngine.ImpMeter.Count(), 8)
VerifyMetrics(t, "NoCookieMeter", goEngine.NoCookieMeter.Count(), 0)
VerifyMetrics(t, "SafariRequestMeter", goEngine.SafariRequestMeter.Count(), 5)
VerifyMetrics(t, "SafariNoCookieMeter", goEngine.SafariNoCookieMeter.Count(), 0)
Expand Down
33 changes: 31 additions & 2 deletions pbsmetrics/go_metrics.go
Original file line number Diff line number Diff line change
Expand Up @@ -37,6 +37,12 @@ type Metrics struct {
userSyncSet map[openrtb_ext.BidderName]metrics.Meter
userSyncGDPRPrevent map[openrtb_ext.BidderName]metrics.Meter

// Media types found in the "imp" JSON object
ImpsTypeBanner metrics.Meter
ImpsTypeVideo metrics.Meter
ImpsTypeAudio metrics.Meter
ImpsTypeNative metrics.Meter

AdapterMetrics map[openrtb_ext.BidderName]*AdapterMetrics
// Don't export accountMetrics because we need helper functions here to insure its properly populated dynamically
accountMetrics map[string]*accountMetrics
Expand Down Expand Up @@ -107,6 +113,11 @@ func NewBlankMetrics(registry metrics.Registry, exchanges []openrtb_ext.BidderNa
userSyncSet: make(map[openrtb_ext.BidderName]metrics.Meter),
userSyncGDPRPrevent: make(map[openrtb_ext.BidderName]metrics.Meter),

ImpsTypeBanner: blankMeter,
ImpsTypeVideo: blankMeter,
ImpsTypeAudio: blankMeter,
ImpsTypeNative: blankMeter,

AdapterMetrics: make(map[openrtb_ext.BidderName]*AdapterMetrics, len(exchanges)),
accountMetrics: make(map[string]*accountMetrics),

Expand Down Expand Up @@ -137,6 +148,12 @@ func NewMetrics(registry metrics.Registry, exchanges []openrtb_ext.BidderName) *
newMetrics.ConnectionAcceptErrorMeter = metrics.GetOrRegisterMeter("connection_accept_errors", registry)
newMetrics.ConnectionCloseErrorMeter = metrics.GetOrRegisterMeter("connection_close_errors", registry)
newMetrics.ImpMeter = metrics.GetOrRegisterMeter("imps_requested", registry)

newMetrics.ImpsTypeBanner = metrics.GetOrRegisterMeter("imp_banner", registry)
newMetrics.ImpsTypeVideo = metrics.GetOrRegisterMeter("imp_video", registry)
newMetrics.ImpsTypeAudio = metrics.GetOrRegisterMeter("imp_audio", registry)
newMetrics.ImpsTypeNative = metrics.GetOrRegisterMeter("imp_native", registry)

newMetrics.SafariRequestMeter = metrics.GetOrRegisterMeter("safari_requests", registry)
newMetrics.NoCookieMeter = metrics.GetOrRegisterMeter("no_cookie_requests", registry)
newMetrics.AppRequestMeter = metrics.GetOrRegisterMeter("app_requests", registry)
Expand Down Expand Up @@ -297,8 +314,20 @@ func (me *Metrics) RecordRequest(labels Labels) {
am.requestMeter.Mark(1)
}

func (me *Metrics) RecordImps(labels Labels, numImps int) {
me.ImpMeter.Mark(int64(numImps))
func (me *Metrics) RecordImps(labels ImpLabels) {
me.ImpMeter.Mark(int64(1))
if labels.BannerImps {
me.ImpsTypeBanner.Mark(int64(1))
}
if labels.VideoImps {
me.ImpsTypeVideo.Mark(int64(1))
}
if labels.AudioImps {
me.ImpsTypeAudio.Mark(int64(1))
}
if labels.NativeImps {
me.ImpsTypeNative.Mark(int64(1))
}
}

func (me *Metrics) RecordConnectionAccept(success bool) {
Expand Down
30 changes: 29 additions & 1 deletion pbsmetrics/metrics.go
Original file line number Diff line number Diff line change
Expand Up @@ -28,11 +28,22 @@ type AdapterLabels struct {
AdapterErrors map[AdapterError]struct{}
}

// ImpLabels
type ImpLabels struct {
BannerImps bool
VideoImps bool
AudioImps bool
NativeImps bool
}

// Label typecasting. Se below the type definitions for possible values

// DemandSource : Demand source enumeration
type DemandSource string

// ImpMediaType : Media type described in the "imp" JSON object TODO is this still needed?
type ImpMediaType string

// RequestType : Request type enumeration
type RequestType string

Expand Down Expand Up @@ -78,6 +89,14 @@ const (
ReqTypeVideo RequestType = "video"
)

// The media types described in the "imp" json objects TODO is this still needed?
const (
ImpTypeBanner ImpMediaType = "banner"
ImpTypeVideo ImpMediaType = "video"
ImpTypeAudio ImpMediaType = "audio"
ImpTypeNative ImpMediaType = "native"
)

func RequestTypes() []RequestType {
return []RequestType{
ReqTypeLegacy,
Expand All @@ -88,6 +107,15 @@ func RequestTypes() []RequestType {
}
}

func ImpTypes() []ImpMediaType {
return []ImpMediaType{
ImpTypeBanner,
ImpTypeVideo,
ImpTypeAudio,
ImpTypeNative,
}
}

// Browser flag; at this point we only care about identifying Safari
const (
BrowserSafari Browser = "safari"
Expand Down Expand Up @@ -208,7 +236,7 @@ type MetricsEngine interface {
RecordConnectionAccept(success bool)
RecordConnectionClose(success bool)
RecordRequest(labels Labels) // ignores adapter. only statusOk and statusErr fom status
RecordImps(labels Labels, numImps int) // ignores adapter. only statusOk and statusErr fom status
RecordImps(labels ImpLabels) // ignores adapter. only statusOk and statusErr fom status
RecordRequestTime(labels Labels, length time.Duration) // ignores adapter. only statusOk and statusErr fom status
RecordAdapterRequest(labels AdapterLabels)
RecordAdapterPanic(labels AdapterLabels)
Expand Down
4 changes: 2 additions & 2 deletions pbsmetrics/metrics_mock.go
Original file line number Diff line number Diff line change
Expand Up @@ -31,8 +31,8 @@ func (me *MetricsEngineMock) RecordConnectionClose(success bool) {
}

// RecordImps mock
func (me *MetricsEngineMock) RecordImps(labels Labels, numImps int) {
me.Called(labels, numImps)
func (me *MetricsEngineMock) RecordImps(labels ImpLabels) {
me.Called(labels)
return
}

Expand Down
Loading