Struct aws_sdk_emr::client::Client

source ·
pub struct Client { /* private fields */ }
Expand description

Client for Amazon EMR

Client for invoking operations on Amazon EMR. Each operation on Amazon EMR is a method on this this struct. .send() MUST be invoked on the generated operations to dispatch the request to the service.

Constructing a Client

A Config is required to construct a client. For most use cases, the aws-config crate should be used to automatically resolve this config using aws_config::load_from_env(), since this will resolve an SdkConfig which can be shared across multiple different AWS SDK clients. This config resolution process can be customized by calling aws_config::from_env() instead, which returns a ConfigLoader that uses the builder pattern to customize the default config.

In the simplest case, creating a client looks as follows:

let config = aws_config::load_from_env().await;
let client = aws_sdk_emr::Client::new(&config);

Occasionally, SDKs may have additional service-specific that can be set on the Config that is absent from SdkConfig, or slightly different settings for a specific client may be desired. The Config struct implements From<&SdkConfig>, so setting these specific settings can be done as follows:

let sdk_config = ::aws_config::load_from_env().await;
let config = aws_sdk_emr::config::Builder::from(&sdk_config)
    .some_service_specific_setting("value")
    .build();

See the aws-config docs and Config for more information on customizing configuration.

Note: Client construction is expensive due to connection thread pool initialization, and should be done once at application start-up.

Using the Client

A client has a function for every operation that can be performed by the service. For example, the AddInstanceFleet operation has a Client::add_instance_fleet, function which returns a builder for that operation. The fluent builder ultimately has a send() function that returns an async future that returns a result, as illustrated below:

let result = client.add_instance_fleet()
    .cluster_id("example")
    .send()
    .await;

The underlying HTTP requests that get made by this can be modified with the customize_operation function on the fluent builder. See the customize module for more information.

Implementations§

source§

impl Client

source

pub fn add_instance_fleet(&self) -> AddInstanceFleetFluentBuilder

Constructs a fluent builder for the AddInstanceFleet operation.

source§

impl Client

source

pub fn add_instance_groups(&self) -> AddInstanceGroupsFluentBuilder

Constructs a fluent builder for the AddInstanceGroups operation.

source§

impl Client

source

pub fn add_job_flow_steps(&self) -> AddJobFlowStepsFluentBuilder

Constructs a fluent builder for the AddJobFlowSteps operation.

source§

impl Client

source

pub fn add_tags(&self) -> AddTagsFluentBuilder

Constructs a fluent builder for the AddTags operation.

source§

impl Client

source

pub fn cancel_steps(&self) -> CancelStepsFluentBuilder

Constructs a fluent builder for the CancelSteps operation.

source§

impl Client

source

pub fn create_security_configuration( &self ) -> CreateSecurityConfigurationFluentBuilder

Constructs a fluent builder for the CreateSecurityConfiguration operation.

source§

impl Client

source

pub fn create_studio(&self) -> CreateStudioFluentBuilder

Constructs a fluent builder for the CreateStudio operation.

source§

impl Client

source

pub fn create_studio_session_mapping( &self ) -> CreateStudioSessionMappingFluentBuilder

Constructs a fluent builder for the CreateStudioSessionMapping operation.

source§

impl Client

source

pub fn delete_security_configuration( &self ) -> DeleteSecurityConfigurationFluentBuilder

Constructs a fluent builder for the DeleteSecurityConfiguration operation.

source§

impl Client

source

pub fn delete_studio(&self) -> DeleteStudioFluentBuilder

Constructs a fluent builder for the DeleteStudio operation.

source§

impl Client

source

pub fn delete_studio_session_mapping( &self ) -> DeleteStudioSessionMappingFluentBuilder

Constructs a fluent builder for the DeleteStudioSessionMapping operation.

source§

impl Client

source

pub fn describe_cluster(&self) -> DescribeClusterFluentBuilder

Constructs a fluent builder for the DescribeCluster operation.

source§

impl Client

source

pub fn describe_job_flows(&self) -> DescribeJobFlowsFluentBuilder

👎Deprecated

Constructs a fluent builder for the DescribeJobFlows operation.

source§

impl Client

source

pub fn describe_notebook_execution( &self ) -> DescribeNotebookExecutionFluentBuilder

Constructs a fluent builder for the DescribeNotebookExecution operation.

