mirror of
https://github.com/seaweedfs/seaweedfs.git
synced 2024-12-02 16:39:16 +08:00
51939efeac
master server does not need to store the sequence on disk any more 2. fix raft server's failure to init cluster during bootstrapping
37 lines
649 B
Go
37 lines
649 B
Go
package sequence
|
|
|
|
import (
|
|
"sync"
|
|
)
|
|
|
|
// just for testing
|
|
type MemorySequencer struct {
|
|
counter uint64
|
|
sequenceLock sync.Mutex
|
|
}
|
|
|
|
func NewMemorySequencer() (m *MemorySequencer) {
|
|
m = &MemorySequencer{counter: 1}
|
|
return
|
|
}
|
|
|
|
func (m *MemorySequencer) NextFileId(count int) (uint64, int) {
|
|
m.sequenceLock.Lock()
|
|
defer m.sequenceLock.Unlock()
|
|
ret := m.counter
|
|
m.counter += uint64(count)
|
|
return ret, count
|
|
}
|
|
|
|
func (m *MemorySequencer) SetMax(seenValue uint64) {
|
|
m.sequenceLock.Lock()
|
|
defer m.sequenceLock.Unlock()
|
|
if m.counter <= seenValue {
|
|
m.counter = seenValue + 1
|
|
}
|
|
}
|
|
|
|
func (m *MemorySequencer) Peek() uint64 {
|
|
return m.counter
|
|
}
|