Neo4j Connector for Apache Spark is an integration tool that moves and reshapes data bi-directionally between Neo4j and Apache Spark.
With this connector, Neo4j customers now have access to any data sources that are connected to the Spark ecosystem. Spark is the data orchestration tool of choice for most organizations, and also a powerful ETL tool.
Data scientists and developers who regularly need to manipulate data – data mashup and munging, extracting, consolidating, aggregating deduplicating, summing, etc. from Spark or other data sources (Oracle, Snowflake, Teradata, etc.) – can do so in Spark and then move it to Neo4j for graph processing.
For the Spark users out there that want advanced graph functionality, look no further: Neo4j offers a fully supported native graph database with rich data science tools.
How the Connector Works
Apache Spark has a DataSource API that allows foreign systems to be plugged in easily. Simply put, this lets us implement Neo4j within Apache Spark just like any other source for DataFrame reads or target for writing them.
Reading millions of nodes out of Neo4j can be as simple as this:
spark.read.format("org.neo4j.spark.DataSource") .option("url", "neo4j://my-cluster:7687") .option("labels", "Person") .load() .show()
Under the covers, the connector uses Neo4j’s official Bolt driver for Java, so all the usual connection settings that you would use with any other graph application are the same – no changes.
The connector lets you work with three kinds of graph objects, in both directions (read and write):
- Nodes
- Relationships
- Queries
Person
nodes in the example above. Other times, you need the full richness of the Cypher query language to express a graph pattern, and this will also work. You can perform path traversals or call special graph algorithms and quickly read the results back into Spark.How You Can Use the Connector
If you’re already using Apache Spark, the connector is ideal for extraction, transformation and load (ETL) work with Neo4j and tying graphs into existing data engineering or machine learning (ML) pipelines.
Here’s a simple five-step workflow illustrating how to use Neo4j Connector for Apache Spark:
- Assemble and Transform
Select data from a data store (e.g., Oracle), clean and transform to tables in Spark. - Reshape Tables to Graphs
Write any DataFrame1 to Neo4j using Tables for Labels2. - Enrich Data
Derive graph value in Neo4j and reveal connections that enrich data. - Reshape Graphs to Tables
Read graph-enriched data from the Neo4j graph back to Spark using Labels for Tables2. - Further Processing
Loop insights derived from graph analytics back to the original data source (Oracle) to make a decision or to contribute to other workflow activities within Spark.
2Tables for Labels, 2Labels for Tables: terminology used by Neo4j to denote conversion of graphs to tables and tables to graphs.
A huge thank you to our beta testing customers who helped us bring this product to market. We are excited to hear what new solutions you build by merging your Spark and graph data.
Try it out and let us know!