The congress.dse2.data_service Module¶
- 
class congress.dse2.data_service.DataService(service_id)¶
- Bases: - object- A unit of data and business logic that interfaces with the DSE. - A DataService may publish tables, subscribe to tables, and/or expose RPCs on the DSE. DataService instances are bound to a DseNode which is used for all inter-service communication. - Attributes:
- service_id: A unique ID of the service. _published_tables_with_subscriber: A set of tables published by self that has subscribers
 - 
add_rpc_endpoint(endpt)¶
 - 
check_resub_all()¶
- Check all subscriptions for long missing update and resubscribe. 
 - 
get_datasource(datasource_id)¶
 - 
get_datasources(filter_secret=False)¶
 - 
get_driver_info(*args)¶
 - 
get_driver_schema(*args)¶
 - 
get_drivers_info(*args)¶
 - 
get_last_published_data_with_seqnum(table)¶
- Method that returns the current seqnum & data for given table. 
 - 
get_snapshot(table)¶
- Method that returns the current data for the given table. - Should be overridden. 
 - 
info¶
 - 
is_valid_service(service_id)¶
 - 
make_datasource_dict(*args, **kwargs)¶
 - 
publish(table, data, use_snapshot=True)¶
 - 
receive_data(publisher, table, data, is_snapshot=True)¶
- Method called when publication data arrives. - Instances will override this method. 
 - 
receive_data_sequenced(publisher, table, data, seqnum, is_snapshot=False, receipt_time=None)¶
- Method called when sequenced publication data arrives. 
 - 
rpc(service, action, kwargs=None, timeout=None, local=False, retry=None)¶
 - 
rpc_endpoints()¶
- Return list of RPC endpoint objects to be exposed for this service. - A DataService may include zero or more RPC endpoints to be exposed by the DseNode. Each endpoint object must be compatible with the oslo.messaging RPC Server. 
 - 
start()¶
- Start the DataService. - This method is called by a DseNode before any RPCs are invoked. 
 - 
status¶
 - 
stop()¶
- Stop the DataService. - This method is called by a DseNode when the DataService instance is no longer needed. No RPCs will invoked on stopped DataServices. 
 - 
subscribe(service, table)¶
 - 
subscriber_list()¶
- Method that returns subscribers list. - It returns list of services subscribed to this service data. 
 - 
subscription_list()¶
- Method that returns subscription list. - It returns list of tuple that represents the service’s subscription. The tuple forms following format: (service_id, table_name). 
 - 
unsubscribe(service, table)¶
 - 
wait()¶
- Wait for processing to complete. - After a call to stop(), the DataService may have some outstanding work that has not yet completed. The wait() method blocks until all DataService processing is complete. 
 
- 
class congress.dse2.data_service.DataServiceEndPoints(service)¶
- Bases: - object- 
get_last_published_data_with_seqnum(context, table)¶
- Function called on a node when an RPC request is sent. 
 - 
get_snapshot(context, table)¶
- Function called on a node when an RPC request is sent. 
 - 
ping(client_ctxt, **args)¶
- Echo args 
 
- 
- 
class congress.dse2.data_service.DataServiceInfo(service_id=None, node_id=None, published_tables=None, subscribed_tables=None, rpc_endpoints_info=None)¶
- Bases: - object- Metadata for DataService on the DSE. - Attributes:
- service_id: The ID of the service. node_id: The ID of the node the service is running on. published_tables: List of table IDs published by this service. subscribed_tables: List of table IDs this service subscribes to. rpc_endpoints_info: List of RPC endpoints exposed by this service.
 - 
MARSHALL_ATTRS= set([‘published_tables’, ‘subscribed_tables’, ‘service_id’, ‘rpc_endpoints_info’, ‘node_id’])¶
 - 
classmethod from_dict(raw_dict)¶
 - 
classmethod from_json(json_string)¶
 - 
to_dict()¶
 - 
to_json()¶