pub struct FlownodeContext {
pub source_to_tasks: BTreeMap<TableId, BTreeSet<u64>>,
pub flow_to_sink: BTreeMap<u64, [String; 3]>,
pub flow_plans: BTreeMap<u64, TypedPlan>,
pub sink_to_flow: BTreeMap<[String; 3], u64>,
pub source_sender: BTreeMap<TableId, SourceSender>,
pub sink_receiver: BTreeMap<[String; 3], (UnboundedSender<Batch>, UnboundedReceiver<Batch>)>,
pub table_source: Box<dyn FlowTableSource>,
pub table_repr: IdToNameMap,
pub query_context: Option<Arc<QueryContext>>,
}
Expand description
A context that holds the information of the dataflow
Fields§
§source_to_tasks: BTreeMap<TableId, BTreeSet<u64>>
mapping from source table to tasks, useful for schedule which task to run when a source table is updated
flow_to_sink: BTreeMap<u64, [String; 3]>
mapping from task to sink table, useful for sending data back to the client when a task is done running
flow_plans: BTreeMap<u64, TypedPlan>
§sink_to_flow: BTreeMap<[String; 3], u64>
§source_sender: BTreeMap<TableId, SourceSender>
broadcast sender for source table, any incoming write request will be sent to the source table’s corresponding sender
Note that we are getting insert requests with table id, so we should use table id as the key
sink_receiver: BTreeMap<[String; 3], (UnboundedSender<Batch>, UnboundedReceiver<Batch>)>
broadcast receiver for sink table, there should only be one receiver, and it will receive all the data from the sink table
and send it back to the client, since we are mocking the sink table as a client, we should use table name as the key note that the sink receiver should only have one, and we are using broadcast as mpsc channel here
table_source: Box<dyn FlowTableSource>
can query the schema of the table source, from metasrv with local cache
table_repr: IdToNameMap
All the tables that have been registered in the worker
query_context: Option<Arc<QueryContext>>
Implementations§
Source§impl FlownodeContext
impl FlownodeContext
pub fn new(table_source: Box<dyn FlowTableSource>) -> Self
pub fn get_flow_ids(&self, table_id: TableId) -> Option<&BTreeSet<u64>>
Source§impl FlownodeContext
impl FlownodeContext
Sourcepub async fn send(
&self,
table_id: TableId,
rows: Vec<(Row, i64, i64)>,
batch_datatypes: &[ConcreteDataType],
) -> Result<usize, Error>
pub async fn send( &self, table_id: TableId, rows: Vec<(Row, i64, i64)>, batch_datatypes: &[ConcreteDataType], ) -> Result<usize, Error>
return number of rows it actual send(including what’s in the buffer)
TODO(discord9): make this concurrent
pub async fn send_rb( &self, table_id: TableId, batch: RecordBatch, ) -> Result<usize, Error>
Sourcepub async fn flush_all_sender(&self) -> Result<usize, Error>
pub async fn flush_all_sender(&self) -> Result<usize, Error>
flush all sender’s buf
return numbers being sent
Source§impl FlownodeContext
impl FlownodeContext
Sourcepub fn register_task_src_sink(
&mut self,
task_id: u64,
source_table_ids: &[TableId],
sink_table_name: [String; 3],
)
pub fn register_task_src_sink( &mut self, task_id: u64, source_table_ids: &[TableId], sink_table_name: [String; 3], )
mapping source table to task, and sink table to task in worker context
also add their corresponding broadcast sender/receiver
Sourcepub fn add_flow_plan(&mut self, task_id: u64, plan: TypedPlan)
pub fn add_flow_plan(&mut self, task_id: u64, plan: TypedPlan)
add flow plan to worker context
pub fn get_flow_plan(&self, task_id: &u64) -> Option<TypedPlan>
Sourcepub fn remove_flow(&mut self, task_id: u64)
pub fn remove_flow(&mut self, task_id: u64)
remove flow from worker context
Sourcepub fn add_source_sender_if_not_exist(&mut self, table_id: TableId)
pub fn add_source_sender_if_not_exist(&mut self, table_id: TableId)
try add source sender, if already exist, do nothing
pub fn add_sink_receiver(&mut self, table_name: [String; 3])
pub fn get_source_by_global_id( &self, id: &GlobalId, ) -> Result<&SourceSender, Error>
pub fn get_sink_by_global_id( &self, id: &GlobalId, ) -> Result<UnboundedSender<Batch>, Error>
Source§impl FlownodeContext
impl FlownodeContext
Sourcepub async fn table(
&self,
name: &[String; 3],
) -> Result<(GlobalId, RelationDesc), Error>
pub async fn table( &self, name: &[String; 3], ) -> Result<(GlobalId, RelationDesc), Error>
Retrieves a GlobalId and table schema representing a table previously registered by calling the [register_table] function.
Returns an error if no table has been registered with the provided names
Sourcepub async fn assign_global_id_to_table(
&mut self,
srv_map: &ManagedTableSource,
table_name: Option<[String; 3]>,
table_id: Option<TableId>,
) -> Result<GlobalId, Error>
pub async fn assign_global_id_to_table( &mut self, srv_map: &ManagedTableSource, table_name: Option<[String; 3]>, table_id: Option<TableId>, ) -> Result<GlobalId, Error>
Assign a global id to a table, if already assigned, return the existing global id
require at least one of table_name
or table_id
to be Some
and will try to fetch the schema from table info manager(if table exist now)
NOTE: this will not actually render the table into collection referred as GlobalId merely creating a mapping from table id to global id
Sourcepub fn new_global_id(&self) -> GlobalId
pub fn new_global_id(&self) -> GlobalId
Get a new global id
Trait Implementations§
Auto Trait Implementations§
impl Freeze for FlownodeContext
impl !RefUnwindSafe for FlownodeContext
impl Send for FlownodeContext
impl Sync for FlownodeContext
impl Unpin for FlownodeContext
impl !UnwindSafe for FlownodeContext
Blanket Implementations§
Source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
§impl<T> Conv for T
impl<T> Conv for T
§impl<T, V> Convert<T> for Vwhere
V: Into<T>,
impl<T, V> Convert<T> for Vwhere
V: Into<T>,
fn convert(value: Self) -> T
fn convert_box(value: Box<Self>) -> Box<T>
fn convert_vec(value: Vec<Self>) -> Vec<T>
fn convert_vec_box(value: Vec<Box<Self>>) -> Vec<Box<T>>
fn convert_matrix(value: Vec<Vec<Self>>) -> Vec<Vec<T>>
fn convert_option(value: Option<Self>) -> Option<T>
fn convert_option_box(value: Option<Box<Self>>) -> Option<Box<T>>
fn convert_option_vec(value: Option<Vec<Self>>) -> Option<Vec<T>>
§impl<Choices> CoproductSubsetter<CNil, HNil> for Choices
impl<Choices> CoproductSubsetter<CNil, HNil> for Choices
§impl<T> FmtForward for T
impl<T> FmtForward for T
§fn fmt_binary(self) -> FmtBinary<Self>where
Self: Binary,
fn fmt_binary(self) -> FmtBinary<Self>where
Self: Binary,
self
to use its Binary
implementation when Debug
-formatted.§fn fmt_display(self) -> FmtDisplay<Self>where
Self: Display,
fn fmt_display(self) -> FmtDisplay<Self>where
Self: Display,
self
to use its Display
implementation when
Debug
-formatted.§fn fmt_lower_exp(self) -> FmtLowerExp<Self>where
Self: LowerExp,
fn fmt_lower_exp(self) -> FmtLowerExp<Self>where
Self: LowerExp,
self
to use its LowerExp
implementation when
Debug
-formatted.§fn fmt_lower_hex(self) -> FmtLowerHex<Self>where
Self: LowerHex,
fn fmt_lower_hex(self) -> FmtLowerHex<Self>where
Self: LowerHex,
self
to use its LowerHex
implementation when
Debug
-formatted.§fn fmt_octal(self) -> FmtOctal<Self>where
Self: Octal,
fn fmt_octal(self) -> FmtOctal<Self>where
Self: Octal,
self
to use its Octal
implementation when Debug
-formatted.§fn fmt_pointer(self) -> FmtPointer<Self>where
Self: Pointer,
fn fmt_pointer(self) -> FmtPointer<Self>where
Self: Pointer,
self
to use its Pointer
implementation when
Debug
-formatted.§fn fmt_upper_exp(self) -> FmtUpperExp<Self>where
Self: UpperExp,
fn fmt_upper_exp(self) -> FmtUpperExp<Self>where
Self: UpperExp,
self
to use its UpperExp
implementation when
Debug
-formatted.§fn fmt_upper_hex(self) -> FmtUpperHex<Self>where
Self: UpperHex,
fn fmt_upper_hex(self) -> FmtUpperHex<Self>where
Self: UpperHex,
self
to use its UpperHex
implementation when
Debug
-formatted.§fn fmt_list(self) -> FmtList<Self>where
&'a Self: for<'a> IntoIterator,
fn fmt_list(self) -> FmtList<Self>where
&'a Self: for<'a> IntoIterator,
§impl<T> FutureExt for T
impl<T> FutureExt for T
§fn with_context(self, otel_cx: Context) -> WithContext<Self>
fn with_context(self, otel_cx: Context) -> WithContext<Self>
§fn with_current_context(self) -> WithContext<Self>
fn with_current_context(self) -> WithContext<Self>
§impl<T> FutureExt for T
impl<T> FutureExt for T
§fn with_context(self, otel_cx: Context) -> WithContext<Self>
fn with_context(self, otel_cx: Context) -> WithContext<Self>
§fn with_current_context(self) -> WithContext<Self>
fn with_current_context(self) -> WithContext<Self>
§impl<T> Instrument for T
impl<T> Instrument for T
§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
§fn in_current_span(self) -> Instrumented<Self>
fn in_current_span(self) -> Instrumented<Self>
Source§impl<T> IntoEither for T
impl<T> IntoEither for T
Source§fn into_either(self, into_left: bool) -> Either<Self, Self>
fn into_either(self, into_left: bool) -> Either<Self, Self>
self
into a Left
variant of Either<Self, Self>
if into_left
is true
.
Converts self
into a Right
variant of Either<Self, Self>
otherwise. Read moreSource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
self
into a Left
variant of Either<Self, Self>
if into_left(&self)
returns true
.
Converts self
into a Right
variant of Either<Self, Self>
otherwise. Read moreSource§impl<T> IntoRequest<T> for T
impl<T> IntoRequest<T> for T
Source§fn into_request(self) -> Request<T>
fn into_request(self) -> Request<T>
T
in a tonic::Request
Source§impl<T> IntoRequest<T> for T
impl<T> IntoRequest<T> for T
Source§fn into_request(self) -> Request<T>
fn into_request(self) -> Request<T>
T
in a tonic::Request
§impl<T, U, I> LiftInto<U, I> for Twhere
U: LiftFrom<T, I>,
impl<T, U, I> LiftInto<U, I> for Twhere
U: LiftFrom<T, I>,
§impl<T> Pipe for Twhere
T: ?Sized,
impl<T> Pipe for Twhere
T: ?Sized,
§fn pipe<R>(self, func: impl FnOnce(Self) -> R) -> Rwhere
Self: Sized,
fn pipe<R>(self, func: impl FnOnce(Self) -> R) -> Rwhere
Self: Sized,
§fn pipe_ref<'a, R>(&'a self, func: impl FnOnce(&'a Self) -> R) -> Rwhere
R: 'a,
fn pipe_ref<'a, R>(&'a self, func: impl FnOnce(&'a Self) -> R) -> Rwhere
R: 'a,
self
and passes that borrow into the pipe function. Read more§fn pipe_ref_mut<'a, R>(&'a mut self, func: impl FnOnce(&'a mut Self) -> R) -> Rwhere
R: 'a,
fn pipe_ref_mut<'a, R>(&'a mut self, func: impl FnOnce(&'a mut Self) -> R) -> Rwhere
R: 'a,
self
and passes that borrow into the pipe function. Read more§fn pipe_borrow<'a, B, R>(&'a self, func: impl FnOnce(&'a B) -> R) -> R
fn pipe_borrow<'a, B, R>(&'a self, func: impl FnOnce(&'a B) -> R) -> R
§fn pipe_borrow_mut<'a, B, R>(
&'a mut self,
func: impl FnOnce(&'a mut B) -> R,
) -> R
fn pipe_borrow_mut<'a, B, R>( &'a mut self, func: impl FnOnce(&'a mut B) -> R, ) -> R
§fn pipe_as_ref<'a, U, R>(&'a self, func: impl FnOnce(&'a U) -> R) -> R
fn pipe_as_ref<'a, U, R>(&'a self, func: impl FnOnce(&'a U) -> R) -> R
self
, then passes self.as_ref()
into the pipe function.§fn pipe_as_mut<'a, U, R>(&'a mut self, func: impl FnOnce(&'a mut U) -> R) -> R
fn pipe_as_mut<'a, U, R>(&'a mut self, func: impl FnOnce(&'a mut U) -> R) -> R
self
, then passes self.as_mut()
into the pipe
function.§fn pipe_deref<'a, T, R>(&'a self, func: impl FnOnce(&'a T) -> R) -> R
fn pipe_deref<'a, T, R>(&'a self, func: impl FnOnce(&'a T) -> R) -> R
self
, then passes self.deref()
into the pipe function.§impl<T> Pointable for T
impl<T> Pointable for T
§impl<T> PolicyExt for Twhere
T: ?Sized,
impl<T> PolicyExt for Twhere
T: ?Sized,
§impl<Source> Sculptor<HNil, HNil> for Source
impl<Source> Sculptor<HNil, HNil> for Source
§impl<SS, SP> SupersetOf<SS> for SPwhere
SS: SubsetOf<SP>,
impl<SS, SP> SupersetOf<SS> for SPwhere
SS: SubsetOf<SP>,
§fn to_subset(&self) -> Option<SS>
fn to_subset(&self) -> Option<SS>
self
from the equivalent element of its
superset. Read more§fn is_in_subset(&self) -> bool
fn is_in_subset(&self) -> bool
self
is actually part of its subset T
(and can be converted to it).§fn to_subset_unchecked(&self) -> SS
fn to_subset_unchecked(&self) -> SS
self.to_subset
but without any property checks. Always succeeds.§fn from_subset(element: &SS) -> SP
fn from_subset(element: &SS) -> SP
self
to the equivalent element of its superset.§impl<T> Tap for T
impl<T> Tap for T
§fn tap_borrow<B>(self, func: impl FnOnce(&B)) -> Self
fn tap_borrow<B>(self, func: impl FnOnce(&B)) -> Self
Borrow<B>
of a value. Read more§fn tap_borrow_mut<B>(self, func: impl FnOnce(&mut B)) -> Self
fn tap_borrow_mut<B>(self, func: impl FnOnce(&mut B)) -> Self
BorrowMut<B>
of a value. Read more§fn tap_ref<R>(self, func: impl FnOnce(&R)) -> Self
fn tap_ref<R>(self, func: impl FnOnce(&R)) -> Self
AsRef<R>
view of a value. Read more§fn tap_ref_mut<R>(self, func: impl FnOnce(&mut R)) -> Self
fn tap_ref_mut<R>(self, func: impl FnOnce(&mut R)) -> Self
AsMut<R>
view of a value. Read more§fn tap_deref<T>(self, func: impl FnOnce(&T)) -> Self
fn tap_deref<T>(self, func: impl FnOnce(&T)) -> Self
Deref::Target
of a value. Read more§fn tap_deref_mut<T>(self, func: impl FnOnce(&mut T)) -> Self
fn tap_deref_mut<T>(self, func: impl FnOnce(&mut T)) -> Self
Deref::Target
of a value. Read more§fn tap_dbg(self, func: impl FnOnce(&Self)) -> Self
fn tap_dbg(self, func: impl FnOnce(&Self)) -> Self
.tap()
only in debug builds, and is erased in release builds.§fn tap_mut_dbg(self, func: impl FnOnce(&mut Self)) -> Self
fn tap_mut_dbg(self, func: impl FnOnce(&mut Self)) -> Self
.tap_mut()
only in debug builds, and is erased in release
builds.§fn tap_borrow_dbg<B>(self, func: impl FnOnce(&B)) -> Self
fn tap_borrow_dbg<B>(self, func: impl FnOnce(&B)) -> Self
.tap_borrow()
only in debug builds, and is erased in release
builds.§fn tap_borrow_mut_dbg<B>(self, func: impl FnOnce(&mut B)) -> Self
fn tap_borrow_mut_dbg<B>(self, func: impl FnOnce(&mut B)) -> Self
.tap_borrow_mut()
only in debug builds, and is erased in release
builds.§fn tap_ref_dbg<R>(self, func: impl FnOnce(&R)) -> Self
fn tap_ref_dbg<R>(self, func: impl FnOnce(&R)) -> Self
.tap_ref()
only in debug builds, and is erased in release
builds.§fn tap_ref_mut_dbg<R>(self, func: impl FnOnce(&mut R)) -> Self
fn tap_ref_mut_dbg<R>(self, func: impl FnOnce(&mut R)) -> Self
.tap_ref_mut()
only in debug builds, and is erased in release
builds.§fn tap_deref_dbg<T>(self, func: impl FnOnce(&T)) -> Self
fn tap_deref_dbg<T>(self, func: impl FnOnce(&T)) -> Self
.tap_deref()
only in debug builds, and is erased in release
builds.