| commit | e3dfcc43bf962077e926ad0a8d6bbb41cae62c2a | [log] [tgz] | 
|---|---|---|
| author | kitalkuyo-gita <windwheel@sina.cn> | Mon Sep 29 19:07:39 2025 +0800 | 
| committer | GitHub <noreply@github.com> | Mon Sep 29 19:07:39 2025 +0800 | 
| tree | fb11126e7c406a24d1f1b03c0518c3a3a2fc711c | |
| parent | 5307fcb0f359915057d2b4d1426428c3cc3e4569 [diff] | 
feat: Support incremental Minimum Spanning Tree (#599) * finish mst tree * fix checkstyle * refactor code * remove useless files * add test files * fix checkstyle * fix checkstyle * translate english * rename team name * fix tests * translate english * translate english * fix checkstyle * fix checkstyle * fix tests * fix complie error * fix checkstyle * fix checkstyle * chore: support short-circuit algorithm * support itype * refactor code * fix tests * refactor code && improve performce * chore: change paramster * add register class * update seriable * fix dataset * fix dataset * fix tests * fix tests --------- Co-authored-by: undertaker86001 <windwheelorz@outlook.com>
🌐️ English | 中文
Apache GeaFlow (Incubating) is a distributed streaming graph computing engine originally initiated by Ant Group, and it has since been integrated into the Apache ecosystem. It supports core capabilities such as trillion-level graph storage, hybrid graph and table processing, real-time graph computing, and interactive graph analysis. Currently, it is widely used in scenarios such as data warehouse acceleration, financial risk control, knowledge graph, and social networks etc.
For more information: GeaFlow Introduction
For design paper: GeaFlow: A Graph Extended and Accelerated Dataflow System
Step 1: Package the JAR and submit the Quick Start task
git clone https://github.com/apache/geaflow.git geaflow./build.sh --module=geaflow --output=package./bin/gql_submit.sh --gql geaflow/geaflow-examples/gql/loop_detection_file_demo.sqlStep 2: Launch the console and experience submitting the Quick Start task through the console
./build.sh --module=geaflow-consoledocker run -d --name geaflow-console -p 8888:8888 geaflow-console:0.1For more details:Quick Start。
GeaFlow supports two sets of programming interfaces: DSL and API. You can develop streaming graph computing jobs using GeaFlow‘s SQL extension language SQL+ISO/GQL or use GeaFlow’s high-level API programming interface to develop applications in Java.
GeaFlow supports incremental graph computing capabilities, allowing for continuous streaming incremental graph iterative computing or traversals on dynamic graphs (graphs that are constantly changing). When GeaFlow consumes messages from real-time middleware, the points associated with the real-time data in the current window are activated, triggering iterative graph computing. In each iteration, only the updated points need to notify their neighboring nodes, while unchanged points are not triggered for computing, significantly enhancing the timeliness of the calculations.
In the early days of the industry, there were systems for distributed offline graph computing using Spark GraphX. To support similar engine capabilities, Spark relied on the Spark Streaming framework. However, although this integrated approach can handle streaming consumption of point-edge data, it still requires full graph computings every time a calculation is triggered. This makes it challenging to meet the performance expectations of the business (this approach is also referred to as snapshot-based graph computing).
Using the WCC (Weakly Connected Components) algorithm as an example, we compared the algorithmic execution time of GeaFlow and Spark solutions, with specific performance results as follows: 
Since GeaFlow only activates the vertex-edge relations involved in the current window for incremental computing, the computing time can be completed within seconds, and the computing time for each window remains fairly stable. As the data volume increases, Spark’s need to backtrack through historical data during computing also grows. While the machine capacity has not reached its limit, the computing delay shows a positive correlation with the data volume. In similar conditions, GeaFlow's computing time may slightly increase but can generally still be kept at the level of seconds.
Compared to traditional stream processing engines (such as Flink and Storm, which are based on table models), GeaFlow utilizes a graph as its data model (using a vertex-edge storage format), offering significant performance advantages in handling Join operations, especially for complex multi-hop relationships (like joins exceeding 3 hops and complex cycle searches).
To make a comparison, we analyzed the performance of Flink and GeaFlow using the K-Hop algorithm. K-Hop relationships refer to chains of relationships in which individuals can know each other through K intermediaries. For example, in social networks, K-Hop indicates user relationships connected through K intermediaries. In transaction analysis, K-Hop refers to the path of funds transferred consecutively K times.
In comparing the time consumption of the K-Hop algorithm in Flink and GeaFlow: 
As shown in the figure above, Flink performs slightly better than GeaFlow in one-hop and two-hop scenarios. This is because, in these cases, the data volume involved in the Join calculations is relatively small, and both the left and right tables are compact, resulting in shorter traversal times. Additionally, Flink's computing framework can cache the historical results of Join operations.
Thank you very much for contributing to GeaFlow, whether bug reporting, documentation improvement, or major feature development, we warmly welcome all contributions.
For more information: Contribution.
Contact us through the following mailing list.
| Name | Scope | |||
|---|---|---|---|---|
| dev@geaflow.apache.org | Development-related discussions | Subscribe | Unsubscribe | Archives | 
If you are interested in GeaFlow, please give our project a ⭐️ .
Thanks to some outstanding open-source projects in the industry such as Apache Flink, Apache Spark, and Apache Calcite, some modules of GeaFlow were developed with their references. We would like to express our special gratitude for their contributions. Also, thanks to all the individual developers who have contributed to this repository, which are listed below.
Made with contrib.rocks.