concrete.ml.deployment.deploy_to_aws.md
Last updated
Last updated
concrete.ml.deployment.deploy_to_aws
Methods to deploy a client/server to AWS.
It takes as input a folder with: - client.zip - server.zip - processing.json
It spawns a AWS EC2 instance with proper security groups. Then SSHs to it to rsync the files and update Python dependencies. It then launches the server.
DATE_FORMAT
DEFAULT_CML_AMI_ID
create_instance
Create a EC2 instance.
Arguments:
instance_type
(str): the type of AWS EC2 instance.
open_port
(int): the port to open.
instance_name
(Optional[str]): the name to use for AWS created objects
verbose
(bool): show logs or not
region_name
(Optional[str]): AWS region
ami_id
(str): AMI to use
Returns:
Dict[str, Any]
: some information about the newly created instance. - ip - private_key - instance_id - key_path - ip_address - port
deploy_to_aws
Deploy a model to a EC2 AWS instance.
Arguments:
instance_metadata
(Dict[str, Any]): the metadata of AWS EC2 instance created using AWSInstance or create_instance
path_to_model
(Path): the path to the serialized model
number_of_ssh_retries
(int): the number of ssh retries (-1 is no limit)
wait_bar
(bool): whether to show a wait bar when waiting for ssh connection to be available
verbose
(bool): whether to show a logs
Returns: instance_metadata (Dict[str, Any])
Raises:
RuntimeError
: if launching the server crashed
wait_instance_termination
Wait for AWS EC2 instance termination.
Arguments:
instance_id
(str): the id of the AWS EC2 instance to terminate.
region_name
(Optional[str]): AWS region (Optional)
terminate_instance
Terminate a AWS EC2 instance.
Arguments:
instance_id
(str): the id of the AWS EC2 instance to terminate.
region_name
(Optional[str]): AWS region (Optional)
delete_security_group
Terminate a AWS EC2 instance.
Arguments:
security_group_id
(str): the id of the AWS EC2 instance to terminate.
region_name
(Optional[str]): AWS region (Optional)
main
Deploy a model.
Arguments:
path_to_model
(Path): path to serialized model to serve.
port
(int): port to use.
instance_type
(str): type of AWS EC2 instance to use.
instance_name
(Optional[str]): the name to use for AWS created objects
verbose
(bool): show logs or not
wait_bar
(bool): show progress bar when waiting for ssh connection
terminate_on_shutdown
(bool): terminate instance when script is over
AWSInstance
AWSInstance.
Context manager for AWS instance that supports ssh and http over one port.
__init__