diff --git a/cache/resolve_record.go b/cache/resolve_record.go new file mode 100644 index 0000000..fef0f11 --- /dev/null +++ b/cache/resolve_record.go @@ -0,0 +1,32 @@ +package cache + +import ( + "fmt" + "kenaito-dns/dao" + "sync" +) + +var KeyResolveRecordMap sync.Map +var IdResolveRecordMap sync.Map + +func ReloadCache() { + resolveRecords := dao.FindResolveRecordByVersion(dao.GetResolveVersion()) + for _, record := range resolveRecords { + // id -> resolveRecord + IdResolveRecordMap.Store(record.Id, record) + // key -> resolveRecord + cacheKey := fmt.Sprintf("%s-%s", record.Name, record.RecordType) + records, ok := KeyResolveRecordMap.Load(cacheKey) + if !ok { + fmt.Println("读取缓存失败, key=" + cacheKey) + var tempRecords []dao.ResolveRecord + tempRecords = append(tempRecords, record) + KeyResolveRecordMap.Store(cacheKey, tempRecords) + } else { + fmt.Println("读取缓存成功, key=" + cacheKey) + var newRecords = records.([]dao.ResolveRecord) + records = append(newRecords, record) + KeyResolveRecordMap.Store(cacheKey, records) + } + } +} diff --git a/dao/resolve_config.go b/dao/resolve_config.go index 242c462..2a18407 100644 --- a/dao/resolve_config.go +++ b/dao/resolve_config.go @@ -14,7 +14,7 @@ type ResolveVersion struct { CurrentVersion int `xorm:"not null integer 'curr_version'"` } -func getResolveVersion() int { +func GetResolveVersion() int { var records []ResolveVersion err := Engine.Table("resolve_config").Where("`id` = ?", 1).Find(&records) if err != nil { diff --git a/dao/resolve_record.go b/dao/resolve_record.go index a36ed64..8cb9ae6 100644 --- a/dao/resolve_record.go +++ b/dao/resolve_record.go @@ -41,7 +41,7 @@ func FindResolveRecordByVersion(version int) []ResolveRecord { func FindResolveRecordByNameType(name string, recordType string) []ResolveRecord { var records []ResolveRecord - err := Engine.Table("resolve_record").Where("`name` = ? and `record_type` = ? and `version` = ?", name, recordType, getResolveVersion()).Find(&records) + err := Engine.Table("resolve_record").Where("`name` = ? and `record_type` = ? and `version` = ?", name, recordType, GetResolveVersion()).Find(&records) if err != nil { fmt.Println(err) } @@ -75,7 +75,7 @@ func FindResolveRecordPage(pageNo int, pageSize int, args *domain.QueryPageArgs) session.And("`value` = ?", qs) } } - session.And("`version` = ?", getResolveVersion()) + session.And("`version` = ?", GetResolveVersion()) err := session.Limit(pageSize, offset).Find(&records) if err != nil { fmt.Println(err) @@ -94,8 +94,8 @@ func SaveResolveRecord(wrapper *ResolveRecord) (bool, error) { func BackupResolveRecord(record *ResolveRecord) (bool, error, int, int) { var backupRecords []*ResolveRecord - oldVersion := getResolveVersion() - newVersion := getResolveVersion() + 1 + oldVersion := GetResolveVersion() + newVersion := GetResolveVersion() + 1 oldRecords := FindResolveRecordByVersion(oldVersion) for _, oldRecord := range oldRecords { newRecord := new(ResolveRecord) @@ -134,7 +134,7 @@ func RemoveResolveRecord(wrapper *ResolveRecord) (bool, error) { } func IsResolveRecordExist(wrapper *ResolveRecord) bool { - wrapper.Version = getResolveVersion() + wrapper.Version = GetResolveVersion() count, err := Engine.Table("resolve_record").Count(wrapper) if err != nil { fmt.Println(err) @@ -154,7 +154,7 @@ func IsUpdResolveRecordExist(id int, wrapper *ResolveRecord) bool { r.Name = wrapper.Name r.RecordType = wrapper.RecordType r.Value = wrapper.Value - r.Version = getResolveVersion() + r.Version = GetResolveVersion() count, err := Engine.Table("resolve_record").Where("id != ?", id).Count(r) if err != nil { fmt.Println(err) diff --git a/dns.sqlite3 b/dns.sqlite3 index c252b45..f4a09b8 100644 Binary files a/dns.sqlite3 and b/dns.sqlite3 differ diff --git a/main.go b/main.go index d73bdea..3eda64f 100644 --- a/main.go +++ b/main.go @@ -9,6 +9,7 @@ import ( "fmt" "github.com/gin-gonic/gin" "github.com/miekg/dns" + "kenaito-dns/cache" "kenaito-dns/config" "kenaito-dns/controller" "kenaito-dns/core" @@ -18,6 +19,7 @@ import ( func main() { fmt.Println("[app] [info] kenaito-dns version = " + config.AppVersion) + go cache.ReloadCache() go initDNSServer() initRestfulServer() }