Github: https://github.com/mahdavipanah/keyv-upstash
keyv-upstash ist ein Speicheradapter für Keyv, der es mit Upstash Redis, einer serverlosen Redis-Plattform, verbindet. Mit diesem Adapter erhalten Sie eine einfache, effiziente und flexible Lösung für die Schlüsselwertspeicherung in serverlosen Anwendungen.
Keyv ist eine vielseitige Schlüsselwert-Speicherbibliothek, die über Adapter mehrere Backends unterstützt. Es bietet:
TTL-basierter Ablauf: Ideal für Caching oder dauerhafte Speicherung.
Namespace-Unterstützung: Vermeidet Schlüsselkollisionen in gemeinsam genutzten Umgebungen.
Erweiterbarkeit: Einfache Erstellung benutzerdefinierter Module oder das Hinzufügen von Funktionen wie Komprimierung.
Keyv funktioniert mit vielen Adaptern, wie Redis, SQLite, MongoDB und jetzt keyv-upstash für Upstash Redis.
keyv-upstash erweitert die Funktionen von Keyv durch die Integration mit Upstash Redis und bietet:
Serverlose Kompatibilität: Upstash Redis funktioniert ohne Verbindungsverwaltung, skaliert automatisch, perfekt für serverlose Apps.
Flexibel: Kompatibel mit dem Ökosystem von Keyv und unterstützt Erweiterungen von Drittanbietern.
Cache Layering: Kombinieren Sie es mit Cacheable für mehrschichtiges Caching.
Keine Anbieterbindung: Ist vollständig kompatibel mit serverless-redis-http, sodass Sie Ihr eigenes serverloses Redis einrichten und diesen Adapter damit verwenden können.
Folgen Sie diesen Schritten, um keyv-upstash zu integrieren:
Installieren Sie Keyv und den Upstash-Adapter:
npm install keyv keyv-upstash
Optional: Installieren Sie Cacheable für mehrschichtiges Caching:
npm install cacheable
Stellen Sie sicher, dass Sie eine Redis-Datenbank in Upstash erstellt haben. So verwenden Sie keyv-upstash in Ihrem Projekt:
import Keyv from 'keyv'; import { KeyvUpstash } from 'keyv-upstash'; const keyv = new Keyv({ store: new KeyvUpstash({ url: 'your-upstash-redis-url', token: 'your-upstash-redis-token', }), }); // Set a key-value pair await keyv.set('foo', 'bar'); // Retrieve the value const value = await keyv.get('foo'); console.log(value); // 'bar'
Namespaces verhindern Schlüsselkollisionen und ermöglichen eine bereichsbezogene Löschung:
const keyv = new Keyv({ store: new KeyvUpstash({ url: 'your-upstash-redis-url', token: 'your-upstash-redis-token', namespace: 'my-namespace', }), }); await keyv.set('foo', 'bar'); // Stored as 'my-namespace::foo'
Kombinieren Sie keyv-upstash mit Cacheable für mehrschichtiges Caching:
import { Cacheable } from 'cacheable'; const redisStore = new KeyvUpstash({ url: 'your-upstash-redis-url', token: 'your-upstash-redis-token', }); const cache = new Cacheable({ primary: new Map(), // Fast in-memory caching secondary: redisStore, // Persistent Redis caching }); await cache.set('foo', 'bar', { ttl: 1000 }); // Stores in both layers const value = await cache.get('foo'); // Fast lookup from memory or Redis console.log(value); // 'bar'
Verbessern Sie die Leistung mit setMany und getMany:
await keyv.setMany([ { key: 'key1', value: 'value1' }, { key: 'key2', value: 'value2' }, ]); const values = await keyv.getMany(['key1', 'key2']); console.log(values); // ['value1', 'value2']
Passen Sie Ihr Setup mit Optionen wie defaultTtl, keyPrefixSeparator und clearBatchSize an.
Das obige ist der detaillierte Inhalt vonEinführung von keyv-upstash: Nahtloser Schlüsselwertspeicher für serverlose Redis. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!