forked from mlflow/mlflow
-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
fixed issues minor change fixed doc Changed qubole conda path updated doc
- Loading branch information
1 parent
6e60e79
commit b99f2f4
Showing
7 changed files
with
428 additions
and
3 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,79 @@ | ||
# Running MLFlow in Qubole Mode | ||
|
||
|
||
When run in `"qubole"` mode, a `ShellCommand` is launched on QDS from the MLFlow project. | ||
|
||
## Setting up cluster | ||
|
||
Install `mlflow` package on cluster using the node-bootstrap. | ||
|
||
``` | ||
source /usr/lib/environs/a-2019.03-py-3.7.3/bin/activate /usr/lib/environs/a-2019.03-py-3.7.3/ | ||
conda install mlflow | ||
``` | ||
|
||
## Start tracking server | ||
|
||
To run a long-lived, shared MLflow tracking server, launch an EC2 instance to run the MLflow Tracking server. | ||
|
||
Create an Anaconda with Python 3 AMI EC2 instance.You can use a t2.micro (Free-tier) instance for test environment. This AMI already has conda and many other packages needed pre-installed. | ||
Install mlflow: | ||
``` | ||
wget https://github.com/qubole/mlflow/releases/download/v1.5.0-q/mlflow-1.5.0-py3-none-any.whl | ||
pip install mlflow-1.5.0-py3-none-any.whl | ||
``` | ||
Open port 5000 for MLflow server; an example of how to do this via How to open a web server port on EC2 instance. Opening up port 5000 to the Internet will allow anyone to access your server, so it is recommended to only open up the port within an AWS VPC that your Qubole clusters have access to. | ||
Configure your AWS credentials on the instance. The optimal configuration for MLflow Remote Tracking is to use the default-artifact-root option to store your artifacts in an S3 bucket. | ||
SSH into your EC2 instance, e.g. ssh -i ~/.ssh/<key>.pem ubuntu@<hostname>.<region>.compute.amazonaws.com. | ||
Configure your S3 credentials via aws cli; for more information, refer to Configuring the AWS CLI. | ||
Run the Tracking Server | ||
Start the tracking server: | ||
```sh | ||
mlflow server --default-artifact-root s3://<bucket-name> --host 0.0.0.0. | ||
``` | ||
For more information, refer to MLflow > Running a Tracking Server. | ||
Test connectivity of your tracking server. Go to http://<mlflow-server-dns>:5000; it should look similar to | ||
|
||
![](https://docs.databricks.com/_static/images/mlflow/mlflow-web-ui.png) | ||
|
||
## Run the job | ||
|
||
### Set tracking server variable | ||
|
||
Set environment variable `MLFLOW_TRACKING_URI`. | ||
|
||
### Create cluster spec file | ||
Running the remote job requires `backend-spec.json` to be passed as follows, | ||
|
||
```json | ||
{ | ||
"aws": { | ||
"s3_experiment_bucket": "<bucket-name>", | ||
"s3_experiment_base_path": "<directory>" | ||
}, | ||
"qubole": { | ||
"api_token": "<qubole-api-token>" , | ||
"api_url": "https://api.qubole.com/api/", | ||
"version": "v1.2", | ||
"poll_interval": 5, | ||
"skip_ssl_cert_check": false, | ||
"cloud_name": "AWS" | ||
}, | ||
"cluster": { | ||
"label": "mlflow-test" | ||
}, | ||
"command": { | ||
"name": "mlflow-test", | ||
"tags": ["mlflow"], | ||
"notify": false | ||
} | ||
} | ||
``` | ||
|
||
### Example | ||
|
||
A toy example can be launch using the following command, | ||
|
||
```sh | ||
mlflow run git@github.com:agrawalamey/mlflow-example.git -P alpha=0.5 -b qubole --backend-config backend-spec.json | ||
``` |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.