代码拉取完成,页面将自动刷新
package queue
import (
"sync"
"github.com/google/uuid"
"gitee.com/sansaniot/ssiot-core/storage"
)
type queue chan storage.Messager
// NewMemory 内存模式
func NewMemory(poolNum uint) *Memory {
return &Memory{
queue: new(sync.Map),
PoolNum: poolNum,
}
}
type Memory struct {
queue *sync.Map
wait sync.WaitGroup
mutex sync.RWMutex
PoolNum uint
}
func (*Memory) String() string {
return "memory"
}
func (m *Memory) makeQueue() queue {
if m.PoolNum <= 0 {
return make(queue)
}
return make(queue, m.PoolNum)
}
func (m *Memory) Append(message storage.Messager) error {
m.mutex.RLock()
defer m.mutex.RUnlock()
memoryMessage := new(Message)
memoryMessage.SetID(message.GetID())
memoryMessage.SetStream(message.GetStream())
memoryMessage.SetValues(message.GetValues())
v, ok := m.queue.Load(message.GetStream())
if !ok {
v = m.makeQueue()
m.queue.Store(message.GetStream(), v)
}
var q queue
switch v.(type) {
case queue:
q = v.(queue)
default:
q = m.makeQueue()
m.queue.Store(message.GetStream(), q)
}
go func(gm storage.Messager, gq queue) {
gm.SetID(uuid.New().String())
gq <- gm
}(memoryMessage, q)
return nil
}
func (m *Memory) Register(name string, f storage.ConsumerFunc) {
m.mutex.RLock()
defer m.mutex.RUnlock()
v, ok := m.queue.Load(name)
if !ok {
v = m.makeQueue()
m.queue.Store(name, v)
}
var q queue
switch v.(type) {
case queue:
q = v.(queue)
default:
q = m.makeQueue()
m.queue.Store(name, q)
}
go func(out queue, gf storage.ConsumerFunc) {
var err error
for message := range q {
err = gf(message)
if err != nil {
out <- message
err = nil
}
}
}(q, f)
}
func (m *Memory) Run() {
m.wait.Add(1)
m.wait.Wait()
}
func (m *Memory) Shutdown() {
m.wait.Done()
}
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。