-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathmonitoringjob_utils.py
103 lines (84 loc) · 4.93 KB
/
monitoringjob_utils.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
import os, sys
from urllib.parse import urlparse
from sagemaker.processing import Processor, ProcessingInput, ProcessingOutput
def get_model_monitor_container_uri(region):
container_uri_format = '{0}.dkr.ecr.{1}.amazonaws.com/sagemaker-model-monitor-analyzer'
regions_to_accounts = {
'eu-north-1': '895015795356',
'me-south-1': '607024016150',
'ap-south-1': '126357580389',
'us-east-2': '680080141114',
'us-east-2': '777275614652',
'eu-west-1': '468650794304',
'eu-central-1': '048819808253',
'sa-east-1': '539772159869',
'ap-east-1': '001633400207',
'us-east-1': '156813124566',
'ap-northeast-2': '709848358524',
'eu-west-2': '749857270468',
'ap-northeast-1': '574779866223',
'us-west-2': '159807026194',
'us-west-1': '890145073186',
'ap-southeast-1': '245545462676',
'ap-southeast-2': '563025443158',
'ca-central-1': '536280801234'
}
container_uri = container_uri_format.format(regions_to_accounts[region], region)
return container_uri
def get_file_name(url):
print(url)
a = urlparse(url)
return os.path.basename(a.path)
def run_model_monitor_job_processor(region, instance_type, role, data_capture_path, statistics_path, constraints_path, reports_path,
instance_count=1, preprocessor_path=None, postprocessor_path=None, publish_cloudwatch_metrics='Disabled'):
data_capture_sub_path = data_capture_path[data_capture_path.rfind('datacapture/') :]
data_capture_sub_path = data_capture_sub_path[data_capture_sub_path.find('/') + 1 :]
processing_output_paths = reports_path + '/' + data_capture_sub_path
input_1 = ProcessingInput(input_name='input_1',
source=data_capture_path,
destination='/opt/ml/processing/input/endpoint/' + data_capture_sub_path,
s3_data_type='S3Prefix',
s3_input_mode='File')
baseline = ProcessingInput(input_name='baseline',
source=statistics_path,
destination='/opt/ml/processing/baseline/stats',
s3_data_type='S3Prefix',
s3_input_mode='File')
constraints = ProcessingInput(input_name='constraints',
source=constraints_path,
destination='/opt/ml/processing/baseline/constraints',
s3_data_type='S3Prefix',
s3_input_mode='File')
outputs = ProcessingOutput(output_name='result',
source='/opt/ml/processing/output',
destination=processing_output_paths,
s3_upload_mode='Continuous')
env = {'baseline_constraints': '/opt/ml/processing/baseline/constraints/' + get_file_name(constraints_path),
'baseline_statistics': '/opt/ml/processing/baseline/stats/' + get_file_name(statistics_path),
'dataset_format': '{"sagemakerCaptureJson":{"captureIndexNames":["endpointInput","endpointOutput"]}}',
'dataset_source': '/opt/ml/processing/input/endpoint',
'output_path': '/opt/ml/processing/output',
'publish_cloudwatch_metrics': publish_cloudwatch_metrics }
inputs=[input_1, baseline, constraints]
if postprocessor_path:
env['post_analytics_processor_script'] = '/opt/ml/processing/code/postprocessing/' + get_file_name(postprocessor_path)
post_processor_script = ProcessingInput(input_name='post_processor_script',
source=postprocessor_path,
destination='/opt/ml/processing/code/postprocessing',
s3_data_type='S3Prefix',
s3_input_mode='File')
inputs.append(post_processor_script)
if preprocessor_path:
env['record_preprocessor_script'] = '/opt/ml/processing/code/preprocessing/' + get_file_name(preprocessor_path)
pre_processor_script = ProcessingInput(input_name='pre_processor_script',
source=preprocessor_path,
destination='/opt/ml/processing/code/preprocessing',
s3_data_type='S3Prefix',
s3_input_mode='File')
inputs.append(pre_processor_script)
processor = Processor(image_uri = get_model_monitor_container_uri(region),
instance_count = instance_count,
instance_type = instance_type,
role=role,
env = env)
return processor.run(inputs=inputs, outputs=[outputs])