Charger les données de la lecture des fichiers au démarrage, puis traiter les nouveaux fichiers et effacer l'ancien état de la carte
Ce scénario implique le chargement de données à partir de fichiers lors du démarrage du serveur et en le stockant dans une carte. Le code surveille également périodiquement les nouveaux fichiers et met à jour la carte avec leurs données, remplaçant ainsi l'état précédent. Cependant, un problème survient si une erreur se produit lors de la lecture du fichier, car la carte est effacée avant que l'erreur ne soit traitée, la laissant vide.
Pour résoudre ce problème, une approche plus simple peut être utilisée :
Étape 1 : Charger la configuration initiale
Chargez la configuration initiale à partir de fichiers au démarrage à l'aide d'une fonction qui remplit une structure CustomerConfig.
Étape 2 : Créez un cache de configuration
Créez une structure ConfigCache qui stocke la configuration actuelle (*CustomerConfig) et gère les accès simultanés à l'aide d'un sync.RWMutex. De plus, créez un canal closeCh pour gérer l'arrêt du gestionnaire de cache.
Étape 3 : implémentez l'actualisation du cache de configuration
Lancez une goroutine dans l'actualisation qui vérifie périodiquement les modifications. Si des modifications sont détectées, il charge une nouvelle configuration à l'aide de loadConfig et met à jour le cache avec les nouvelles données. La méthode surveille également closeCh pour les demandes d'arrêt.
Étape 4 : Fournissez une méthode pour obtenir la configuration actuelle
Implémentez GetConfig pour fournir un accès en lecture seule à la configuration actuelle * Configuration client. Il utilise sync.RWMutex pour un accès simultané sécurisé.
Étape 5 : Gérer le gestionnaire de cache
Créez le gestionnaire de cache avec NewConfigCache. Pour arrêter l'actualisation, appelez Stop sur le gestionnaire de cache pour fermer le closeCh.
Exemple d'utilisation :
<code class="go">// Create the config cache cc, err := NewConfigCache() if err != nil { // Handle error } // Get the current config cfg := cc.GetConfig() // Use the config in your application</code>
Cette approche révisée garantit que si une erreur se produit pendant lecture du fichier, la configuration précédente est conservée et reste accessible. Cela simplifie également la conception globale tout en conservant la fonctionnalité souhaitée.
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!