Skip to content

Commit

Permalink
[GIE/Runtime] Remove the dependency of GIE Runtime on GlobalQueryStor…
Browse files Browse the repository at this point in the history
…e to accelerate the compilation (#2681)

<!--
Thanks for your contribution! please review
https://github.com/alibaba/GraphScope/blob/main/CONTRIBUTING.md before
opening an issue.
-->

## What do these changes do?

<!-- Please give a short brief about these changes. -->

 As titled.

Notice that by default compiling (`cargo build` in ir-core), it won't
depend on `GlobalQuery` anymore. If you want to compile GIE based on
`GlobalQuery` (including Groot and V6d), do `cargo build --features
with_global_query`.

## Related issue number

<!-- Are there any issues opened that will be resolved by merging this
change? -->

Fixes #2679
  • Loading branch information
BingqingLyu authored May 10, 2023
1 parent a46663e commit 909b3c4
Show file tree
Hide file tree
Showing 11 changed files with 26 additions and 15 deletions.
1 change: 1 addition & 0 deletions interactive_engine/compiler/Makefile
Original file line number Diff line number Diff line change
Expand Up @@ -31,6 +31,7 @@ clean:
test:
cd $(CUR_DIR)/../executor/ir && cargo test && \
cd $(CUR_DIR)/../executor/ir && cargo test --features with_v6d && \
cd $(CUR_DIR)/../executor/ir && cargo test --features with_global_query && \
cd $(CUR_DIR) && mvn test

# start rpc server
Expand Down
2 changes: 1 addition & 1 deletion interactive_engine/executor/assembly/groot/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -13,7 +13,7 @@ groot-store = { path = "../../store/groot" }
gaia_pegasus = { path = "../../engine/pegasus/pegasus", package = "pegasus" }
pegasus_network = { path = "../../engine/pegasus/network" }
pegasus_server = { path = "../../engine/pegasus/server" }
runtime_integration = { path = "../../ir/integrated" }
runtime_integration = { path = "../../ir/integrated" , features = ["with_global_query"]}
log = "0.4"
log4rs = "1.2"
tokio = { version = "1.24", features = ["macros", "sync"] }
Expand Down
3 changes: 1 addition & 2 deletions interactive_engine/executor/assembly/v6d/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -20,5 +20,4 @@ global_query = { path = "../../store/global_query" , features = ["with_v6d"] }
pegasus = { path = "../../engine/pegasus/pegasus", package = "pegasus" }
pegasus_network = { path = "../../engine/pegasus/network" }
pegasus_server = { path = "../../engine/pegasus/server" }
runtime_integration = { path = "../../ir/integrated", features = ["with_v6d"] }

runtime_integration = { path = "../../ir/integrated", features = ["with_global_query", "with_v6d"] }
2 changes: 1 addition & 1 deletion interactive_engine/executor/ir/core/src/plan/physical.rs
Original file line number Diff line number Diff line change
Expand Up @@ -19,9 +19,9 @@
//! protobuf structure.
//!
use ir_common::error::ParsePbError;
use std::convert::TryInto;

use ir_common::error::ParsePbError;
use ir_common::expr_parse::str_to_expr_pb;
use ir_common::generated::algebra as pb;
use ir_common::generated::common as common_pb;
Expand Down
5 changes: 3 additions & 2 deletions interactive_engine/executor/ir/graph_proxy/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -10,7 +10,7 @@ log = "0.4"
lazy_static = "1.3.0"
mcsr = {path = "../../store/mcsr"}
graph_store = {path = "../../store/exp_store"}
global_query = {path = "../../store/global_query"}
global_query = {path = "../../store/global_query", optional = true}
dyn_type = { path = "../../common/dyn_type" }
ir_common = {path = "../common"}
pegasus = { path = "../../engine/pegasus/pegasus" }
Expand All @@ -21,4 +21,5 @@ rand = "0.8.5"
[features]
default = []
proto_inplace = ["ir_common/proto_inplace"]
with_v6d = ["global_query/with_v6d"]
with_global_query = ["global_query"]
with_v6d = ["global_query/with_v6d", "with_global_query"]
Original file line number Diff line number Diff line change
Expand Up @@ -29,7 +29,7 @@ use global_query::{
use graph_store::utils::IterList;
use ir_common::{KeyId, LabelId, NameOrId, OneOrMany};

use super::details::{LazyEdgeDetails, LazyVertexDetails};
use crate::adapters::gs_store::details::{LazyEdgeDetails, LazyVertexDetails};
use crate::apis::graph::PKV;
use crate::apis::{
from_fn, register_graph, Direction, DynDetails, Edge, QueryParams, ReadGraph, Statement, Vertex, ID,
Expand Down Expand Up @@ -609,7 +609,7 @@ fn extract_needed_columns(
) -> GraphProxyResult<Option<Vec<PropId>>> {
use ahash::HashSet;

use super::translation::zip_option_vecs;
use crate::adapters::gs_store::translation::zip_option_vecs;

// Some(vec[]) means need all props, so can't merge it with props needed in filter
if let Some(out_columns) = out_columns {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -15,10 +15,14 @@
mod csr_store;
mod exp_store;
#[cfg(feature = "with_global_query")]
mod gs_store;
#[cfg(feature = "with_global_query")]
mod vineyard_store;

pub use csr_store::{create_csr_store, CsrPartition};
pub use exp_store::{create_exp_store, SimplePartition};
#[cfg(feature = "with_global_query")]
pub use gs_store::{create_gs_store, GrootMultiPartition, VineyardMultiPartition};
#[cfg(feature = "with_global_query")]
pub use vineyard_store::VineyardGraphWriter;
7 changes: 3 additions & 4 deletions interactive_engine/executor/ir/graph_proxy/src/lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -17,10 +17,9 @@
extern crate log;
#[macro_use]
extern crate lazy_static;
pub use adapters::{
create_csr_store, create_exp_store, create_gs_store, CsrPartition, GrootMultiPartition,
SimplePartition, VineyardGraphWriter, VineyardMultiPartition,
};
pub use adapters::{create_csr_store, create_exp_store, CsrPartition, SimplePartition};
#[cfg(feature = "with_global_query")]
pub use adapters::{create_gs_store, GrootMultiPartition, VineyardGraphWriter, VineyardMultiPartition};
pub use errors::{GraphProxyError, GraphProxyResult};

mod adapters;
Expand Down
5 changes: 3 additions & 2 deletions interactive_engine/executor/ir/integrated/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -23,10 +23,11 @@ runtime = {path="../runtime"}
graph_proxy = {path = "../graph_proxy"}
graph_store = {path = "../../store/exp_store"}
dyn_type = {path = "../../common/dyn_type"}
global_query = {path = "../../store/global_query"}
global_query = {path = "../../store/global_query", optional = true}

[features]
default = []
proto_inplace = ["ir_common/proto_inplace", "pegasus_server/gcip"]
with_v6d = ["runtime/with_v6d"]
column_filter_push_down = []
with_global_query = ["global_query", "graph_proxy/with_global_query"]
column_filter_push_down = []
4 changes: 4 additions & 0 deletions interactive_engine/executor/ir/integrated/src/assemble/mod.rs
Original file line number Diff line number Diff line change
Expand Up @@ -15,10 +15,14 @@
mod csr;
mod exp;
#[cfg(feature = "with_global_query")]
mod groot;
#[cfg(feature = "with_global_query")]
mod vineyard;

pub use csr::QueryCsrGraph;
pub use exp::QueryExpGraph;
#[cfg(feature = "with_global_query")]
pub use groot::QueryGrootGraph;
#[cfg(feature = "with_global_query")]
pub use vineyard::QueryVineyard;
4 changes: 3 additions & 1 deletion interactive_engine/executor/ir/integrated/src/lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -14,7 +14,9 @@
//! limitations under the License.
mod assemble;
pub use assemble::{QueryCsrGraph, QueryExpGraph, QueryGrootGraph, QueryVineyard};
pub use assemble::{QueryCsrGraph, QueryExpGraph};
#[cfg(feature = "with_global_query")]
pub use assemble::{QueryGrootGraph, QueryVineyard};
use runtime::IRJobAssembly;

pub trait InitializeJobAssembly {
Expand Down

0 comments on commit 909b3c4

Please sign in to comment.