Heim > Backend-Entwicklung > Golang > Wie entwerfe ich einen Konfigurationscache, der Aktualisierungen und Fehler ordnungsgemäß verarbeitet?

Wie entwerfe ich einen Konfigurationscache, der Aktualisierungen und Fehler ordnungsgemäß verarbeitet?

Mary-Kate Olsen
Freigeben: 2024-10-25 06:43:02
Original
849 Leute haben es durchsucht

How to Design a Configuration Cache That Handles Updates and Errors Gracefully?

Konfiguration aus Dateien laden und mit neuen Updates aktualisieren

Problembeschreibung:

Ein Code Beim Design wird beim Start eine Konfiguration aus Dateien geladen und regelmäßig mit neueren Versionen aktualisiert. Ziel ist es, über einen Mechanismus zu verfügen, der die folgenden Anforderungen erfüllt:

  • Gleichzeitiger Zugriff auf die Konfiguration
  • Neuladen erkannter Konfigurationsänderungen
  • Zugriff auf die neueste Konfiguration
  • Sofortiger Zugriff auf die neueste Konfiguration bei Updates
  • Beibehaltung der vorherigen Konfiguration, wenn ein Update fehlschlägt

Das ursprüngliche Design verwendet eine gleichzeitige Karte zum Speichern der Konfiguration , steht aber vor einem Problem, bei dem Fehler während der Aktualisierung zu einer leeren Karte führen können.

Lösung:

Es wird ein vereinfachtes Design vorgeschlagen, das alle Anforderungen erfüllt:

CustomerConfig-Struktur:

Definiert die zwischenzuspeichernde Konfiguration:

type CustomerConfig struct {
    Data map[string]bool
    LoadedAt time.Time
}
Nach dem Login kopieren

loadConfig-Funktion:

Ladet die Konfiguration aus Dateien:

func loadConfig() (*CustomerConfig, error) {
    cfg := &CustomerConfig{
        Data:     map[string]bool{},
        LoadedAt: time.Now(),
    }

    // Logic to load files and populate cfg.Data
    // If an error occurs, return it

    // If loading succeeds, return the config
    return cfg, nil
}
Nach dem Login kopieren

ConfigCache-Struktur:

Verwaltet das Konfigurations-Caching:

type ConfigCache struct {
    configMu sync.RWMutex
    config   *CustomerConfig
    closeCh  chan struct{}
}
Nach dem Login kopieren

NeueConfigCache-Funktion:

Erstellt einen neuen Konfigurationscache:

func NewConfigCache() (*ConfigCache, error) {
    cfg, err := loadConfig()
    if err != nil {
        return nil, fmt.Errorf("loading initial config failed: %w", err)
    }

    cc := &ConfigCache{
        config:  cfg,
        closeCh: make(chan struct{}),
    }

    // Launch a goroutine to periodically check for changes and load new configs
    go cc.refresher()

    return cc, nil
}
Nach dem Login kopieren

Auffrischungsfunktion:

Prüft regelmäßig auf Konfigurationsänderungen und aktualisiert den Cache:

func (cc *ConfigCache) refresher() {
    ticker := time.NewTicker(1 * time.Minute) // Every minute
    defer ticker.Stop()

    for {
        select {
        case <-ticker.C:
            // Check for changes
            changes := false // Logic to detect changes
            if !changes {
                continue // No changes, continue
            }

            // Changes! Load new config:
            cfg, err := loadConfig()
            if err != nil {
                log.Printf("Failed to load config: %v", err)
                continue // Keep the previous config
            }

            // Apply / store new config
            cc.configMu.Lock()
            cc.config = cfg
            cc.configMu.Unlock()

        case <-cc.closeCh:
            return
        }
    }
}
Nach dem Login kopieren

Stopp-Funktion:

Stoppt die Refresh-Goroutine:

func (cc *ConfigCache) Stop() {
    close(cc.closeCh)
}
Nach dem Login kopieren

GetConfig-Funktion:

Zugriff auf die aktuelle Konfiguration:

func (cc *ConfigCache) GetConfig() *CustomerConfig {
    cc.configMu.RLock()
    defer cc.configMu.RUnlock()
    return cc.config
}
Nach dem Login kopieren

Verwendung:

cc, err := NewConfigCache()
if err != nil {
    // Handle the error appropriately
}

// Access the configuration whenever needed:
cfg := cc.GetConfig()
// Use the configuration here

// Stop the cache refreshing when necessary:
cc.Stop()
Nach dem Login kopieren

Diese Lösung gewährleistet:

  • Gleichzeitiger Zugriff auf die Konfiguration
  • Bei erkannten Änderungen neu laden
  • Zugriff auf die neueste Konfiguration
  • Sofortiger Zugriff bei Aktualisierungen
  • Beibehaltung der vorherigen Konfiguration bei Aktualisierungsfehlern

Das obige ist der detaillierte Inhalt vonWie entwerfe ich einen Konfigurationscache, der Aktualisierungen und Fehler ordnungsgemäß verarbeitet?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Neueste Artikel des Autors
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage