欧美一区二区三区老妇人-欧美做爰猛烈大尺度电-99久久夜色精品国产亚洲a-亚洲福利视频一区二区

mlflow的搭建使用是怎樣的

mlflow的搭建使用是怎樣的,相信很多沒(méi)有經(jīng)驗(yàn)的人對(duì)此束手無(wú)策,為此本文總結(jié)了問(wèn)題出現(xiàn)的原因和解決方法,通過(guò)這篇文章希望你能解決這個(gè)問(wèn)題。

10年的土默特右旗網(wǎng)站建設(shè)經(jīng)驗(yàn),針對(duì)設(shè)計(jì)、前端、開(kāi)發(fā)、售后、文案、推廣等六對(duì)一服務(wù),響應(yīng)快,48小時(shí)及時(shí)工作處理。網(wǎng)絡(luò)營(yíng)銷(xiāo)推廣的優(yōu)勢(shì)是能夠根據(jù)用戶(hù)設(shè)備顯示端的尺寸不同,自動(dòng)調(diào)整土默特右旗建站的顯示方式,使網(wǎng)站能夠適用不同顯示終端,在瀏覽器中調(diào)整網(wǎng)站的寬度,無(wú)論在任何一種瀏覽器上瀏覽網(wǎng)站,都能展現(xiàn)優(yōu)雅布局與設(shè)計(jì),從而大程度地提升瀏覽體驗(yàn)。創(chuàng)新互聯(lián)從事“土默特右旗網(wǎng)站設(shè)計(jì)”,“土默特右旗網(wǎng)站推廣”以來(lái),每個(gè)客戶(hù)項(xiàng)目都認(rèn)真落實(shí)執(zhí)行。

背景

mlflow是Databrick開(kāi)源的機(jī)器學(xué)習(xí)管理平臺(tái),它很好的解藕了算法訓(xùn)練和算法模型服務(wù),使得算法工程師專(zhuān)注于模型的訓(xùn)練,而不需要過(guò)多的關(guān)注于服務(wù)的,
而且在我們公司已經(jīng)有十多個(gè)服務(wù)穩(wěn)定運(yùn)行了兩年多。

搭建

mlflow的搭建主要是mlflow tracking server的搭建,tracking server主要是用于模型的元數(shù)據(jù)以及模型的數(shù)據(jù)存儲(chǔ)
我們這次以minio作為模型數(shù)據(jù)的存儲(chǔ)后臺(tái),MySQL作為模型元數(shù)據(jù)的存儲(chǔ),因?yàn)檫@種模式能滿(mǎn)足線(xiàn)上的需求,不僅僅是用于測(cè)試

  • minio的搭建
    MinIO的搭建使用,并且創(chuàng)建名為mlflow的bucket,便于后續(xù)操作

  • mlflow的搭建

    # 創(chuàng)建conda環(huán)境 并安裝 python 3.6  
    conda create -n mlflow-1.11.0 python==3.6
    #激活conda環(huán)境
    conda activate mlflow-1.11.0
    # 安裝mlfow tracking server python需要的依賴(lài)包
    pip install mlflow==1.11.0 
    pip install mysqlclient
    pip install boto3

     

    暴露出minio url以及需要的ID和KEY,因?yàn)閙lflow tracking server在上傳模型文件時(shí)需要   
    export AWS_ACCESS_KEY_ID=AKIAIOSFODNN7EXAMPLE
    export AWS_SECRET_ACCESS_KEY=wJalrXUtnFEMI/K7MDENG/bPxRfiCYEXAMPLEKEY
    export MLFLOW_S3_ENDPOINT_URL=http://localhost:9001
    mlflow server \
       --backend-store-uri mysql://root:AO,h07ObIeH-@localhost/mlflow_test \
       --host 0.0.0.0 -p 5002 \
       --default-artifact-root s3://mlflow

    訪(fǎng)問(wèn)localhost:5002, 就能看到如下界面:
    mlflow的搭建使用是怎樣的

    • mlflow tracking server的啟動(dòng)

    • conda的安裝
      參照install conda,根據(jù)自己的系統(tǒng)安裝不同的conda環(huán)境

    • mlfow tracking server安裝

使用

拷貝以下的wine.py文件

import os
import warnings
import sys

import pandas as pd
import numpy as np
from sklearn.metrics import mean_squared_error, mean_absolute_error, r2_score
from sklearn.model_selection import train_test_split
from sklearn.linear_model import ElasticNet
import mlflow.sklearn


def eval_metrics(actual, pred):
  rmse = np.sqrt(mean_squared_error(actual, pred))
  mae = mean_absolute_error(actual, pred)
  r2 = r2_score(actual, pred)
  return rmse, mae, r2


