github.com/keybase/client/go@v0.0.0-20240309051027-028f7c731f8b/kbfs/libkbfs/bserver_measured.go (about) 1 // Copyright 2016 Keybase Inc. All rights reserved. 2 // Use of this source code is governed by a BSD 3 // license that can be found in the LICENSE file. 4 5 package libkbfs 6 7 import ( 8 "github.com/keybase/client/go/kbfs/kbfsblock" 9 "github.com/keybase/client/go/kbfs/kbfscrypto" 10 "github.com/keybase/client/go/kbfs/tlf" 11 "github.com/keybase/client/go/protocol/keybase1" 12 metrics "github.com/rcrowley/go-metrics" 13 "golang.org/x/net/context" 14 ) 15 16 // BlockServerMeasured delegates to another BlockServer instance but 17 // also keeps track of stats. 18 type BlockServerMeasured struct { 19 delegate BlockServer 20 getTimer metrics.Timer 21 getEncodedSizeTimer metrics.Timer 22 putTimer metrics.Timer 23 putAgainTimer metrics.Timer 24 addBlockReferenceTimer metrics.Timer 25 removeBlockReferencesTimer metrics.Timer 26 archiveBlockReferencesTimer metrics.Timer 27 getLiveBlockReferencesTimer metrics.Timer 28 isUnflushedTimer metrics.Timer 29 } 30 31 var _ BlockServer = BlockServerMeasured{} 32 33 // NewBlockServerMeasured creates and returns a new 34 // BlockServerMeasured instance with the given delegate and registry. 35 func NewBlockServerMeasured(delegate BlockServer, r metrics.Registry) BlockServerMeasured { 36 getTimer := metrics.GetOrRegisterTimer("BlockServer.Get", r) 37 getEncodedSizeTimer := metrics.GetOrRegisterTimer( 38 "BlockServer.GetEncodedSize", r) 39 putTimer := metrics.GetOrRegisterTimer("BlockServer.Put", r) 40 addBlockReferenceTimer := metrics.GetOrRegisterTimer("BlockServer.AddBlockReference", r) 41 removeBlockReferencesTimer := metrics.GetOrRegisterTimer("BlockServer.RemoveBlockReferences", r) 42 archiveBlockReferencesTimer := metrics.GetOrRegisterTimer("BlockServer.ArchiveBlockReferences", r) 43 getLiveBlockReferencesTimer := metrics.GetOrRegisterTimer("BlockServer.GetLiveBlockReferences", r) 44 isUnflushedTimer := metrics.GetOrRegisterTimer("BlockServer.IsUnflushed", r) 45 return BlockServerMeasured{ 46 delegate: delegate, 47 getTimer: getTimer, 48 getEncodedSizeTimer: getEncodedSizeTimer, 49 putTimer: putTimer, 50 addBlockReferenceTimer: addBlockReferenceTimer, 51 removeBlockReferencesTimer: removeBlockReferencesTimer, 52 archiveBlockReferencesTimer: archiveBlockReferencesTimer, 53 getLiveBlockReferencesTimer: getLiveBlockReferencesTimer, 54 isUnflushedTimer: isUnflushedTimer, 55 } 56 } 57 58 // FastForwardBackoff implements the BlockServer interface. 59 func (b BlockServerMeasured) FastForwardBackoff() { 60 b.delegate.FastForwardBackoff() 61 } 62 63 // Get implements the BlockServer interface for BlockServerMeasured. 64 func (b BlockServerMeasured) Get( 65 ctx context.Context, tlfID tlf.ID, id kbfsblock.ID, 66 context kbfsblock.Context, cacheType DiskBlockCacheType) ( 67 buf []byte, serverHalf kbfscrypto.BlockCryptKeyServerHalf, err error) { 68 b.getTimer.Time(func() { 69 buf, serverHalf, err = b.delegate.Get( 70 ctx, tlfID, id, context, cacheType) 71 }) 72 return buf, serverHalf, err 73 } 74 75 // GetEncodedSizes implements the BlockServer interface for BlockServerMeasured. 76 func (b BlockServerMeasured) GetEncodedSizes( 77 ctx context.Context, tlfID tlf.ID, ids []kbfsblock.ID, 78 contexts []kbfsblock.Context) ( 79 sizes []uint32, statuses []keybase1.BlockStatus, err error) { 80 b.getEncodedSizeTimer.Time(func() { 81 sizes, statuses, err = b.delegate.GetEncodedSizes( 82 ctx, tlfID, ids, contexts) 83 }) 84 return sizes, statuses, err 85 } 86 87 // Put implements the BlockServer interface for BlockServerMeasured. 88 func (b BlockServerMeasured) Put( 89 ctx context.Context, tlfID tlf.ID, id kbfsblock.ID, 90 context kbfsblock.Context, buf []byte, 91 serverHalf kbfscrypto.BlockCryptKeyServerHalf, 92 cacheType DiskBlockCacheType) (err error) { 93 b.putTimer.Time(func() { 94 err = b.delegate.Put( 95 ctx, tlfID, id, context, buf, serverHalf, cacheType) 96 }) 97 return err 98 } 99 100 // PutAgain implements the BlockServer interface for BlockServerMeasured. 101 func (b BlockServerMeasured) PutAgain( 102 ctx context.Context, tlfID tlf.ID, id kbfsblock.ID, 103 context kbfsblock.Context, buf []byte, 104 serverHalf kbfscrypto.BlockCryptKeyServerHalf, 105 cacheType DiskBlockCacheType) (err error) { 106 b.putAgainTimer.Time(func() { 107 err = b.delegate.PutAgain( 108 ctx, tlfID, id, context, buf, serverHalf, cacheType) 109 }) 110 return err 111 } 112 113 // AddBlockReference implements the BlockServer interface for 114 // BlockServerMeasured. 115 func (b BlockServerMeasured) AddBlockReference(ctx context.Context, tlfID tlf.ID, 116 id kbfsblock.ID, context kbfsblock.Context) (err error) { 117 b.addBlockReferenceTimer.Time(func() { 118 err = b.delegate.AddBlockReference(ctx, tlfID, id, context) 119 }) 120 return err 121 } 122 123 // RemoveBlockReferences implements the BlockServer interface for 124 // BlockServerMeasured. 125 func (b BlockServerMeasured) RemoveBlockReferences(ctx context.Context, 126 tlfID tlf.ID, contexts kbfsblock.ContextMap) ( 127 liveCounts map[kbfsblock.ID]int, err error) { 128 b.removeBlockReferencesTimer.Time(func() { 129 liveCounts, err = b.delegate.RemoveBlockReferences( 130 ctx, tlfID, contexts) 131 }) 132 return liveCounts, err 133 } 134 135 // ArchiveBlockReferences implements the BlockServer interface for 136 // BlockServerMeasured. 137 func (b BlockServerMeasured) ArchiveBlockReferences(ctx context.Context, 138 tlfID tlf.ID, contexts kbfsblock.ContextMap) (err error) { 139 b.archiveBlockReferencesTimer.Time(func() { 140 err = b.delegate.ArchiveBlockReferences(ctx, tlfID, contexts) 141 }) 142 return err 143 } 144 145 // GetLiveBlockReferences implements the BlockServer interface for 146 // BlockServerMeasured. 147 func (b BlockServerMeasured) GetLiveBlockReferences( 148 ctx context.Context, tlfID tlf.ID, contexts kbfsblock.ContextMap) ( 149 liveCounts map[kbfsblock.ID]int, err error) { 150 b.getLiveBlockReferencesTimer.Time(func() { 151 liveCounts, err = b.delegate.GetLiveBlockReferences( 152 ctx, tlfID, contexts) 153 }) 154 return liveCounts, err 155 } 156 157 // IsUnflushed implements the BlockServer interface for BlockServerMeasured. 158 func (b BlockServerMeasured) IsUnflushed(ctx context.Context, tlfID tlf.ID, 159 id kbfsblock.ID) (isUnflushed bool, err error) { 160 b.isUnflushedTimer.Time(func() { 161 isUnflushed, err = b.delegate.IsUnflushed(ctx, tlfID, id) 162 }) 163 return isUnflushed, err 164 165 } 166 167 // Shutdown implements the BlockServer interface for 168 // BlockServerMeasured. 169 func (b BlockServerMeasured) Shutdown(ctx context.Context) { 170 b.delegate.Shutdown(ctx) 171 } 172 173 // RefreshAuthToken implements the BlockServer interface for 174 // BlockServerMeasured. 175 func (b BlockServerMeasured) RefreshAuthToken(ctx context.Context) { 176 b.delegate.RefreshAuthToken(ctx) 177 } 178 179 // GetUserQuotaInfo implements the BlockServer interface for BlockServerMeasured 180 func (b BlockServerMeasured) GetUserQuotaInfo(ctx context.Context) (info *kbfsblock.QuotaInfo, err error) { 181 return b.delegate.GetUserQuotaInfo(ctx) 182 } 183 184 // GetTeamQuotaInfo implements the BlockServer interface for BlockServerMeasured 185 func (b BlockServerMeasured) GetTeamQuotaInfo( 186 ctx context.Context, tid keybase1.TeamID) ( 187 info *kbfsblock.QuotaInfo, err error) { 188 return b.delegate.GetTeamQuotaInfo(ctx, tid) 189 }