The Spark of Neo4j
data:image/s3,"s3://crabby-images/41685/41685bad784c57f29cbb105e03202b5d362ec363" alt=""
Data Engineer, LARUS Business Automation
5 min read
data:image/s3,"s3://crabby-images/e4dda/e4ddad34b10e7e1ae09eaab39305249e40cec904" alt=""
data:image/s3,"s3://crabby-images/62bca/62bca140c5a97f5d63fdbfcfcdfd7e554fd45c5c" alt=""
TL;DR If you just want to see how to use the connector API, jump down to the “Final Result” section, or check out our examples in the docs.We wanted to give users an official library to avoid them to use custom “hacky” solutions, and to offer a continuous service, both from development and support points of view. We decided to deprecate the old connector, in favour of a complete rewriting of the code using the new DataSource API V2 that enable us to leverage the multi-language support of Apache Spark. We also focused a lot on the documentation website, keeping the docs up to date is actually part of our backlog. I also presented the story at the GraphRM meetup in Rome, if you rather want to watch the video:
Challenges
Getting to where we are now wasn’t really straightforward. We faced some problems and here’s a quick overview on how we dealt with them.Lack of Documentation
Being DataSource API V2 relatively new, we couldn’t find so much official Databricks documentation (especially for Spark 3). Examples, videos, and tutorials were not going enough in-depth for what we have to do, so we had to find another way build things; the good old “look at the source code” mantra came handy in this case and we were able to figure out what we were doing wrong when the documentation was not enough.Breaking Changes
We found breaking changes even between minor versions, and of course also between Spark 2.4 and Spark 3.0.data:image/s3,"s3://crabby-images/00af5/00af548567a612741a5ffb05bd3109a4670d848c" alt=""
Deal with Versions
Dealing with these breaking changes among the versions wasn’t easy. We couldn’t address all the Spark versions on the first release so we had to pick one. Spark 2.3 was relatively old and would have been unsupported in the future. On the other hand Spark 3.0 was new, and not widely adopted; so we decided to start with Spark 2.4. Finally after some month of coding we did out first pre-release on September 30th! 🎉data:image/s3,"s3://crabby-images/cf928/cf9289ea03bc284320e658bf0d2b47a4a09bc588" alt=""
data:image/s3,"s3://crabby-images/fd191/fd191f0df3eb758348029b7980ad9ff59d644c49" alt=""
- Spark 2.4 supports Scala 2.11 and Scala 2.12.
- Spark 3.0 supports Scala 2.12 and Scala 2.13, but dropped the support for Scala 2.11.
Neo4j vs Tables
The pain of integrating Spark and Neo4j is that Spark works with tables, and Neo4j doesn’t have anything similar to that, but instead nodes and relationships. We had to find solutions to a couple of problems here as well.Tables or Labels?
To map a graph made of nodes and relationships into a table we created a column for each property of the nodes, and two columns for the relationship, that contain the source node ID and the target node ID. In this way we are able to represent nodes and relationship in a tabular way to work with the DataSource APIs.data:image/s3,"s3://crabby-images/3995a/3995ae346069be9eafb9ab783490ce142d1168b5" alt=""
Schema or Not Schema?
Tables have schema, Neo4j doesn’t. We had to find a way to extract a schema from a schema-less graph. For doing this, once we got the result from Neo4j, we flatten the results, and go through each property, extracting the type and eventually creating the schema of the result set.data:image/s3,"s3://crabby-images/61004/610043c6b680d245ce151ef7d81d31cb2076b81b" alt=""
Final Result — And How To Use It
Let’s quickly look at the API of the Neo4j Connector for Apache Spark Here you can see how to read all the nodes that have the labels :Person:Admin using Scala, Python and R.data:image/s3,"s3://crabby-images/84320/84320e8866d22505484b32adf6dbcc353320e6e4" alt=""
data:image/s3,"s3://crabby-images/6d51f/6d51f3fc5356587a3e51aaf3c6a304ca7fcf7eb9" alt=""
data:image/s3,"s3://crabby-images/73f9e/73f9e5e6f0fb7b353313d9ecd7b5aed1c1d7c05d" alt=""
data:image/s3,"s3://crabby-images/29411/2941141a4eb5371a71a9f4c3283b0ddebaed94ea" alt=""
The Spark of Neo4j was originally published in Neo4j Developer Blog on Medium, where people are continuing the conversation by highlighting and responding to this story.