if __name__ == "__main__":
  warnings.filterwarnings("ignore")
  np.random.seed(40)

  # Read the wine-quality csv file (make sure you're running this from the root of MLflow!)
  wine_path = os.path.join(os.path.dirname(os.path.abspath(__file__)), "wine-quality.csv")
  data = pd.read_csv(wine_path)

  # Split the data into training and test sets. (0.75, 0.25) split.
  train, test = train_test_split(data)

  # The predicted column is "quality" which is a scalar from [3, 9]
  train_x = train.drop(["quality"], axis=1)
  test_x = test.drop(["quality"], axis=1)
  train_y = train[["quality"]]
  test_y = test[["quality"]]

  alpha = float(sys.argv[1]) if len(sys.argv) > 1 else 0.5
  l1_ratio = float(sys.argv[2]) if len(sys.argv) > 2 else 0.5
  mlflow.set_tracking_uri("http://localhost:5002")
  client = mlflow.tracking.MlflowClient()
  mlflow.set_experiment('http_metrics_test')
  with mlflow.start_run():
      lr = ElasticNet(alpha=alpha, l1_ratio=l1_ratio, random_state=42)
      lr.fit(train_x, train_y)

      predicted_qualities = lr.predict(test_x)

      (rmse, mae, r2) = eval_metrics(test_y, predicted_qualities)

      print("Elasticnet model (alpha=%f, l1_ratio=%f):" % (alpha, l1_ratio))
      print("  RMSE: %s" % rmse)
      print("  MAE: %s" % mae)
      print("  R2: %s" % r2)

      mlflow.log_param("alpha", alpha)
      mlflow.log_param("l1_ratio", l1_ratio)
      mlflow.log_metric("rmse", rmse)
      mlflow.log_metric("r2", r2)
      mlflow.log_metric("mae", mae)

      mlflow.sklearn.log_model(lr, "model")

注意:
1.mlflow.set_tracking_uri("http://localhost:5002") 設(shè)置為剛才啟動(dòng)的mlflow tracking server的地址
2.mlflow.set_experiment('http_metrics_test') 設(shè)置實(shí)驗(yàn)的名字
3.安裝該程序所依賴(lài)的python包
4.如果不是在同一個(gè)conda環(huán)境中,還得執(zhí)行

    export AWS_ACCESS_KEY_ID=AKIAIOSFODNN7EXAMPLE
    export AWS_SECRET_ACCESS_KEY=wJalrXUtnFEMI/K7MDENG/bPxRfiCYEXAMPLEKEY
    export MLFLOW_S3_ENDPOINT_URL=http://localhost:9001

便于python客戶(hù)端上傳模型文件以及模型元數(shù)據(jù)
直接執(zhí)行 python wine.py 如果成功,訪(fǎng)問(wèn)mlflow tracking server ui下有如下
mlflow的搭建使用是怎樣的 點(diǎn)擊 2020-10-30 10:34:38,如下:
mlflow的搭建使用是怎樣的 mlflow的搭建使用是怎樣的

啟動(dòng)mlflow 算法服務(wù)

在同一個(gè)conda環(huán)境中執(zhí)行命令

export MLFLOW_TRACKING_URI=http://localhost:5002 
mlflow models serve -m runs:/e69aed0b22fb45debd115dfc09dbc75a/model -p 1234 --no-conda

其中e69aed0b22fb45debd115dfc09dbc75a為mlflow tracking server ui中的run id

如遇到ModuleNotFoundError: No module named 'sklearn'
執(zhí)行 pip install scikit-learn==0.19.1
遇到ModuleNotFoundError: No module named 'scipy'
執(zhí)行pip install scipy

請(qǐng)求訪(fǎng)問(wèn)該model啟動(dòng)的服務(wù):

curl -X POST -H "Content-Type:application/json; format=pandas-split" --data '{"columns":["alcohol", "chlorides", "citric acid", "density", "fixed acidity", "free sulfur dioxide", "pH", "residual sugar", "sulphates", "total sulfur dioxide", "volatile acidity"],"data":[[12.8, 0.029, 0.48, 0.98, 6.2, 29, 3.33, 1.2, 0.39, 75, 0.66]]}' http://127.0.0.1:1234/invocations

輸出 [5.455573233630147] 則表明該模型服務(wù)成功部署

看完上述內(nèi)容,你們掌握mlflow的搭建使用是怎樣的的方法了嗎?如果還想學(xué)到更多技能或想了解更多相關(guān)內(nèi)容,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道,感謝各位的閱讀!

網(wǎng)站標(biāo)題:mlflow的搭建使用是怎樣的
瀏覽地址:http://www.chinadenli.net/article6/pgioig.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供靜態(tài)網(wǎng)站標(biāo)簽優(yōu)化品牌網(wǎng)站建設(shè)微信公眾號(hào)網(wǎng)站策劃建站公司

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶(hù)投稿、用戶(hù)轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話(huà):028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)

手機(jī)網(wǎng)站建設(shè)