1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192 |
- package service
- import (
- commonConfig "cicv-data-closedloop/aarch64/kinglong/common/config"
- masterConfig "cicv-data-closedloop/aarch64/kinglong/master/package/config"
- "cicv-data-closedloop/common/config/c_log"
- "cicv-data-closedloop/common/domain"
- "cicv-data-closedloop/common/entity"
- "cicv-data-closedloop/common/util"
- "time"
- )
- // DiskClean 如果磁盘占用过高,则删除timeWindow和对应的文件
- func DiskClean() {
- c_log.GlobalLogger.Info("启动timeWindow清理goroutine,根据缓存策略清理copy目录。")
- for {
- time.Sleep(1000 * time.Millisecond)
- bags, _ := util.ListAbsolutePathWithSuffixAndSort(commonConfig.CloudConfig.BagCopyDir, ".bag")
- if len(bags) == 0 {
- continue
- }
- /*
- TTL(0, "删除旧数据");
- STOP(1, "停止缓存");
- LRU(2, "保留高优先级")
- */
- policyToDescription := map[string]string{
- "TTL": "删除旧数据",
- "STOP": "停止缓存",
- "LRU": "保留高优先级",
- }
- // 1 获取磁盘占用
- percent, _ := util.GetDiskUsagePercent()
- if percent > commonConfig.CloudConfig.DiskUsage {
- // 2 获取策略
- policy := commonConfig.PlatformConfig.TaskCachePolicy
- c_log.GlobalLogger.Errorf("磁盘占用超过 %v,触发删除规则 %v", commonConfig.CloudConfig.DiskUsage, policyToDescription[policy])
- if policy == "TTL" {
- // 1 获取时间窗口队列中的第二个
- if len(entity.TimeWindowConsumerQueue) > 2 {
- deleteTimeWindow(1)
- }
- } else if policy == "STOP" {
- // 2 获取时间窗口队列中的倒数第一个
- if len(entity.TimeWindowConsumerQueue) > 2 {
- deleteTimeWindow(len(entity.TimeWindowConsumerQueue) - 1)
- }
- } else if policy == "LRU" {
- // 3 获取优先级最低的时间窗口
- if len(entity.TimeWindowConsumerQueue) > 2 {
- indexToRemove := getIndexToRemoveForLRU()
- if indexToRemove != -1 {
- deleteTimeWindow(indexToRemove)
- }
- }
- } else {
- c_log.GlobalLogger.Error("未知的缓存策略:", policy)
- }
- }
- }
- }
- func deleteTimeWindow(indexToRemove int) {
- timeWindowToRemove := entity.TimeWindowConsumerQueue[indexToRemove]
- // 删除文件
- faultTime := timeWindowToRemove.FaultTime
- dir := domain.GetCopyDir(commonConfig.CloudConfig.BagCopyDir, faultTime)
- err := util.RemoveDir(dir)
- if err != nil {
- c_log.GlobalLogger.Error("删除目录", dir, "失败:", err)
- }
- entity.TimeWindowConsumerQueueMutex.Lock()
- // 使用切片的特性删除指定位置的元素
- entity.TimeWindowConsumerQueue = append(entity.TimeWindowConsumerQueue[:indexToRemove], entity.TimeWindowConsumerQueue[indexToRemove+1:]...)
- entity.TimeWindowConsumerQueueMutex.Unlock()
- }
- func getIndexToRemoveForLRU() int {
- lru := commonConfig.PlatformConfig.Lru
- i := len(lru) - 1
- for i >= 0 {
- for i2, window := range entity.TimeWindowConsumerQueue {
- for _, label := range window.Labels {
- if masterConfig.LabelMapTriggerId[label] == lru[i] {
- return i2
- }
- }
- }
- }
- return -1
- }
|