mongo.go 1.1 KB

1234567891011121314151617181920212223242526272829
  1. package internal
  2. import (
  3. "context"
  4. "fmt"
  5. "github.com/qiniu/qmgo/options"
  6. "go.mongodb.org/mongo-driver/event"
  7. opt "go.mongodb.org/mongo-driver/mongo/options"
  8. "go.uber.org/zap"
  9. )
  10. var Mongo = new(mongo)
  11. type mongo struct{}
  12. func (m *mongo) GetClientOptions() []options.ClientOptions {
  13. cmdMonitor := &event.CommandMonitor{
  14. Started: func(ctx context.Context, event *event.CommandStartedEvent) {
  15. zap.L().Info(fmt.Sprintf("[MongoDB][RequestID:%d][database:%s] %s\n", event.RequestID, event.DatabaseName, event.Command), zap.String("business", "mongo"))
  16. },
  17. Succeeded: func(ctx context.Context, event *event.CommandSucceededEvent) {
  18. zap.L().Info(fmt.Sprintf("[MongoDB][RequestID:%d] [%s] %s\n", event.RequestID, event.Duration.String(), event.Reply), zap.String("business", "mongo"))
  19. },
  20. Failed: func(ctx context.Context, event *event.CommandFailedEvent) {
  21. zap.L().Error(fmt.Sprintf("[MongoDB][RequestID:%d] [%s] %s\n", event.RequestID, event.Duration.String(), event.Failure), zap.String("business", "mongo"))
  22. },
  23. }
  24. return []options.ClientOptions{{ClientOptions: &opt.ClientOptions{Monitor: cmdMonitor}}}
  25. }