source§

impl Client

source

pub fn describe_release_label(&self) -> DescribeReleaseLabelFluentBuilder

Constructs a fluent builder for the DescribeReleaseLabel operation.

source§

impl Client

source

pub fn describe_security_configuration( &self ) -> DescribeSecurityConfigurationFluentBuilder

Constructs a fluent builder for the DescribeSecurityConfiguration operation.

source§

impl Client

source

pub fn describe_step(&self) -> DescribeStepFluentBuilder

Constructs a fluent builder for the DescribeStep operation.

source§

impl Client

source

pub fn describe_studio(&self) -> DescribeStudioFluentBuilder

Constructs a fluent builder for the DescribeStudio operation.

source§

impl Client

source

pub fn get_auto_termination_policy( &self ) -> GetAutoTerminationPolicyFluentBuilder

Constructs a fluent builder for the GetAutoTerminationPolicy operation.

source§

impl Client

source

pub fn get_block_public_access_configuration( &self ) -> GetBlockPublicAccessConfigurationFluentBuilder

Constructs a fluent builder for the GetBlockPublicAccessConfiguration operation.

  • The fluent builder takes no input, just send it.
  • On success, responds with GetBlockPublicAccessConfigurationOutput with field(s):
    • block_public_access_configuration(Option<BlockPublicAccessConfiguration>):

      A configuration for Amazon EMR block public access. The configuration applies to all clusters created in your account for the current Region. The configuration specifies whether block public access is enabled. If block public access is enabled, security groups associated with the cluster cannot have rules that allow inbound traffic from 0.0.0.0/0 or ::/0 on a port, unless the port is specified as an exception using PermittedPublicSecurityGroupRuleRanges in the BlockPublicAccessConfiguration. By default, Port 22 (SSH) is an exception, and public access is allowed on this port. You can change this by updating the block public access configuration to remove the exception.

      For accounts that created clusters in a Region before November 25, 2019, block public access is disabled by default in that Region. To use this feature, you must manually enable and configure it. For accounts that did not create an Amazon EMR cluster in a Region before this date, block public access is enabled by default in that Region.

    • block_public_access_configuration_metadata(Option<BlockPublicAccessConfigurationMetadata>):

      Properties that describe the Amazon Web Services principal that created the BlockPublicAccessConfiguration using the PutBlockPublicAccessConfiguration action as well as the date and time that the configuration was created. Each time a configuration for block public access is updated, Amazon EMR updates this metadata.

  • On failure, responds with SdkError<GetBlockPublicAccessConfigurationError>
source§

impl Client

source

pub fn get_cluster_session_credentials( &self ) -> GetClusterSessionCredentialsFluentBuilder

Constructs a fluent builder for the GetClusterSessionCredentials operation.

source§

impl Client

source

pub fn get_managed_scaling_policy(&self) -> GetManagedScalingPolicyFluentBuilder

Constructs a fluent builder for the GetManagedScalingPolicy operation.

source§

impl Client

source

pub fn get_studio_session_mapping(&self) -> GetStudioSessionMappingFluentBuilder

Constructs a fluent builder for the GetStudioSessionMapping operation.

source§

impl Client

source

pub fn list_bootstrap_actions(&self) -> ListBootstrapActionsFluentBuilder

Constructs a fluent builder for the ListBootstrapActions operation. This operation supports pagination; See into_paginator().

source§

impl Client

source

pub fn list_clusters(&self) -> ListClustersFluentBuilder

Constructs a fluent builder for the ListClusters operation. This operation supports pagination; See into_paginator().

source§

impl Client

source

pub fn list_instance_fleets(&self) -> ListInstanceFleetsFluentBuilder

Constructs a fluent builder for the ListInstanceFleets operation. This operation supports pagination; See into_paginator().

source§

impl Client

source

pub fn list_instance_groups(&self) -> ListInstanceGroupsFluentBuilder

Constructs a fluent builder for the ListInstanceGroups operation. This operation supports pagination; See into_paginator().

source§

impl Client

source

pub fn list_instances(&self) -> ListInstancesFluentBuilder

Constructs a fluent builder for the ListInstances operation. This operation supports pagination; See into_paginator().

source§

impl Client

source

pub fn list_notebook_executions(&self) -> ListNotebookExecutionsFluentBuilder

