本文整理匯總了Python中dart.client.python.dart_client.Dart類的典型用法代碼示例。如果您正苦於以下問題:Python Dart類的具體用法?Python Dart怎麽用?Python Dart使用的例子?那麽, 這裏精選的類代碼示例或許可以為您提供幫助。
在下文中一共展示了Dart類的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。
示例1: S3Engine
class S3Engine(object):
def __init__(self, dart_host, dart_port, dart_api_version):
self.dart = Dart(dart_host, dart_port, dart_api_version)
self._action_handlers = {
S3ActionTypes.copy.name: s3_copy
}
def run(self):
action_context = self.dart.engine_action_checkout(os.environ.get('DART_ACTION_ID'))
action = action_context.action
state = ActionResultState.SUCCESS
error_message = None
try:
_logger.info("*** S3Engine.run_action: %s", action.data.action_type_name)
error_message = 'unsupported action: %s' % action.data.action_type_name
assert action.data.action_type_name in self._action_handlers, error_message
handler = self._action_handlers[action.data.action_type_name]
handler(**action.data.args)
except Exception as e:
state = ActionResultState.FAILURE
error_message = e.message + '\n\n\n' + traceback.format_exc()
finally:
self.dart.engine_action_checkin(action.id, ActionResult(state, error_message))
示例2: NoOpEngine
class NoOpEngine(object):
def __init__(self, region, dart_host='localhost', dart_port=5000, dart_api_version=1):
self.region = region
self.dart = Dart(dart_host, dart_port, dart_api_version)
def run(self):
action_context = self.dart.engine_action_checkout(os.environ.get('DART_ACTION_ID'))
action = action_context.action
datastore = action_context.datastore
state = ActionResultState.SUCCESS
error_message = None
try:
sleep_seconds = datastore.data.args['action_sleep_time_in_seconds']
_logger.info('sleeping for %s seconds...' % sleep_seconds)
time.sleep(sleep_seconds)
if action.data.action_type_name == NoOpActionTypes.action_that_fails.name:
state = ActionResultState.FAILURE
error_message = '%s failed as expected' % NoOpActionTypes.action_that_fails.name
if action.data.action_type_name == NoOpActionTypes.consume_subscription.name:
subscription_elements = self.dart.get_subscription_elements(action.id)
_logger.info('consuming subscription, size = %s' % len(list(subscription_elements)))
except Exception as e:
state = ActionResultState.FAILURE
error_message = e.message + '\n\n\n' + traceback.format_exc()
finally:
self.dart.engine_action_checkin(action.id, ActionResult(state, error_message))
示例3: ElasticsearchEngine
class ElasticsearchEngine(object):
def __init__(self, kms_key_arn, secrets_s3_path, dart_host, dart_port, dart_api_version=1):
self.dart = Dart(dart_host, dart_port, dart_api_version)
self._action_handlers = {
ElasticsearchActionTypes.data_check.name: data_check,
ElasticsearchActionTypes.create_index.name: create_index,
ElasticsearchActionTypes.create_template.name: create_template,
ElasticsearchActionTypes.create_mapping.name: create_mapping,
ElasticsearchActionTypes.delete_index.name: delete_index,
ElasticsearchActionTypes.delete_template.name: delete_template,
ElasticsearchActionTypes.force_merge_index.name: force_merge_index,
}
self.secrets = Secrets(kms_key_arn, secrets_s3_path)
def run(self):
action_context = self.dart.engine_action_checkout(os.environ.get('DART_ACTION_ID'))
action = action_context.action
datastore = action_context.datastore
state = ActionResultState.SUCCESS
error_message = None
try:
action_type_name = action.data.action_type_name
_logger.info('**** ElasticsearchEngine.run_action: %s', action_type_name)
assert action_type_name in self._action_handlers, 'unsupported action: %s' % action_type_name
handler = self._action_handlers[action_type_name]
handler(self, datastore, action)
except Exception as e:
state = ActionResultState.FAILURE
error_message = e.message + '\n\n\n' + traceback.format_exc()
finally:
self.dart.engine_action_checkin(action.id, ActionResult(state, error_message))
示例4: S3Engine
class S3Engine(ActionRunner):
def __init__(self, region, dart_host, dart_port, dart_api_version):
super(S3Engine, self).__init__()
self.region = region
self.dart = Dart(dart_host, dart_port, dart_api_version)
self._action_handlers = {
S3ActionTypes.copy.name: copy,
S3ActionTypes.data_check.name: data_check,
}
def run(self):
action_context = self.dart.engine_action_checkout(os.environ.get('DART_ACTION_ID'))
action = action_context.action
datastore = action_context.datastore
state = ActionResultState.SUCCESS
error_message = None
try:
action_type_name = action.data.action_type_name
_logger.info("*** S3Engine.run_action: %s", action_type_name)
assert action_type_name in self._action_handlers, 'unsupported action: %s' % action_type_name
handler = self._action_handlers[action_type_name]
handler(self, datastore, action)
except Exception as e:
state = ActionResultState.FAILURE
error_message = '{m}\r\r\r{t}'.format(
m=str(e.message),
t=traceback.format_exc(),
)
finally:
self.dart.engine_action_checkin(action.id, ActionResult(state, error_message))
self.publish_sns_message(action, error_message, state)
示例5: TestWorkflowCrud
class TestWorkflowCrud(unittest.TestCase):
def setUp(self):
self.dart = Dart(host='localhost', port=5000)
args = {'action_sleep_time_in_seconds': 0}
dst = Datastore(data=DatastoreData('test-datastore', 'no_op_engine', args=args, state=DatastoreState.ACTIVE))
self.datastore = self.dart.save_datastore(dst)
def tearDown(self):
self.dart.delete_datastore(self.datastore.id)
def test_crud(self):
wf = Workflow(data=WorkflowData('test-workflow', self.datastore.id, engine_name='no_op_engine'))
posted_wf = self.dart.save_workflow(wf, self.datastore.id)
self.assertEqual(posted_wf.data.to_dict(), wf.data.to_dict())
workflow = self.dart.get_workflow(posted_wf.id)
self.assertEqual(posted_wf.to_dict(), workflow.to_dict())
workflow.data.concurrency = 2
workflow.data.state = WorkflowState.ACTIVE
put_workflow = self.dart.save_workflow(workflow)
# not all properties can be modified
self.assertEqual(put_workflow.data.concurrency, 1)
self.assertEqual(put_workflow.data.state, WorkflowState.ACTIVE)
self.assertNotEqual(posted_wf.to_dict(), put_workflow.to_dict())
self.dart.delete_workflow(workflow.id)
try:
self.dart.get_workflow(workflow.id)
except DartRequestException as e:
self.assertEqual(e.response.status_code, 404)
return
self.fail('workflow should have been missing after delete!')
示例6: EmrEngine
class EmrEngine(object):
def __init__(self, ec2_keyname, instance_profile, service_role, region, core_node_limit,
impala_docker_repo_base_url, impala_version, cluster_tags, cluster_availability_zone,
dart_host, dart_port, dart_api_version=1):
self._action_handlers = {
EmrActionTypes.start_datastore.name: start_datastore,
EmrActionTypes.terminate_datastore.name: terminate_datastore,
EmrActionTypes.load_dataset.name: load_dataset,
EmrActionTypes.consume_subscription.name: consume_subscription,
EmrActionTypes.run_hive_script_action.name: run_hive_script,
EmrActionTypes.run_impala_script_action.name: run_impala_script,
EmrActionTypes.run_pyspark_script_action.name: run_pyspark_script,
EmrActionTypes.copy_hdfs_to_s3_action.name: copy_hdfs_to_s3,
}
self._region = RegionInfo(self, region, 'elasticmapreduce.%s.amazonaws.com' % region) if region else None
self._conn = None
self.ec2_keyname = ec2_keyname
self.core_node_limit = core_node_limit
self.instance_profile = instance_profile
self.service_role = service_role
self.cluster_tags = cluster_tags
self.cluster_availability_zone = cluster_availability_zone
self.impala_docker_repo_base_url = impala_docker_repo_base_url
self.impala_version = impala_version
self.dart = Dart(dart_host, dart_port, dart_api_version)
@property
def conn(self):
if self._conn:
return self._conn
self._conn = EmrConnection(region=self._region)
return self._conn
def run(self):
action_context = self.dart.engine_action_checkout(os.environ.get('DART_ACTION_ID'))
action = action_context.action
datastore = action_context.datastore
state = ActionResultState.SUCCESS
consume_subscription_state = None
error_message = None
try:
action_type_name = action.data.action_type_name
assert action_type_name in self._action_handlers, 'unsupported action: %s' % action_type_name
handler = self._action_handlers[action_type_name]
handler(self, datastore, action)
except ActionFailedButConsumeSuccessfulException as e:
state = ActionResultState.FAILURE
consume_subscription_state = ConsumeSubscriptionResultState.SUCCESS
error_message = e.message + '\n\n\n' + traceback.format_exc()
except Exception as e:
state = ActionResultState.FAILURE
error_message = e.message + '\n\n\n' + traceback.format_exc()
finally:
self.dart.engine_action_checkin(action.id, ActionResult(state, error_message, consume_subscription_state))
示例7: add_s3_engine
def add_s3_engine(config):
engine_config = config['engines']['s3_engine']
opts = engine_config['options']
dart = Dart(opts['dart_host'], opts['dart_port'], opts['dart_api_version'])
assert isinstance(dart, Dart)
_logger.info('saving s3 engine')
engine_id = None
for e in dart.get_engines():
if e.data.name == 's3_engine':
engine_id = e.id
ecs_task_definition = None if config['dart']['use_local_engines'] else {
'family': 'dart-%s-s3_engine' % config['dart']['env_name'],
'containerDefinitions': [
{
'name': 'dart-s3_engine',
'cpu': 64,
'memory': 256,
'image': engine_config['docker_image'],
'logConfiguration': {'logDriver': 'syslog'},
'environment': [
{'name': 'DART_ROLE', 'value': 'worker:engine_s3'},
{'name': 'DART_CONFIG', 'value': engine_config['config']},
{'name': 'AWS_DEFAULT_REGION', 'value': opts['region']}
],
'mountPoints': [
{
'containerPath': '/mnt/ecs_agent_data',
'sourceVolume': 'ecs-agent-data',
'readOnly': True
}
],
}
],
'volumes': [
{
'host': {'sourcePath': '/var/lib/ecs/data'},
'name': 'ecs-agent-data'
}
],
}
e1 = dart.save_engine(Engine(id=engine_id, data=EngineData(
name='s3_engine',
description='For S3 operations',
options_json_schema={},
supported_action_types=[
S3ActionTypes.copy,
S3ActionTypes.data_check,
],
ecs_task_definition=ecs_task_definition
)))
_logger.info('Saved s3_engine: %s' % e1.id)
示例8: RedshiftEngine
class RedshiftEngine(ActionRunner):
def __init__(self, kms_key_arn, secrets_s3_path, vpc_subnet, security_group_ids,
region, availability_zones, publicly_accessible, cluster_tags,
dart_host, dart_port, dart_api_version=1):
super(RedshiftEngine, self).__init__()
self.dart = Dart(dart_host, dart_port, dart_api_version)
self._action_handlers = {
RedshiftActionTypes.start_datastore.name: start_datastore,
RedshiftActionTypes.stop_datastore.name: stop_datastore,
RedshiftActionTypes.execute_sql.name: execute_sql,
RedshiftActionTypes.load_dataset.name: load_dataset,
RedshiftActionTypes.consume_subscription.name: consume_subscription,
RedshiftActionTypes.copy_to_s3.name: copy_to_s3,
RedshiftActionTypes.create_snapshot.name: create_snapshot,
RedshiftActionTypes.data_check.name: data_check,
RedshiftActionTypes.cluster_maintenance.name: cluster_maintenance,
}
self.vpc_subnet = vpc_subnet
self.availability_zones = availability_zones
self.publicly_accessible = publicly_accessible
self.security_group_ids = security_group_ids
self.cluster_tags = cluster_tags
self.region = region
self.secrets = Secrets(kms_key_arn, secrets_s3_path)
def random_availability_zone(self):
return self.availability_zones[random.randint(0, len(self.availability_zones) - 1)]
def run(self):
action_context = self.dart.engine_action_checkout(os.environ.get('DART_ACTION_ID'))
action = action_context.action
datastore = action_context.datastore
state = ActionResultState.SUCCESS
error_message = None
try:
action_type_name = action.data.action_type_name
_logger.info("**** RedshiftEngine.run_action: %s", action_type_name)
assert action_type_name in self._action_handlers, 'unsupported action: %s' % action_type_name
handler = self._action_handlers[action_type_name]
handler(self, datastore, action)
except Exception as e:
state = ActionResultState.FAILURE
error_message = '{m}\r\r\r{t}'.format(
m=str(e.message),
t=traceback.format_exc(),
)
finally:
self.dart.engine_action_checkin(action.id, ActionResult(state, error_message))
self.publish_sns_message(action, error_message, state)
示例9: __init__
def __init__(self, ec2_keyname, instance_profile, service_role, region, core_node_limit,
impala_docker_repo_base_url, impala_version, cluster_tags, cluster_availability_zone,
dart_host, dart_port, dart_api_version=1):
self._action_handlers = {
EmrActionTypes.start_datastore.name: start_datastore,
EmrActionTypes.terminate_datastore.name: terminate_datastore,
EmrActionTypes.load_dataset.name: load_dataset,
EmrActionTypes.consume_subscription.name: consume_subscription,
EmrActionTypes.run_hive_script_action.name: run_hive_script,
EmrActionTypes.run_impala_script_action.name: run_impala_script,
EmrActionTypes.run_pyspark_script_action.name: run_pyspark_script,
EmrActionTypes.copy_hdfs_to_s3_action.name: copy_hdfs_to_s3,
}
self._region = RegionInfo(self, region, 'elasticmapreduce.%s.amazonaws.com' % region) if region else None
self._conn = None
self.ec2_keyname = ec2_keyname
self.core_node_limit = core_node_limit
self.instance_profile = instance_profile
self.service_role = service_role
self.cluster_tags = cluster_tags
self.cluster_availability_zone = cluster_availability_zone
self.impala_docker_repo_base_url = impala_docker_repo_base_url
self.impala_version = impala_version
self.dart = Dart(dart_host, dart_port, dart_api_version)
示例10: setUp
def setUp(self):
self.dart = Dart(host='localhost', port=5000)
args = {'action_sleep_time_in_seconds': 0}
dst = Datastore(data=DatastoreData('test-datastore', 'no_op_engine', args=args, state=DatastoreState.TEMPLATE))
self.datastore = self.dart.save_datastore(dst)
wf = Workflow(data=WorkflowData('test-workflow', self.datastore.id, state=WorkflowState.ACTIVE))
self.workflow = self.dart.save_workflow(wf, self.datastore.id)
示例11: __init__
def __init__(self, region, dart_host, dart_port, dart_api_version):
self.region = region
self.dart = Dart(dart_host, dart_port, dart_api_version)
self._action_handlers = {
S3ActionTypes.copy.name: copy,
S3ActionTypes.data_check.name: data_check,
}
示例12: setUp
def setUp(self):
self.dart = Dart(host='localhost', port=5000)
args = {'action_sleep_time_in_seconds': 0}
dst = Datastore(data=DatastoreData(name='test-datastore',
engine_name='no_op_engine',
args=args,
state=DatastoreState.ACTIVE))
self.datastore = self.dart.save_datastore(dst)
示例13: setUp
def setUp(self):
self.dart = Dart(host='localhost', port=5000)
args = {'action_sleep_time_in_seconds': 0}
dst = Datastore(data=DatastoreData(name='test-datastore', engine_name='no_op_engine', args=args, state=DatastoreState.TEMPLATE))
self.datastore = self.dart.save_datastore(dst)
wf = Workflow(data=WorkflowData(name='test-workflow', datastore_id=self.datastore.id))
self.workflow = self.dart.save_workflow(workflow=wf, datastore_id=self.datastore.id)
self.maxDiff = 99999
示例14: DynamoDBEngine
class DynamoDBEngine(ActionRunner):
def __init__(self, emr_ec2_keyname, emr_instance_profile, emr_service_role, emr_region, emr_core_node_limit,
emr_impala_docker_repo_base_url, emr_impala_version, emr_cluster_tags, emr_cluster_availability_zone,
dart_host, dart_port, dart_api_version=1, emr_release_label='emr-4.2.0',
emr_instance_type='m3.2xlarge'):
super(DynamoDBEngine, self).__init__()
self.emr_release_label = emr_release_label
self.emr_instance_type = emr_instance_type
self._action_handlers = {
DynamoDBActionTypes.create_table.name: create_table,
DynamoDBActionTypes.delete_table.name: delete_table,
DynamoDBActionTypes.load_dataset.name: load_dataset,
}
self.emr_engine = EmrEngine(
emr_ec2_keyname, emr_instance_profile, emr_service_role, emr_region, emr_core_node_limit,
emr_impala_docker_repo_base_url, emr_impala_version, emr_cluster_tags, emr_cluster_availability_zone,
dart_host, dart_port, dart_api_version
)
self.dart = Dart(dart_host, dart_port, dart_api_version)
def run(self):
action_context = self.dart.engine_action_checkout(os.environ.get('DART_ACTION_ID'))
action = action_context.action
datastore = action_context.datastore
state = ActionResultState.SUCCESS
consume_subscription_state = None
error_message = None
try:
action_type_name = action.data.action_type_name
assert action_type_name in self._action_handlers, 'unsupported action: %s' % action_type_name
handler = self._action_handlers[action_type_name]
handler(self, datastore, action)
except Exception as e:
state = ActionResultState.FAILURE
error_message = '{m}\r\r\r{t}'.format(
m=str(e.message),
t=traceback.format_exc(),
)
finally:
self.dart.engine_action_checkin(action.id, ActionResult(state, error_message, consume_subscription_state))
self.publish_sns_message(action, error_message, state)
示例15: TestDatasetCrud
class TestDatasetCrud(unittest.TestCase):
def setUp(self):
self.dart = Dart(host='localhost', port=5000)
def test_crud(self):
columns = [Column('c1', DataType.VARCHAR, 50), Column('c2', DataType.BIGINT)]
df = DataFormat(FileFormat.PARQUET, RowFormat.NONE)
ds = Dataset(
data=DatasetData(name=NoOpActionTypes.action_that_succeeds.name,
table_name=NoOpActionTypes.action_that_succeeds.name,
load_type=LoadType.INSERT,
location='s3://bucket/prefix',
data_format=df,
columns=columns,
tags=['foo']))
ds.data.user_id = '[email protected]'
posted_dataset = self.dart.save_dataset(ds)
self.assertEqual(posted_dataset.data.to_dict(), ds.data.to_dict())
dataset = self.dart.get_dataset(posted_dataset.id)
self.assertEqual(posted_dataset.to_dict(), dataset.to_dict())
dataset.data.compression = Compression.GZIP
put_dataset = self.dart.save_dataset(dataset)
self.assertEqual(put_dataset.data.compression, Compression.GZIP)
self.assertNotEqual(posted_dataset.to_dict(), put_dataset.to_dict())
self.dart.delete_dataset(dataset.id)
try:
self.dart.get_dataset(dataset.id)
except DartRequestException as e:
self.assertEqual(e.response.status_code, 404)
return
self.fail('dataset should have been missing after delete!')