You can not select more than 25 topics
			Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
		
		
		
		
		
			
		
			
				
					
					
						
							40 lines
						
					
					
						
							795 B
						
					
					
				
			
		
		
		
			
			
			
		
		
	
	
							40 lines
						
					
					
						
							795 B
						
					
					
				| //+build rocksdb | |
|  | |
| package rocksdb | |
| 
 | |
| import ( | |
| 	"time" | |
| 
 | |
| 	"github.com/tecbot/gorocksdb" | |
| 
 | |
| 	"github.com/chrislusf/seaweedfs/weed/filer" | |
| ) | |
| 
 | |
| type TTLFilter struct { | |
| 	skipLevel0 bool | |
| } | |
| 
 | |
| func NewTTLFilter() gorocksdb.CompactionFilter { | |
| 	return &TTLFilter{ | |
| 		skipLevel0: true, | |
| 	} | |
| } | |
| 
 | |
| func (t *TTLFilter) Filter(level int, key, val []byte) (remove bool, newVal []byte) { | |
| 	// decode could be slow, causing write stall | |
| 	// level >0 sst can run compaction in parallel | |
| 	if !t.skipLevel0 || level > 0 { | |
| 		entry := filer.Entry{} | |
| 		if err := entry.DecodeAttributesAndChunks(val); err == nil { | |
| 			if entry.TtlSec > 0 && | |
| 				entry.Crtime.Add(time.Duration(entry.TtlSec)*time.Second).Before(time.Now()) { | |
| 				return true, nil | |
| 			} | |
| 		} | |
| 	} | |
| 	return false, val | |
| } | |
| 
 | |
| func (t *TTLFilter) Name() string { | |
| 	return "TTLFilter" | |
| }
 |