Constructs a fluent builder for the ListNotebookExecutions operation. This operation supports pagination; See into_paginator().

source§

impl Client

source

pub fn list_release_labels(&self) -> ListReleaseLabelsFluentBuilder

Constructs a fluent builder for the ListReleaseLabels operation. This operation supports pagination; See into_paginator().

source§

impl Client

source

pub fn list_security_configurations( &self ) -> ListSecurityConfigurationsFluentBuilder

Constructs a fluent builder for the ListSecurityConfigurations operation. This operation supports pagination; See into_paginator().

source§

impl Client

source

pub fn list_steps(&self) -> ListStepsFluentBuilder

Constructs a fluent builder for the ListSteps operation. This operation supports pagination; See into_paginator().

source§

impl Client

source

pub fn list_studio_session_mappings( &self ) -> ListStudioSessionMappingsFluentBuilder

Constructs a fluent builder for the ListStudioSessionMappings operation. This operation supports pagination; See into_paginator().

source§

impl Client

source

pub fn list_studios(&self) -> ListStudiosFluentBuilder

Constructs a fluent builder for the ListStudios operation. This operation supports pagination; See into_paginator().

source§

impl Client

source

pub fn list_supported_instance_types( &self ) -> ListSupportedInstanceTypesFluentBuilder

Constructs a fluent builder for the ListSupportedInstanceTypes operation. This operation supports pagination; See into_paginator().

source§

impl Client

source

pub fn modify_cluster(&self) -> ModifyClusterFluentBuilder

Constructs a fluent builder for the ModifyCluster operation.

source§

impl Client

source

pub fn modify_instance_fleet(&self) -> ModifyInstanceFleetFluentBuilder

Constructs a fluent builder for the ModifyInstanceFleet operation.

source§

impl Client

source

pub fn modify_instance_groups(&self) -> ModifyInstanceGroupsFluentBuilder

Constructs a fluent builder for the ModifyInstanceGroups operation.

source§

impl Client

source

pub fn put_auto_scaling_policy(&self) -> PutAutoScalingPolicyFluentBuilder

Constructs a fluent builder for the PutAutoScalingPolicy operation.

source§

impl Client

source

pub fn put_auto_termination_policy( &self ) -> PutAutoTerminationPolicyFluentBuilder

Constructs a fluent builder for the PutAutoTerminationPolicy operation.

source§

impl Client

source

pub fn put_block_public_access_configuration( &self ) -> PutBlockPublicAccessConfigurationFluentBuilder

Constructs a fluent builder for the PutBlockPublicAccessConfiguration operation.

  • The fluent builder is configurable:
    • block_public_access_configuration(BlockPublicAccessConfiguration) / set_block_public_access_configuration(Option<BlockPublicAccessConfiguration>):
      required: true

      A configuration for Amazon EMR block public access. The configuration applies to all clusters created in your account for the current Region. The configuration specifies whether block public access is enabled. If block public access is enabled, security groups associated with the cluster cannot have rules that allow inbound traffic from 0.0.0.0/0 or ::/0 on a port, unless the port is specified as an exception using PermittedPublicSecurityGroupRuleRanges in the BlockPublicAccessConfiguration. By default, Port 22 (SSH) is an exception, and public access is allowed on this port. You can change this by updating BlockPublicSecurityGroupRules to remove the exception.

      For accounts that created clusters in a Region before November 25, 2019, block public access is disabled by default in that Region. To use this feature, you must manually enable and configure it. For accounts that did not create an Amazon EMR cluster in a Region before this date, block public access is enabled by default in that Region.


  • On success, responds with PutBlockPublicAccessConfigurationOutput
  • On failure, responds with SdkError<PutBlockPublicAccessConfigurationError>
source§

impl Client

source

pub fn put_managed_scaling_policy(&self) -> PutManagedScalingPolicyFluentBuilder

Constructs a fluent builder for the PutManagedScalingPolicy operation.

source§

impl Client

source

pub fn remove_auto_scaling_policy(&self) -> RemoveAutoScalingPolicyFluentBuilder

Constructs a fluent builder for the RemoveAutoScalingPolicy operation.

source§

impl Client

source

pub fn remove_auto_termination_policy( &self ) -> RemoveAutoTerminationPolicyFluentBuilder

Constructs a fluent builder for the RemoveAutoTerminationPolicy operation.

