======== Stockage des données contextuelles dans le système de fichiers ======== Les données stockées dans les variables de contexte, de flux et globales sont appelées données de contexte et sont normalement stockées en mémoire. Cela signifie que si vous redémarrez le flux, les données sont perdues. Cependant à partir de la version 0.19 il est possible de stocker les données de contexte dans le système de fichiers. Pour ce faire, vous devrez modifier le fichier de paramètres et ajouter l'entrée suivante : contextStorage: { default: "memoryOnly", memoryOnly: { module: 'memory' }, file: { module: 'localfilesystem' } }, Peu importe où vous le placez dans le fichier de paramètres et selon la version de node-red avec laquelle vous avez commencé, il se peut que vous ayez déjà une entrée commentée. Les paramètres ci-dessus configurent node-red pour utiliser le magasin par défaut en mémoire ainsi que le système de fichiers pour le magasin de fichiers. Nous avons donc deux magasins. Lorsque vous enregistrez des données dans les variables de contexte ou que vous en récupérez des données, vous devrez spécifier le magasin dans lequel elles se trouvent. La valeur par défaut est en mémoire. Donc si vous utilisez : var count=context.get("count"); Vous récupérerez la variable count de la mémoire et pour obtenir la variable count du magasin de fichiers, utilisez : context.get("count", "file"); Pour stocker des données, utilisez : context.set("count", count,"file"); Le système stocke les variables dans un fichier JSON dans un dossier appelé contexte sous le dossier .node-red . Même si vous stockez des données dans le système de fichiers, il est toujours possible de perdre des données car elles ne sont vidées vers le système de fichiers que toutes les 30 secondes. Vous pouvez modifier cela (pas vraiment besoin) et d'autres options de configuration, voir la documentation [[https://nodered.org/docs/api/context/store/localfilesystem#options|ici]] . Vous devez également noter que vous pouvez avoir deux variables portant le même nom mais stockées dans la mémoire et dans le système de fichiers, comme indiqué dans la capture d'écran ci-dessous : {{ :start:raspberry:nodered:store-context-data-filesystem.png?direct&400 |}} Si vous disposez de plusieurs magasins de contexte, lorsque vous utilisez des nœuds tels que le nœud de modification, un choix vous sera présenté comme indiqué ci-dessous : {{ :start:raspberry:nodered:context-store.png?direct&400 |}} Cependant, vous souhaiterez peut-être utiliser uniquement le magasin de fichiers et pour éviter toute confusion, il est alors plus facile d'activer uniquement cette option en supprimant l'option de mémoire dans le fichier settings.js, comme indiqué ci-dessous : contextStorage: { default: "file", file: { module: 'localfilesystem' } }, Vous devez être très prudent lorsque vous utilisez plusieurs magasins, car cela rend les flux difficiles à déboguer.