ExRam.Gremlinq VS plume

Compare ExRam.Gremlinq vs plume and see what are their differences.

plume

Plume is a code representation benchmarking library with options to extract the AST from Java bytecode and store the result in various graph databases. (by plume-oss)
InfluxDB - Power Real-Time Data Analytics at Scale
Get real-time insights from all types of time series data with InfluxDB. Ingest, query, and analyze billions of data points in real-time with unbounded cardinality.
www.influxdata.com
featured
SaaSHub - Software Alternatives and Reviews
SaaSHub helps you find the best software and product alternatives
www.saashub.com
featured
ExRam.Gremlinq plume
1 1
178 68
0.6% -
9.9 3.7
3 days ago 3 months ago
C# Scala
MIT License Apache License 2.0
The number of mentions indicates the total number of mentions that we've tracked plus the number of user suggested alternatives.
Stars - the number of stars that a project has on GitHub. Growth - month over month growth in stars.
Activity is a relative number indicating how actively a project is being developed. Recent commits have higher weight than older ones.
For example, an activity of 9.0 indicates that a project is amongst the top 10% of the most actively developed projects that we are tracking.

ExRam.Gremlinq

Posts with mentions or reviews of ExRam.Gremlinq. We have used some of these posts to build our list of alternatives and similar projects.

plume

Posts with mentions or reviews of plume. We have used some of these posts to build our list of alternatives and similar projects. The last one was on 2022-03-13.
  • Joern – The Bug Hunter's Workbench
    2 projects | news.ycombinator.com | 13 Mar 2022
    I get what you're saying which is why in the past two years (part of my MSc) I've been developing https://github.com/plume-oss/plume which exports CPGs with a pluggable graph database backend. The idea is that there is an interface that accepts the DiffGraph objects that build the AST, CFG, etc. and an implementing class would write the graph database specific approach to storing these results.

    We have one for TinkerGraph, Neo4j, TigerGraph, and Neptune which compared to OverflowDb, the rest are way too slow. We implemented the ODB driver in the same way to avoid bias.

    It is important to note that Plume runs Scala 2.13/3.1.1 (since this is what ODB and the CPG project use) and Neo4j in-mem was on 2.12 (until Nov 21) so I only measure remote Neo4j.

    As I've been developing I've approached the ShiftLeft team to assist and we are in the experimenting phase to write up our results with comparing how ODB does on different programs and versus other graph DBs. Currently my first write up is the approach for incremental CPG building and data flow querying and the second being this graph DB comparison.

    The TLDR of our multi-graph comparison is that remote DBs take way too long due to network overhead of moving data between one machine to the next. Another issue is that other databases use way too much memory and Neo4j/TinkerGraph are the worst offenders here. Simple programs produce multi-million edge graphs with a few hundred thousand nodes which is only "acceptable" in a couple of seconds if you think of a business use-case like analysing a program within a CI/CD pipeline for example.

    On the other hand, I do see the utility in having the other databases supported if time/memory constraints are not an issue e.g. I have one user of Plume using TinkerGraph backend for certain compatibility Tinker has with other tools and I can imagine Neo4j having similar third-party support.

    I think OverflowDB is a great database and the query language the team has extended on top of it is really useful and you should definitely give it a shot and/or contribute to it's development further to include other features other than speed/memory efficiency/query capabilities.

    If there is enough interest from the ideas that Plume has carried across then I'm sure the team may integrate some Plume's capabilities to keep the multi-graph database notion across while maintaining it for the latest changes.

What are some alternatives?

When comparing ExRam.Gremlinq and plume you can also consider the following projects:

graph - Practical Gremlin - An Apache TinkerPop Tutorial

awesome-dynamic-graphs - A collection of resources on dynamic/streaming/temporal/evolving graph processing systems, databases, data structures, datasets, and related academic and industrial work

AzureDotNet - Simplified Azure Storage Client in .NET Core

GraphDB2RDB - generate RDB DDL/DML from GraphDB (Tinkerpop).

Orleans.CosmosDB - Orleans providers for Azure Cosmos DB

Cake - :cake: Cake (C# Make) is a cross platform build automation system.

QuartzNet - Quartz Enterprise Scheduler .NET

gortanagtp - Console Application with Voice and Text Interaction Latest ChatGPT API