View a markdown version of this page

Utilizzo di Python per connettersi a un'istanza database 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à.

Utilizzo di Python per connettersi a un'istanza database Neptune

Importante

La scelta della versione corretta del driver Apache TinkerPop Gremlin è fondamentale per la compatibilità con la versione del motore Neptune in uso. L'utilizzo di una versione incompatibile può causare errori di connessione o comportamenti imprevisti. Per informazioni dettagliate sulla compatibilità delle versioni, vedere. Accesso al grafo Neptune con Gremlin

La sezione seguente illustra come eseguire un esempio Python che si connette a un'istanza database Amazon Neptune ed esegue un attraversamento Gremlin.

Segui queste istruzioni da un'istanza Amazon EC2 nello stesso cloud privato virtuale (VPC) dell'istanza database Neptune.

Prima di iniziare, esegui queste attività:

Per connettersi a Neptune tramite Python
  1. Installare il pacchetto gremlinpython immettendo quanto segue:

    pip install --user gremlinpython
  2. Creare un file denominato gremlinexample.py, quindi aprirlo in un editor di testo.

  3. Copiare quanto segue nel file gremlinexample.py. Sostituisci your-neptune-endpoint con l'indirizzo del tuo cluster Neptune DB your-neptune-port e con la porta del tuo cluster Neptune DB (impostazione predefinita: 8182).

    Per informazioni su come trovare l'indirizzo dell'istanza database Neptune, consulta la sezione Connessione agli endpoint Amazon Neptune.

    L'esempio seguente mostra come connettersi con Gremlin Python.

    import boto3 import os from botocore.auth import SigV4Auth from botocore.awsrequest import AWSRequest from gremlin_python.driver.driver_remote_connection import DriverRemoteConnection from gremlin_python.process.anonymous_traversal import traversal database_url = "wss://your-neptune-endpoint:your-neptune-port/gremlin" remoteConn = DriverRemoteConnection(database_url, "g") g = traversal().withRemote(remoteConn) print(g.inject(1).toList()) remoteConn.close()
  4. Immettere il comando seguente per eseguire l'esempio:

    python gremlinexample.py

    La query Gremlin alla fine di questo esempio restituisce i vertici (g.V().limit(2)) in un elenco. Questo elenco viene quindi stampato con la funzione Python standard print.

    Nota

    La parte finale della query Gremlin, toList() è obbligatoria per inviare l'attraversamento al server per la valutazione. Se non includi quel metodo o un altro metodo equivalente, la query non viene inviata all'istanza database Neptune.

    Di seguito sono riportati alcuni esempi di metodi che inviano la query all'istanza DB Neptune:

    • toList()

    • toSet()

    • next()

    • iterate()

    Questi passaggi terminali si comportano in modo diverso in modalità script e in modalità bytecode. Per l'elenco canonico dei passaggi del terminale e i dettagli su come influiscono sulle transazioni, vedere. Test del codice Gremlin nel contesto in cui verrà implementato

    Utilizzalo iterate() quando non hai bisogno dei risultati delle tue query (ad esempio le mutazioni) in quanto consente di risparmiare sui costi di serializzazione.

    L'esempio precedente restituisce i primi due vertici del grafo utilizzando l'attraversamento g.V().limit(2).toList(). Per eseguire query per qualcos'altro, sostituirla con un altro attraversamento Gremlin con uno dei metodi finali appropriati.

Autenticazione IAM

Neptune supporta l'autenticazione IAM per controllare l'accesso al cluster DB. Se hai abilitato l'autenticazione IAM, devi utilizzare la firma Signature Version 4 per autenticare le tue richieste. Per istruzioni dettagliate ed esempi di codice per la connessione da un client Python, vedere. Connessione ai database Amazon Neptune utilizzando l'autenticazione IAM con Gremlin Python