All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.amazonaws.services.athena.model.EngineConfiguration Maven / Gradle / Ivy

/*
 * Copyright 2019-2024 Amazon.com, Inc. or its affiliates. All Rights Reserved.
 * 
 * Licensed under the Apache License, Version 2.0 (the "License"). You may not use this file except in compliance with
 * the License. A copy of the License is located at
 * 
 * http://aws.amazon.com/apache2.0
 * 
 * or in the "license" file accompanying this file. This file is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR
 * CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions
 * and limitations under the License.
 */
package com.amazonaws.services.athena.model;

import java.io.Serializable;
import javax.annotation.Generated;
import com.amazonaws.protocol.StructuredPojo;
import com.amazonaws.protocol.ProtocolMarshaller;

/**
 * 

* Contains data processing unit (DPU) configuration settings and parameter mappings for a notebook engine. *

* * @see AWS API * Documentation */ @Generated("com.amazonaws:aws-java-sdk-code-generator") public class EngineConfiguration implements Serializable, Cloneable, StructuredPojo { /** *

* The number of DPUs to use for the coordinator. A coordinator is a special executor that orchestrates processing * work and manages other executors in a notebook session. The default is 1. *

*/ private Integer coordinatorDpuSize; /** *

* The maximum number of DPUs that can run concurrently. *

*/ private Integer maxConcurrentDpus; /** *

* The default number of DPUs to use for executors. An executor is the smallest unit of compute that a notebook * session can request from Athena. The default is 1. *

*/ private Integer defaultExecutorDpuSize; /** *

* Contains additional notebook engine MAP<string, string> parameter mappings in the form of * key-value pairs. To specify an Athena notebook that the Jupyter server will download and serve, specify a value * for the StartSessionRequest$NotebookVersion field, and then add a key named NotebookId to * AdditionalConfigs that has the value of the Athena notebook ID. *

*/ private java.util.Map additionalConfigs; /** *

* Specifies custom jar files and Spark properties for use cases like cluster encryption, table formats, and general * Spark tuning. *

*/ private java.util.Map sparkProperties; /** *

* The number of DPUs to use for the coordinator. A coordinator is a special executor that orchestrates processing * work and manages other executors in a notebook session. The default is 1. *

* * @param coordinatorDpuSize * The number of DPUs to use for the coordinator. A coordinator is a special executor that orchestrates * processing work and manages other executors in a notebook session. The default is 1. */ public void setCoordinatorDpuSize(Integer coordinatorDpuSize) { this.coordinatorDpuSize = coordinatorDpuSize; } /** *

* The number of DPUs to use for the coordinator. A coordinator is a special executor that orchestrates processing * work and manages other executors in a notebook session. The default is 1. *

* * @return The number of DPUs to use for the coordinator. A coordinator is a special executor that orchestrates * processing work and manages other executors in a notebook session. The default is 1. */ public Integer getCoordinatorDpuSize() { return this.coordinatorDpuSize; } /** *

* The number of DPUs to use for the coordinator. A coordinator is a special executor that orchestrates processing * work and manages other executors in a notebook session. The default is 1. *

* * @param coordinatorDpuSize * The number of DPUs to use for the coordinator. A coordinator is a special executor that orchestrates * processing work and manages other executors in a notebook session. The default is 1. * @return Returns a reference to this object so that method calls can be chained together. */ public EngineConfiguration withCoordinatorDpuSize(Integer coordinatorDpuSize) { setCoordinatorDpuSize(coordinatorDpuSize); return this; } /** *

* The maximum number of DPUs that can run concurrently. *

* * @param maxConcurrentDpus * The maximum number of DPUs that can run concurrently. */ public void setMaxConcurrentDpus(Integer maxConcurrentDpus) { this.maxConcurrentDpus = maxConcurrentDpus; } /** *

* The maximum number of DPUs that can run concurrently. *

* * @return The maximum number of DPUs that can run concurrently. */ public Integer getMaxConcurrentDpus() { return this.maxConcurrentDpus; } /** *

* The maximum number of DPUs that can run concurrently. *

* * @param maxConcurrentDpus * The maximum number of DPUs that can run concurrently. * @return Returns a reference to this object so that method calls can be chained together. */ public EngineConfiguration withMaxConcurrentDpus(Integer maxConcurrentDpus) { setMaxConcurrentDpus(maxConcurrentDpus); return this; } /** *

* The default number of DPUs to use for executors. An executor is the smallest unit of compute that a notebook * session can request from Athena. The default is 1. *

* * @param defaultExecutorDpuSize * The default number of DPUs to use for executors. An executor is the smallest unit of compute that a * notebook session can request from Athena. The default is 1. */ public void setDefaultExecutorDpuSize(Integer defaultExecutorDpuSize) { this.defaultExecutorDpuSize = defaultExecutorDpuSize; } /** *

* The default number of DPUs to use for executors. An executor is the smallest unit of compute that a notebook * session can request from Athena. The default is 1. *

* * @return The default number of DPUs to use for executors. An executor is the smallest unit of compute that a * notebook session can request from Athena. The default is 1. */ public Integer getDefaultExecutorDpuSize() { return this.defaultExecutorDpuSize; } /** *

* The default number of DPUs to use for executors. An executor is the smallest unit of compute that a notebook * session can request from Athena. The default is 1. *

* * @param defaultExecutorDpuSize * The default number of DPUs to use for executors. An executor is the smallest unit of compute that a * notebook session can request from Athena. The default is 1. * @return Returns a reference to this object so that method calls can be chained together. */ public EngineConfiguration withDefaultExecutorDpuSize(Integer defaultExecutorDpuSize) { setDefaultExecutorDpuSize(defaultExecutorDpuSize); return this; } /** *

* Contains additional notebook engine MAP<string, string> parameter mappings in the form of * key-value pairs. To specify an Athena notebook that the Jupyter server will download and serve, specify a value * for the StartSessionRequest$NotebookVersion field, and then add a key named NotebookId to * AdditionalConfigs that has the value of the Athena notebook ID. *

* * @return Contains additional notebook engine MAP<string, string> parameter mappings in the form * of key-value pairs. To specify an Athena notebook that the Jupyter server will download and serve, * specify a value for the StartSessionRequest$NotebookVersion field, and then add a key named * NotebookId to AdditionalConfigs that has the value of the Athena notebook ID. */ public java.util.Map getAdditionalConfigs() { return additionalConfigs; } /** *

* Contains additional notebook engine MAP<string, string> parameter mappings in the form of * key-value pairs. To specify an Athena notebook that the Jupyter server will download and serve, specify a value * for the StartSessionRequest$NotebookVersion field, and then add a key named NotebookId to * AdditionalConfigs that has the value of the Athena notebook ID. *

* * @param additionalConfigs * Contains additional notebook engine MAP<string, string> parameter mappings in the form * of key-value pairs. To specify an Athena notebook that the Jupyter server will download and serve, specify * a value for the StartSessionRequest$NotebookVersion field, and then add a key named * NotebookId to AdditionalConfigs that has the value of the Athena notebook ID. */ public void setAdditionalConfigs(java.util.Map additionalConfigs) { this.additionalConfigs = additionalConfigs; } /** *

* Contains additional notebook engine MAP<string, string> parameter mappings in the form of * key-value pairs. To specify an Athena notebook that the Jupyter server will download and serve, specify a value * for the StartSessionRequest$NotebookVersion field, and then add a key named NotebookId to * AdditionalConfigs that has the value of the Athena notebook ID. *

* * @param additionalConfigs * Contains additional notebook engine MAP<string, string> parameter mappings in the form * of key-value pairs. To specify an Athena notebook that the Jupyter server will download and serve, specify * a value for the StartSessionRequest$NotebookVersion field, and then add a key named * NotebookId to AdditionalConfigs that has the value of the Athena notebook ID. * @return Returns a reference to this object so that method calls can be chained together. */ public EngineConfiguration withAdditionalConfigs(java.util.Map additionalConfigs) { setAdditionalConfigs(additionalConfigs); return this; } /** * Add a single AdditionalConfigs entry * * @see EngineConfiguration#withAdditionalConfigs * @returns a reference to this object so that method calls can be chained together. */ public EngineConfiguration addAdditionalConfigsEntry(String key, String value) { if (null == this.additionalConfigs) { this.additionalConfigs = new java.util.HashMap(); } if (this.additionalConfigs.containsKey(key)) throw new IllegalArgumentException("Duplicated keys (" + key.toString() + ") are provided."); this.additionalConfigs.put(key, value); return this; } /** * Removes all the entries added into AdditionalConfigs. * * @return Returns a reference to this object so that method calls can be chained together. */ public EngineConfiguration clearAdditionalConfigsEntries() { this.additionalConfigs = null; return this; } /** *

* Specifies custom jar files and Spark properties for use cases like cluster encryption, table formats, and general * Spark tuning. *

* * @return Specifies custom jar files and Spark properties for use cases like cluster encryption, table formats, and * general Spark tuning. */ public java.util.Map getSparkProperties() { return sparkProperties; } /** *

* Specifies custom jar files and Spark properties for use cases like cluster encryption, table formats, and general * Spark tuning. *

* * @param sparkProperties * Specifies custom jar files and Spark properties for use cases like cluster encryption, table formats, and * general Spark tuning. */ public void setSparkProperties(java.util.Map sparkProperties) { this.sparkProperties = sparkProperties; } /** *

* Specifies custom jar files and Spark properties for use cases like cluster encryption, table formats, and general * Spark tuning. *

* * @param sparkProperties * Specifies custom jar files and Spark properties for use cases like cluster encryption, table formats, and * general Spark tuning. * @return Returns a reference to this object so that method calls can be chained together. */ public EngineConfiguration withSparkProperties(java.util.Map sparkProperties) { setSparkProperties(sparkProperties); return this; } /** * Add a single SparkProperties entry * * @see EngineConfiguration#withSparkProperties * @returns a reference to this object so that method calls can be chained together. */ public EngineConfiguration addSparkPropertiesEntry(String key, String value) { if (null == this.sparkProperties) { this.sparkProperties = new java.util.HashMap(); } if (this.sparkProperties.containsKey(key)) throw new IllegalArgumentException("Duplicated keys (" + key.toString() + ") are provided."); this.sparkProperties.put(key, value); return this; } /** * Removes all the entries added into SparkProperties. * * @return Returns a reference to this object so that method calls can be chained together. */ public EngineConfiguration clearSparkPropertiesEntries() { this.sparkProperties = null; return this; } /** * Returns a string representation of this object. This is useful for testing and debugging. Sensitive data will be * redacted from this string using a placeholder value. * * @return A string representation of this object. * * @see java.lang.Object#toString() */ @Override public String toString() { StringBuilder sb = new StringBuilder(); sb.append("{"); if (getCoordinatorDpuSize() != null) sb.append("CoordinatorDpuSize: ").append(getCoordinatorDpuSize()).append(","); if (getMaxConcurrentDpus() != null) sb.append("MaxConcurrentDpus: ").append(getMaxConcurrentDpus()).append(","); if (getDefaultExecutorDpuSize() != null) sb.append("DefaultExecutorDpuSize: ").append(getDefaultExecutorDpuSize()).append(","); if (getAdditionalConfigs() != null) sb.append("AdditionalConfigs: ").append(getAdditionalConfigs()).append(","); if (getSparkProperties() != null) sb.append("SparkProperties: ").append(getSparkProperties()); sb.append("}"); return sb.toString(); } @Override public boolean equals(Object obj) { if (this == obj) return true; if (obj == null) return false; if (obj instanceof EngineConfiguration == false) return false; EngineConfiguration other = (EngineConfiguration) obj; if (other.getCoordinatorDpuSize() == null ^ this.getCoordinatorDpuSize() == null) return false; if (other.getCoordinatorDpuSize() != null && other.getCoordinatorDpuSize().equals(this.getCoordinatorDpuSize()) == false) return false; if (other.getMaxConcurrentDpus() == null ^ this.getMaxConcurrentDpus() == null) return false; if (other.getMaxConcurrentDpus() != null && other.getMaxConcurrentDpus().equals(this.getMaxConcurrentDpus()) == false) return false; if (other.getDefaultExecutorDpuSize() == null ^ this.getDefaultExecutorDpuSize() == null) return false; if (other.getDefaultExecutorDpuSize() != null && other.getDefaultExecutorDpuSize().equals(this.getDefaultExecutorDpuSize()) == false) return false; if (other.getAdditionalConfigs() == null ^ this.getAdditionalConfigs() == null) return false; if (other.getAdditionalConfigs() != null && other.getAdditionalConfigs().equals(this.getAdditionalConfigs()) == false) return false; if (other.getSparkProperties() == null ^ this.getSparkProperties() == null) return false; if (other.getSparkProperties() != null && other.getSparkProperties().equals(this.getSparkProperties()) == false) return false; return true; } @Override public int hashCode() { final int prime = 31; int hashCode = 1; hashCode = prime * hashCode + ((getCoordinatorDpuSize() == null) ? 0 : getCoordinatorDpuSize().hashCode()); hashCode = prime * hashCode + ((getMaxConcurrentDpus() == null) ? 0 : getMaxConcurrentDpus().hashCode()); hashCode = prime * hashCode + ((getDefaultExecutorDpuSize() == null) ? 0 : getDefaultExecutorDpuSize().hashCode()); hashCode = prime * hashCode + ((getAdditionalConfigs() == null) ? 0 : getAdditionalConfigs().hashCode()); hashCode = prime * hashCode + ((getSparkProperties() == null) ? 0 : getSparkProperties().hashCode()); return hashCode; } @Override public EngineConfiguration clone() { try { return (EngineConfiguration) super.clone(); } catch (CloneNotSupportedException e) { throw new IllegalStateException("Got a CloneNotSupportedException from Object.clone() " + "even though we're Cloneable!", e); } } @com.amazonaws.annotation.SdkInternalApi @Override public void marshall(ProtocolMarshaller protocolMarshaller) { com.amazonaws.services.athena.model.transform.EngineConfigurationMarshaller.getInstance().marshall(this, protocolMarshaller); } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy