feat(service): add aof service
This commit is contained in:
parent
6fc2417de2
commit
3b61f55fe3
|
@ -73,11 +73,12 @@ func (a *AOF) flushLog() {
|
||||||
select {
|
select {
|
||||||
case <-flushTc.C:
|
case <-flushTc.C:
|
||||||
flush()
|
flush()
|
||||||
|
atomic.SwapInt32(a.ioNum, 0)
|
||||||
case <-frequencyTc.C:
|
case <-frequencyTc.C:
|
||||||
if num := atomic.LoadInt32(a.ioNum); num >= a.ioFrequency {
|
if num := atomic.LoadInt32(a.ioNum); num >= a.ioFrequency {
|
||||||
flush()
|
flush()
|
||||||
atomic.SwapInt32(a.ioNum, 0)
|
|
||||||
}
|
}
|
||||||
|
atomic.SwapInt32(a.ioNum, 0)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -9,4 +9,6 @@ var (
|
||||||
sysSingleService *singleService
|
sysSingleService *singleService
|
||||||
)
|
)
|
||||||
|
|
||||||
const timeOutDefault = 2
|
const (
|
||||||
|
timeOutDefault = 2
|
||||||
|
)
|
||||||
|
|
|
@ -5,8 +5,10 @@ import (
|
||||||
|
|
||||||
"gitee.com/timedb/wheatCache/pkg/event"
|
"gitee.com/timedb/wheatCache/pkg/event"
|
||||||
"gitee.com/timedb/wheatCache/pkg/lru"
|
"gitee.com/timedb/wheatCache/pkg/lru"
|
||||||
|
"gitee.com/timedb/wheatCache/pkg/middle"
|
||||||
"gitee.com/timedb/wheatCache/pkg/proto"
|
"gitee.com/timedb/wheatCache/pkg/proto"
|
||||||
"gitee.com/timedb/wheatCache/storage/dao"
|
"gitee.com/timedb/wheatCache/storage/dao"
|
||||||
|
"gitee.com/timedb/wheatCache/storage/persisted"
|
||||||
"github.com/spf13/viper"
|
"github.com/spf13/viper"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
@ -16,6 +18,28 @@ type singleService struct {
|
||||||
timeOut time.Duration
|
timeOut time.Duration
|
||||||
lruCache *lru.SingleCache
|
lruCache *lru.SingleCache
|
||||||
dao dao.Interface
|
dao dao.Interface
|
||||||
|
aof *persisted.AOF
|
||||||
|
}
|
||||||
|
|
||||||
|
func loadAOF() *persisted.AOF {
|
||||||
|
decName := viper.GetString("storage.aof-codec")
|
||||||
|
var aofCodec persisted.AOFCodec
|
||||||
|
switch decName {
|
||||||
|
case "":
|
||||||
|
return nil
|
||||||
|
case "b16":
|
||||||
|
aofCodec = nil
|
||||||
|
default:
|
||||||
|
aofCodec = nil
|
||||||
|
}
|
||||||
|
|
||||||
|
aofPath := viper.GetString("storage.aof-path")
|
||||||
|
aofFlush := viper.GetInt("storage.aof-flush-time")
|
||||||
|
aofCheckTime := viper.GetInt("storage.aof-check-time")
|
||||||
|
aofCheckFreq := viper.GetInt("storage.aof-check-freq")
|
||||||
|
|
||||||
|
return persisted.NewAOF(aofCodec, aofPath, time.Second*time.Duration(aofFlush),
|
||||||
|
aofCheckFreq, time.Second*time.Duration(aofCheckTime))
|
||||||
}
|
}
|
||||||
|
|
||||||
func NewSingleServer() proto.CommServerServer {
|
func NewSingleServer() proto.CommServerServer {
|
||||||
|
@ -27,11 +51,16 @@ func NewSingleServer() proto.CommServerServer {
|
||||||
|
|
||||||
lruCache := lru.NewLRUCache()
|
lruCache := lru.NewLRUCache()
|
||||||
|
|
||||||
|
// 加载 aof
|
||||||
|
aof := loadAOF()
|
||||||
|
|
||||||
ser := &singleService{
|
ser := &singleService{
|
||||||
lruCache: lruCache,
|
lruCache: lruCache,
|
||||||
lruProduce: event.NewProduce(lruCache.GetDriver()),
|
lruProduce: event.NewProduce(lruCache.GetDriver()),
|
||||||
timeOut: time.Duration(timeOut) * time.Second,
|
timeOut: time.Duration(timeOut) * time.Second,
|
||||||
dao: dao.NewDao(lruCache),
|
dao: dao.NewDao(lruCache),
|
||||||
|
middleProduce: event.NewProduce(middle.NewMiddleWare().GetEventDriver()),
|
||||||
|
aof: aof,
|
||||||
}
|
}
|
||||||
sysSingleService = ser
|
sysSingleService = ser
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue