mlflow - 如何将本地 MLflow 运行复制到远程跟踪服务器?
问题描述
我目前正在跟踪我的 MLflow 运行到本地文件路径 URI。我还想设置一个远程跟踪服务器与我的合作者共享。我想避免的一件事是将所有内容记录到服务器,因为它可能很快就会被失败的运行淹没。
理想情况下,我想保留我的本地跟踪器,然后能够只将有希望的运行发送到服务器。
将运行从本地跟踪器复制到远程服务器的推荐方法是什么?
解决方案
要将训练好的模型发布到远程 MLflow 服务器,您应该使用“register_model”API。例如,如果您使用的是 MLflow 的 spacy 风格,您可以如下使用,其中“nlp”是经过训练的模型:
mlflow.spacy.log_model(spacy_model=nlp, artifact_path='mlflow_sample')
model_uri = "runs:/{run_id}/{artifact_path}".format(
run_id=mlflow.active_run().info.run_id, artifact_path='mlflow_sample'
)
mlflow.register_model(model_uri=model_uri, name='mlflow_sample')
确保应设置以下环境变量。在下面的示例中使用 S3 存储:
SET MLFLOW_TRACKING_URI=https://YOUR-REMOTE-MLFLOW-HOST
SET MLFLOW_S3_BUCKET=s3://YOUR-BUCKET-NAME
SET AWS_ACCESS_KEY_ID=YOUR-ACCESS-KEY
SET AWS_SECRET_ACCESS_KEY=YOUR-SECRET-KEY
推荐阅读
- c# - 如何在 C# 中以编程方式输入 DataGridView 单元格?
- azure - .Net Core MVC 中用于安全服务请求的两种方式 SSL X509 证书位置 - Azure 服务托管应用程序
- sql-server - 经典 ASP - SQL 错误停止代码,从不显示
- templates - 为什么在 Laravel 5 应用程序中使用 laravel-mail-preview 插件发送的电子邮件没有被接收者接收?
- android - 设置为墙纸意图对话框?
- android - 禁用系统动画会使 UI 测试失败 Espresso?
- php - 无法插入具有多对多关系的类别类型
- java - Android Java NDK JNI 将对象(包括多级对象数组)传递给 C++
- go - golang中的marshal和Unmarshall错误
- r - 将砖块中的每个栅格图层与数据帧 R 中的值相关联