dispatcher.go 841 B

123456789101112131415161718192021222324252627282930313233343536373839404142
  1. package ruleEngine
  2. import (
  3. "github.com/gogf/gf/os/grpool"
  4. "runtime"
  5. )
  6. const (
  7. APP_DISPATCHER_NAME = "app-dispatcher"
  8. TENANT_DISPATCHER_NAME = "tenant-dispatcher"
  9. DEVICE_DISPATCHER_NAME = "device-dispatcher"
  10. RULE_DISPATCHER_NAME = "rule-dispatcher"
  11. )
  12. // IDispatcher 分发器接口
  13. type IDispatcher interface {
  14. // submit a task,is a func
  15. Submit(func()) error
  16. Destroy() error
  17. }
  18. // PoolDispatcher gr pool implements IDispatcher
  19. type PoolDispatcher struct {
  20. pool *grpool.Pool
  21. }
  22. func (p *PoolDispatcher) Destroy() error {
  23. return nil
  24. }
  25. func (p *PoolDispatcher) Submit(fn func()) error {
  26. return p.pool.Add(fn)
  27. }
  28. // NewPoolDispatcher new instance with limit
  29. func NewPoolDispatcher(limit int) *PoolDispatcher {
  30. if limit <= 0 {
  31. limit = runtime.GOMAXPROCS(-1)
  32. }
  33. pl := grpool.New(limit)
  34. return &PoolDispatcher{pool: pl}
  35. }