source§

impl Client

source

pub fn remove_managed_scaling_policy( &self ) -> RemoveManagedScalingPolicyFluentBuilder

Constructs a fluent builder for the RemoveManagedScalingPolicy operation.

source§

impl Client

source

pub fn remove_tags(&self) -> RemoveTagsFluentBuilder

Constructs a fluent builder for the RemoveTags operation.

source§

impl Client

source

pub fn run_job_flow(&self) -> RunJobFlowFluentBuilder

Constructs a fluent builder for the RunJobFlow operation.

source§

impl Client

source

pub fn set_termination_protection( &self ) -> SetTerminationProtectionFluentBuilder

Constructs a fluent builder for the SetTerminationProtection operation.

source§

impl Client

source

pub fn set_visible_to_all_users(&self) -> SetVisibleToAllUsersFluentBuilder

Constructs a fluent builder for the SetVisibleToAllUsers operation.

source§

impl Client

source

pub fn start_notebook_execution(&self) -> StartNotebookExecutionFluentBuilder

Constructs a fluent builder for the StartNotebookExecution operation.

source§

impl Client

source

pub fn stop_notebook_execution(&self) -> StopNotebookExecutionFluentBuilder

Constructs a fluent builder for the StopNotebookExecution operation.

source§

impl Client

source

pub fn terminate_job_flows(&self) -> TerminateJobFlowsFluentBuilder

Constructs a fluent builder for the TerminateJobFlows operation.

source§

impl Client

source

pub fn update_studio(&self) -> UpdateStudioFluentBuilder

Constructs a fluent builder for the UpdateStudio operation.

source§

impl Client

source

pub fn update_studio_session_mapping( &self ) -> UpdateStudioSessionMappingFluentBuilder

Constructs a fluent builder for the UpdateStudioSessionMapping operation.

source§

impl Client

source

pub fn from_conf(conf: Config) -> Self

Creates a new client from the service Config.

Panics

This method will panic in the following cases:

  • Retries or timeouts are enabled without a sleep_impl configured.
  • Identity caching is enabled without a sleep_impl and time_source configured.
  • No behavior_version is provided.

The panic message for each of these will have instructions on how to resolve them.

source

pub fn config(&self) -> &Config

Returns the client’s configuration.

source§

impl Client

source

pub fn new(sdk_config: &SdkConfig) -> Self

Creates a new client from an SDK Config.

Panics
  • This method will panic if the sdk_config is missing an async sleep implementation. If you experience this panic, set the sleep_impl on the Config passed into this function to fix it.
  • This method will panic if the sdk_config is missing an HTTP connector. If you experience this panic, set the http_connector on the Config passed into this function to fix it.
  • This method will panic if no BehaviorVersion is provided. If you experience this panic, set behavior_version on the Config or enable the behavior-version-latest Cargo feature.

Trait Implementations§

source§

impl Clone for Client

source§

fn clone(&self) -> Client

Returns a copy of the value. Read more
1.0.0 · source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
source§

impl Debug for Client

source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more

Auto Trait Implementations§

§

impl !RefUnwindSafe for Client

§

impl Send for Client

§

impl Sync for Client

§

impl Unpin for Client

§

impl !UnwindSafe for Client

Blanket Implementations§

source§

impl<T> Any for T
where T: 'static + ?Sized,

source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
source§

impl<T> Borrow<T> for T
where T: ?Sized,

source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
source§

impl<T> From<T> for T

source§

fn from(t: T) -> T

Returns the argument unchanged.

source§

impl<T> Instrument for T

source§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided Span, returning an Instrumented wrapper. Read more
source§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
source§

impl<T, U> Into<U> for T
where U: From<T>,

source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

source§

impl<Unshared, Shared> IntoShared<Shared> for Unshared
where Shared: FromUnshared<Unshared>,

source§

fn into_shared(self) -> Shared

Creates a shared type from an unshared type.
source§

impl<T> Same for T

§

type Output = T

Should always be Self
source§

impl<T> ToOwned for T
where T: Clone,

§

type Owned = T

The resulting type after obtaining ownership.
source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

§

type Error = Infallible

The type returned in the event of a conversion error.
source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
source§

impl<T> WithSubscriber for T

source§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a WithDispatch wrapper. Read more
source§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a WithDispatch wrapper. Read more