Skip to main content
Version: 1.44

Create and update Deployments

Preparation

In order to deploy models, you need a Personal Key Pair. For more information regarding authentication, see Authentication.

Another part of the preparation is getting familiar with the repository contract that Deeploy uses, you can find more information about that here. If your model is stored elsewhere and you do not yet adhere to the contract, you generate a reference.json.

Managed deployments

Create a managed deployment

See all Create Deployment arguments

from deeploy import CreateDeployment
from deeploy.enums import ModelType

create_options: CreateDeployment = {
"name": "Python Client",
"description": "Python Client Description",
"repository_id": "b6d8c781-2526-4e03-9b43-4c1a62d064db",
"branch_name": "master",
"commit": "b26af7790c1d3b27b953b37806b91cb6735c590b",
"model_type": ModelType.CUSTOM,
"model_serverless": True,
}

deployment = client.create_deployment(create_options)

Update a managed deployment

See all Update Deployment arguments

from deeploy import UpdateDeployment

update_options: UpdateDeployment = {
"model_mem_request": 256,
"model_mem_limit": 256,
"model_cpu_request": 0.1,
"model_cpu_limit": 0.5,
}

updated_deployment = client.update_deployment(deployment_id=deployment.id, options=update_options)

External deployments

Create an external deployment

See all Create Deployment arguments

from deeploy import CreateRegistrationDeployment

# example used: https://gitlab.com/deeploy-ml/sample-models/example-hello-world-external-deployment
create_options: CreateExternalDeployment = {
"name": "External deployment",
"description": "Created with Python client",
"url": "https://hello-world.external-deployment.workers.dev/hello",
"repository_id": None,
"branch_name": None,
"username": "admin",
"password": "YWRtaW46cGFzc3dvcmQxMjM="
}

deployment = client.create_external_deployment(options=create_options)

Update an external deployment

See all Create Deployment arguments

from deeploy import UpdateRegistrationDeployment

# example used: https://gitlab.com/deeploy-ml/sample-models/example-hello-world-external-deployment
update_options: UpdateExternalDeployment = {
"repository_id": "70cd264a-8023-4aab-9067-a9acc4badb42",
"branch_name": "main",
"commit": "1694c40449f6143373f28794de7b49e941a5fc65"
}

deployment = client.update_external_deployment(deployment_id=deployment.id, options=update_options)

Deployment registrations

Create a deployment registration

See all Create Deployment arguments

from deeploy import CreateRegistrationDeployment

# example used: https://gitlab.com/deeploy-ml/sample-models/example-census-registration-deployment
create_options: CreateExternalDeployment = {
"name": "Deployment registration",
"description": "Created with Python client",
"repository_id": None,
"branch_name": None,
}

deployment = client.create_registration_deployment(options=create_options)

Update a deployment registration

See all Create Deployment arguments

from deeploy import UpdateRegistrationDeployment

# example used: https://gitlab.com/deeploy-ml/sample-models/example-census-registration-deployment
update_options: UpdateExternalDeployment = {
"repository_id": "70cd264a-8023-4aab-9067-a9acc4badb42",
"branch_name": "main",
"commit": "1694c40449f6143373f28794de7b49e941a5fc65"
}

deployment = client.update_external_deployment(deployment_id=deployment.id, options=update_options)

SageMaker

Create a SageMaker Deployment

See all Create SageMaker Deployment arguments

from deeploy import CreateSageMakerDeployment
from deeploy.enums import ModelType

create_options: CreateSageMakerDeployment = {
"name": "Python Client",
"description": "Python Client Description",
"repository_id": "b6d8c781-2526-4e03-9b43-4c1a62d064db",
"branch_name": "master",
"commit": "b26af7790c1d3b27b953b37806b91cb6735c590b",
"model_type": ModelType.CUSTOM,
"model_instance_type": 'ml.c5.large',
}

sagemaker_deployment = client.create_sagemaker_deployment(options=create_options)

Update a SageMaker Deployment

See all Update SageMaker Deployment arguments

from deeploy import UpdateSageMakerDeployment

update_options: UpdateSageMakerDeployment = {
"model_instance_type": 'ml.c4.large',
}

updated_deployment = client.update_sagemaker_deployment(deployment_id=sagemaker_deployment.id, options=update_options)

Azure Machine Learning

Create an Azure Machine Learning Deployment

See all Create Azure Machine Learning Deployment arguments

from deeploy import CreateAzureMLDeployment
from deeploy.enums import ExplainerType, ModelType

create_options: CreateAzureMLDeployment = {
"name": "Python Client",
"description": "Python Client Description",
"repository_id": "b6d8c781-2526-4e03-9b43-4c1a62d064db",
"branch_name": "main",
"commit": "ea420035f347fad091e367a9ce2798aef6cae9eb",
"model_type": ModelType.CUSTOM,
"explainer_type": ExplainerType.CUSTOM,
"model_instance_type": "Standard_D2as_v4",
"model_instance_count": 1,
"explainer_instance_type": "Standard_D2as_v4",
"explainer_instance_count": 1,
}

azure_ml_deployment = client.create_azure_ml_deployment(options=create_options)

Update an Azure Machine Learning Deployment

See all Update Azure Machine Learning Deployment arguments

from deeploy import UpdateAzureMLDeployment

update_options: UpdateAzureMLDeployment = {
"model_instance_type": "Standard_D2as_v4",
"model_instance_count": 1,
"explainer_instance_type": "Standard_D2as_v4",
"explainer_instance_count": 1,
}

updated_azure_ml_deployment = client.update_azure_ml_deployment(deployment_id=azure_ml_deployment.id, options=update_options)

Upgrade Deployments

Upgrade a Deployment using the update_deployment method, the deployment_type attribute and the required attributes for the new deployment_type. See upgrading Deployments for more information.

from deeploy import UpdateDeployment
from deeploy.enums import ExplainerType, DeploymentType, ModelType, TransformerType

update_options: UpdateDeployment = {
"deployment_type": DeploymentType.KSERVE,
"repository_id": "c1607cea-9cbb-4616-83f1-494d2dcd1f5f",
"branch_name": "master",
"commit": "b26af7790c1d3b27b953b37806b91cb6735c590b",
"model_type": ModelType.CUSTOM,
"explainer_type": ExplainerType.NO_EXPLAINER,
"transformer_type": TransformerType.NO_TRANSFORMER,
"model_serverless": True,
}

client.update_deployment("997724e8-9db6-488e-a287-ce2eaf55841d", update_options)

General

Update the Deployment description

from deeploy import UpdateDeploymentDescription

description_options: UpdateDeploymentDescription = {
"name": "Python Client v2",
"description": "Python Client Description v2",
}

updated_deployment = client.update_deployment_description(deployment_id, description_options)

Creating multiple Deployments from a monorepo

Deeploy supports creating multiple Deployments from the same repository using a contract path. The contract path is the path relative to the root of a repository where the deeploy contract for a Deployment is located. The idea is that you create your Deeploy contract path at a subfolder in the repository, as shown in the example below.

repository

├─ subfolder_1
│ ├─ model
│ │ └─ reference.json
│ ├─ explainer
│ │ └─ reference.json
│ ├─ transformer
│ │ └─ reference.json
│ └─ metadata.json

└─ subfolder_2
└─ model
└─ reference.json

To create a Deployment from a contract path, you provide the relative path from the repository root as input to the Python SDK or Core API. In the example above this is subfolder_1 or subfolder_2.

from deeploy import CreateDeployment

create_options: CreateDeployment = {
# other options
"contract_path": "/subfolder_1",
}

deployment = client.create_deployment(create_options)

Check out the API reference for more information.