Skip to content

Commit d581790

Browse files
committed
support expose metrics for plugins
1 parent 982b45c commit d581790

File tree

4 files changed

+36
-1
lines changed

4 files changed

+36
-1
lines changed

api/pkg/filtermanager/config.go

+6
Original file line numberDiff line numberDiff line change
@@ -216,6 +216,12 @@ func (p *FilterManagerConfigParser) Parse(any *anypb.Any, callbacks capi.ConfigC
216216

217217
for _, proto := range plugins {
218218
name := proto.Name
219+
220+
if registerMetrics := pkgPlugins.LoadMetricsCallback(name); registerMetrics != nil {
221+
api.LogInfof("register metrics for plugin %s", name)
222+
registerMetrics(callbacks)
223+
}
224+
219225
if plugin := pkgPlugins.LoadHTTPFilterFactoryAndParser(name); plugin != nil {
220226
config, err := plugin.ConfigParser.Parse(proto.Config)
221227
if err != nil {

api/pkg/plugins/plugins.go

+12
Original file line numberDiff line numberDiff line change
@@ -20,6 +20,8 @@ import (
2020
"errors"
2121
"runtime/debug"
2222

23+
capi "github.com/envoyproxy/envoy/contrib/golang/common/go/api"
24+
2325
"mosn.io/htnn/api/internal/proto"
2426
"mosn.io/htnn/api/pkg/filtermanager/api"
2527
"mosn.io/htnn/api/pkg/log"
@@ -31,6 +33,7 @@ var (
3133
pluginTypes = map[string]Plugin{}
3234
plugins = map[string]Plugin{}
3335
httpFilterFactoryAndParser = map[string]*FilterFactoryAndParser{}
36+
metricsRegister = map[string]func(capi.ConfigCallbacks){}
3437
)
3538

3639
// Here we introduce extra struct to avoid cyclic import between pkg/filtermanager and pkg/plugins
@@ -188,6 +191,15 @@ func (cp *PluginConfigParser) Parse(any interface{}) (res interface{}, err error
188191
return conf, nil
189192
}
190193

194+
func RegisterMetricsCallback(pluginName string, registerMetricFunc func(capi.ConfigCallbacks)) {
195+
logger.Info("register metrics for plugin", "name", pluginName)
196+
metricsRegister[pluginName] = registerMetricFunc
197+
}
198+
199+
func LoadMetricsCallback(pluginName string) func(capi.ConfigCallbacks) {
200+
return metricsRegister[pluginName]
201+
}
202+
191203
// PluginMethodDefaultImpl provides reasonable implementation for optional methods
192204
type PluginMethodDefaultImpl struct{}
193205

api/pkg/plugins/plugins_test.go

+6
Original file line numberDiff line numberDiff line change
@@ -20,6 +20,7 @@ import (
2020
"testing"
2121

2222
"github.com/agiledragon/gomonkey/v2"
23+
capi "github.com/envoyproxy/envoy/contrib/golang/common/go/api"
2324
"github.com/stretchr/testify/assert"
2425
"google.golang.org/protobuf/types/known/anypb"
2526

@@ -285,3 +286,8 @@ func TestRegisterPluginWithType(t *testing.T) {
285286
assert.NotNil(t, LoadPlugin("mock"))
286287
assert.NotNil(t, LoadPluginType("mock"))
287288
}
289+
290+
func TestRegisterPluginMetrics(t *testing.T) {
291+
RegisterMetricsCallback("mock", func(cc capi.ConfigCallbacks) {})
292+
assert.NotNil(t, LoadMetricsCallback("mock"))
293+
}

api/tests/integration/test_plugins.go

+12-1
Original file line numberDiff line numberDiff line change
@@ -21,6 +21,8 @@ import (
2121
"strconv"
2222
"strings"
2323

24+
capi "github.com/envoyproxy/envoy/contrib/golang/common/go/api"
25+
2426
"mosn.io/htnn/api/pkg/filtermanager/api"
2527
"mosn.io/htnn/api/pkg/plugins"
2628
)
@@ -200,6 +202,7 @@ func (p *bufferPlugin) Factory() api.FilterFactory {
200202
type localReplyPlugin struct {
201203
plugins.PluginMethodDefaultImpl
202204
basePlugin
205+
usageCounter capi.CounterMetric
203206
}
204207

205208
func localReplyFactory(c interface{}, callbacks api.FilterCallbackHandler) api.Filter {
@@ -242,6 +245,7 @@ func (f *localReplyFilter) DecodeRequest(headers api.RequestHeaderMap, buf api.B
242245
f.reqHdr = headers
243246
f.runFilters = headers.Values("run")
244247
if f.config.Decode {
248+
lrp.usageCounter.Increment(1)
245249
return f.NewLocalResponse("reply", true)
246250
}
247251
return api.Continue
@@ -309,6 +313,11 @@ func (p *localReplyPlugin) Factory() api.FilterFactory {
309313
return localReplyFactory
310314
}
311315

316+
func (p *localReplyPlugin) MetricsDefinition(c capi.ConfigCallbacks) {
317+
p.usageCounter = c.DefineCounterMetric("localreply.usage.counter")
318+
// Define more metrics here
319+
}
320+
312321
type badPlugin struct {
313322
plugins.PluginMethodDefaultImpl
314323
}
@@ -619,10 +628,12 @@ func (f *onLogFilter) OnLog(reqHeaders api.RequestHeaderMap, reqTrailers api.Req
619628
api.LogWarnf("receive request trailers: %+v", trailers)
620629
}
621630

631+
var lrp = &localReplyPlugin{}
632+
622633
func init() {
623634
plugins.RegisterPlugin("stream", &streamPlugin{})
624635
plugins.RegisterPlugin("buffer", &bufferPlugin{})
625-
plugins.RegisterPlugin("localReply", &localReplyPlugin{})
636+
plugins.RegisterPlugin("localReply", lrp)
626637
plugins.RegisterPlugin("bad", &badPlugin{})
627638
plugins.RegisterPlugin("consumer", &consumerPlugin{})
628639
plugins.RegisterPlugin("init", &initPlugin{})

0 commit comments

Comments
 (0)