mirror of
https://github.com/MetaCubeX/mihomo.git
synced 2026-03-12 19:59:57 +00:00
feat: support ARC for DNS cache
This commit is contained in:
@@ -3,7 +3,7 @@ package dns
|
||||
import (
|
||||
"net/netip"
|
||||
|
||||
"github.com/metacubex/mihomo/common/cache"
|
||||
"github.com/metacubex/mihomo/common/lru"
|
||||
"github.com/metacubex/mihomo/component/fakeip"
|
||||
C "github.com/metacubex/mihomo/constant"
|
||||
)
|
||||
@@ -11,7 +11,7 @@ import (
|
||||
type ResolverEnhancer struct {
|
||||
mode C.DNSMode
|
||||
fakePool *fakeip.Pool
|
||||
mapping *cache.LruCache[netip.Addr, string]
|
||||
mapping *lru.LruCache[netip.Addr, string]
|
||||
}
|
||||
|
||||
func (h *ResolverEnhancer) FakeIPEnabled() bool {
|
||||
@@ -105,11 +105,11 @@ func (h *ResolverEnhancer) StoreFakePoolState() {
|
||||
|
||||
func NewEnhancer(cfg Config) *ResolverEnhancer {
|
||||
var fakePool *fakeip.Pool
|
||||
var mapping *cache.LruCache[netip.Addr, string]
|
||||
var mapping *lru.LruCache[netip.Addr, string]
|
||||
|
||||
if cfg.EnhancedMode != C.DNSNormal {
|
||||
fakePool = cfg.Pool
|
||||
mapping = cache.New(cache.WithSize[netip.Addr, string](4096))
|
||||
mapping = lru.New(lru.WithSize[netip.Addr, string](4096))
|
||||
}
|
||||
|
||||
return &ResolverEnhancer{
|
||||
|
||||
Reference in New Issue
Block a user