Skip to content

Latest commit

 

History

History
64 lines (44 loc) · 2.34 KB

README.md

File metadata and controls

64 lines (44 loc) · 2.34 KB

GraphQL ❤️ GraphDB

GraphRM chat

Questo repository contiene un esempio di come integrare GraphQL con una graph database (in questo caso Neo4J).

Come database di riferimento per questo talk abbiamo usato quello presente in questo repository: avviate il database prima di iniziare con questo tutorial.

Il codice qui presente è il complemento del talk seguente (date un'occhiata per una introduzione anche a GraphQL):

Ci sono 3 branch principali in questo repository che, in modo progressivo, mostrano come migliorare l'integrazione tra i due strumenti.

  • master contiene una prima implementazione naïve di GraphQL (basata unicamente sugli Hello world online)
  • dataloader contiene una versione migliorata di master in cui viene adottato uno strumento per fare caching e migliorare le prestazioni del web server GraphQL.
  • single-query contiene l'apice del miglioramento, in cui per una singola query GraphQL corrisponde una sola query del GraphDB.

Setup

Il seguente repository contiene un web server generato in NodeJS: questo è un pre-requisito per iniziare il setup.

Per iniziare con il progetto potete entrare nella cartella server ed installare i pacchetti richiesti:

$ cd server
$ npm install

Una volta installato il necessario possiamo avviare il server:

$ npm start

Branch master

Sul branch master (il corrente) viene mostrata una integrazione basilare tra GraphQL e Neo4J: una volta avviato il progetto, procedere su GraphiQL ed eseguire la seguente query:

{
  meetupsByName(name:"GraphRM") {
    id
    name
    link
    members {
        name
    }
  }
}

Nel terminale vedrete una moltitudine di query eseguire per la risoluzione dei vari membri del meetup.

Questo approccio naïve funziona ma ha un alto costo prestazionale da pagare - in particolare il problema della N+1 query. Per vedere una metodologia per migliorare le prestazioni su questo fronte andare sul branch dataloader:

// spengere il server
$ git checkout dataloader
$ npm start

Cliccate qui per continuare a leggere...