Model.get_model_path(model_name="model") выдает ошибку: модель не найдена в кэше или в корневом каталоге
У меня есть модель, которую я зарегистрировал с конвейером:
register_step = PythonScriptStep(name = "Register Model",
source_directory = training_folder,
script_name = "register_model.py",
arguments = ['--model_folder', model_folder],
inputs=[model_folder],
compute_target = pipeline_cluster,
runconfig = pipeline_run_config,
allow_reuse = True)
А вот и мой register_model.py:
import argparse
import joblib
from azureml.core import Workspace, Model, Run
# Get parameters
parser = argparse.ArgumentParser()
parser.add_argument('--model_folder', type=str, dest='model_folder', default="model", help='model location')
args = parser.parse_args()
model_folder = args.model_folder
# Get the experiment run context
run = Run.get_context()
# Load the model
print("Loading model from " + model_folder)
model_file = model_folder + "/model.pkl"
model = joblib.load(model_file)
Model.register(workspace=run.experiment.workspace,
model_path = model_file,
model_name = 'model',
tags={'Training context':'Pipeline'})
run.complete()
Я вижу, что модель зарегистрирована, когда я зацикливаю существующие модели, используя следующее:
from azureml.core import Model
for model in Model.list(ws):
print(model.name, 'version:', model.version)
for tag_name in model.tags:
tag = model.tags[tag_name]
print ('\t',tag_name, ':', tag)
for prop_name in model.properties:
prop = model.properties[prop_name]
print ('\t',prop_name, ':', prop)
print('\n')
Однако, когда я пытаюсь загрузить модель в свой Score.py (ниже), чтобы развернуть модель как службу, я получаю следующую ошибку:
Я считаю, что это ошибка:
model_path = Model.get_model_path(
model_name="model", version=1)
Ошибка:
ModelNotFoundException Traceback (most recent call last)
/anaconda/envs/azureml_py36/lib/python3.6/site-packages/azureml/core/model.py in get_model_path(model_name, version, _workspace)
751 try:
--> 752 return Model._get_model_path_local(model_name, version)
753 except ModelNotFoundException as ee:
/anaconda/envs/azureml_py36/lib/python3.6/site-packages/azureml/core/model.py in _get_model_path_local(model_name, version)
783 if not os.path.exists(candidate_model_path):
--> 784 return Model._get_model_path_local_from_root(model_name)
785 else:
/anaconda/envs/azureml_py36/lib/python3.6/site-packages/azureml/core/model.py in _get_model_path_local_from_root(model_name)
826 raise ModelNotFoundException("Model not found in cache or in root at ./{}. For more info,"
--> 827 "set logging level to DEBUG.".format(candidate_model_path))
828
ModelNotFoundException: ModelNotFoundException:
Message: Model not found in cache or in root at ./model. For more info,set logging level to DEBUG.
InnerException None
ErrorResponse
{
"error": {
"message": "Model not found in cache or in root at ./model. For more info,set logging level to DEBUG."
}
}
During handling of the above exception, another exception occurred:
WebserviceException Traceback (most recent call last)
<ipython-input-6-27e8df94d66f> in <module>
1 model_path = Model.get_model_path(
----> 2 model_name="model", version=1)
/anaconda/envs/azureml_py36/lib/python3.6/site-packages/azureml/core/model.py in get_model_path(model_name, version, _workspace)
756 module_logger.debug("Getting model from remote")
757 return Model._get_model_path_remote(model_name, version, active_workspace)
--> 758 raise WebserviceException(ee.message, logger=module_logger)
759 else:
760 if active_workspace is not None:
WebserviceException: WebserviceException:
Message: Model not found in cache or in root at ./model. For more info,set logging level to DEBUG.
InnerException None
ErrorResponse
{
"error": {
"message": "Model not found in cache or in root at ./model. For more info,set logging level to DEBUG."
}
}
3 ответа
#Assume model_name is the variable containing name of your model
model_name = 'model'
ws = Run.get_context().experiment.workspace
model_obj = Model(ws, model_name )
model_path = model_obj.download(exist_ok = True)
model = joblib.load(model_path)
Вам необходимо указать объект рабочей области, как показано ниже.
Model.get_model_path(model_name = 'model', version=1, _workspace=ws)
Извините за эту неприятность. Я не уверен, что происходит в вашем конкретном случае, но можете ли вы пока попробовать использовать AZUREML_MODEL_DIR? https://docs.microsoft.com/en-us/azure/machine-learning/how-to-deploy-advanced-entry-script#load-registered-models