Informazioni generali sulla migrazione da Neo4j a Neptune - Amazon Neptune

Le traduzioni sono generate tramite traduzione automatica. In caso di conflitto tra il contenuto di una traduzione e la versione originale in Inglese, quest'ultima prevarrà.

Informazioni generali sulla migrazione da Neo4j a Neptune

Con il supporto di Neptune per openCypher il linguaggio di interrogazione, puoi spostare la maggior parte dei carichi di lavoro Neo4j che utilizzano il protocollo Bolt o su Neptune. HTTPS Tuttavia, openCypher è una specifica open source che contiene la maggior parte ma non tutte le funzionalità supportate da altri database come Neo4j.

Nonostante sia compatibile in molti modi, Neptune non sostituisce in tutto e per tutto Neo4j. Neptune è un servizio di database a grafo completamente gestito con funzionalità aziendali come l'alta disponibilità e l'elevata durabilità, ma la sua architettura è diversa da quella di Neo4j. Neptune si basa sulle istanze: ha una singola istanza di scrittura principale e fino a 15 istanze di replica di lettura che consentono di dimensionare orizzontalmente la capacità di lettura. Utilizzando Neptune Serverless, puoi aumentare o ridurre automaticamente la capacità di calcolo a seconda del volume di query. Ciò non dipende dall'archiviazione di Neptune, che viene ridimensionata automaticamente con l'aggiunta di dati.

Neptune supporta la specifica standard openCypher open source, versione 9. Noi crediamo che l'open source sia un bene per tutti e ci impegniamo sia a portare il valore dell'open source ai nostri clienti, sia a portare l'eccellenza operativa delle AWS comunità open source. AWS

Tuttavia, molte applicazioni in esecuzione su Neo4j utilizzano anche funzionalità proprietarie che non sono open source e che Neptune non supporta. Ad esempio, Neptune non APOC supporta procedure, alcune clausole e funzioni specifiche di Cypher e/o tipi di dati. Char Date Duration Neptune trasmette automaticamente i tipi di dati mancanti utilizzando i tipi di dati supportati.

InoltreopenCypher, Neptune supporta anche il linguaggio di interrogazione TinkerPop Apache Gremlin per i grafici delle proprietà (oltre che per i dati). SPARQL RDF Gremlin può interagire con openCypher lo stesso grafico delle proprietà e in molti casi è possibile utilizzare Gremlin per fornire funzionalità che non sono disponibili. openCypher Di seguito è riportato un rapido confronto tra i due linguaggi:

openCypher Gremlin

Stile

Dichiarativo

Imperativo

Sintassi

Abbinamento di modelli

Match p=(a)-[:route]->(d) WHERE a.code='ANC' RETURN p

Basato su attraversamento

g.V().has('code', 'ANC'). out('route').path(). by(elementMap())

Facilità d'uso

SQL-ispirato, leggibile dai non programmatori

Più difficile da apprendere, simile a linguaggi di programmazione come Java

Flessibilità

Bassa

Elevata

Supporto delle query

Query basate su stringhe

Query basate su stringhe o codice in linea supportato da librerie client

Client

HTTPSe Bolt

HTTPSe Websockets

In generale, non è necessario modificare il modello di dati per migrare da Neo4j a Neptune, poiché sia Neo4j che Neptune supportano i dati con etichetta property graph (). LPG Tuttavia, Neptune ha alcune differenze in termini di architettura e modello di dati da usare per ottimizzare le prestazioni. Per esempio:

In caso di domande, contatta l' AWS assistenza o contatta il team del tuo account. AWS Utilizziamo il tuo feedback per dare priorità a nuove funzionalità in grado di soddisfare le tue esigenze.