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

com.aliyun.sdk.service.ecs20140526.models.ModifyInstanceAttributeRequest Maven / Gradle / Ivy

// This file is auto-generated, don't edit it. Thanks.
package com.aliyun.sdk.service.ecs20140526.models;

import com.aliyun.core.annotation.*;
import darabonba.core.RequestModel;
import darabonba.core.TeaModel;
import com.aliyun.sdk.gateway.pop.models.*;

/**
 * {@link ModifyInstanceAttributeRequest} extends {@link RequestModel}
 *
 * 

ModifyInstanceAttributeRequest

*/ public class ModifyInstanceAttributeRequest extends Request { @Query @NameInMap("CpuOptions") private CpuOptions cpuOptions; @Host @NameInMap("SourceRegionId") private String sourceRegionId; @Query @NameInMap("CreditSpecification") private String creditSpecification; @Query @NameInMap("DeletionProtection") private Boolean deletionProtection; @Query @NameInMap("Description") private String description; @Query @NameInMap("EnableJumboFrame") private Boolean enableJumboFrame; @Query @NameInMap("HostName") private String hostName; @Query @NameInMap("InstanceId") @Validation(required = true) private String instanceId; @Query @NameInMap("InstanceName") private String instanceName; @Query @NameInMap("NetworkInterfaceQueueNumber") private Integer networkInterfaceQueueNumber; @Query @NameInMap("OwnerAccount") private String ownerAccount; @Query @NameInMap("OwnerId") private Long ownerId; @Query @NameInMap("Password") private String password; @Query @NameInMap("Recyclable") private Boolean recyclable; @Query @NameInMap("RemoteConnectionOptions") private RemoteConnectionOptions remoteConnectionOptions; @Query @NameInMap("ResourceOwnerAccount") private String resourceOwnerAccount; @Query @NameInMap("ResourceOwnerId") private Long resourceOwnerId; @Query @NameInMap("SecurityGroupIds") private java.util.List < String > securityGroupIds; @Query @NameInMap("UserData") private String userData; private ModifyInstanceAttributeRequest(Builder builder) { super(builder); this.cpuOptions = builder.cpuOptions; this.sourceRegionId = builder.sourceRegionId; this.creditSpecification = builder.creditSpecification; this.deletionProtection = builder.deletionProtection; this.description = builder.description; this.enableJumboFrame = builder.enableJumboFrame; this.hostName = builder.hostName; this.instanceId = builder.instanceId; this.instanceName = builder.instanceName; this.networkInterfaceQueueNumber = builder.networkInterfaceQueueNumber; this.ownerAccount = builder.ownerAccount; this.ownerId = builder.ownerId; this.password = builder.password; this.recyclable = builder.recyclable; this.remoteConnectionOptions = builder.remoteConnectionOptions; this.resourceOwnerAccount = builder.resourceOwnerAccount; this.resourceOwnerId = builder.resourceOwnerId; this.securityGroupIds = builder.securityGroupIds; this.userData = builder.userData; } public static Builder builder() { return new Builder(); } public static ModifyInstanceAttributeRequest create() { return builder().build(); } @Override public Builder toBuilder() { return new Builder(this); } /** * @return cpuOptions */ public CpuOptions getCpuOptions() { return this.cpuOptions; } /** * @return sourceRegionId */ public String getSourceRegionId() { return this.sourceRegionId; } /** * @return creditSpecification */ public String getCreditSpecification() { return this.creditSpecification; } /** * @return deletionProtection */ public Boolean getDeletionProtection() { return this.deletionProtection; } /** * @return description */ public String getDescription() { return this.description; } /** * @return enableJumboFrame */ public Boolean getEnableJumboFrame() { return this.enableJumboFrame; } /** * @return hostName */ public String getHostName() { return this.hostName; } /** * @return instanceId */ public String getInstanceId() { return this.instanceId; } /** * @return instanceName */ public String getInstanceName() { return this.instanceName; } /** * @return networkInterfaceQueueNumber */ public Integer getNetworkInterfaceQueueNumber() { return this.networkInterfaceQueueNumber; } /** * @return ownerAccount */ public String getOwnerAccount() { return this.ownerAccount; } /** * @return ownerId */ public Long getOwnerId() { return this.ownerId; } /** * @return password */ public String getPassword() { return this.password; } /** * @return recyclable */ public Boolean getRecyclable() { return this.recyclable; } /** * @return remoteConnectionOptions */ public RemoteConnectionOptions getRemoteConnectionOptions() { return this.remoteConnectionOptions; } /** * @return resourceOwnerAccount */ public String getResourceOwnerAccount() { return this.resourceOwnerAccount; } /** * @return resourceOwnerId */ public Long getResourceOwnerId() { return this.resourceOwnerId; } /** * @return securityGroupIds */ public java.util.List < String > getSecurityGroupIds() { return this.securityGroupIds; } /** * @return userData */ public String getUserData() { return this.userData; } public static final class Builder extends Request.Builder { private CpuOptions cpuOptions; private String sourceRegionId; private String creditSpecification; private Boolean deletionProtection; private String description; private Boolean enableJumboFrame; private String hostName; private String instanceId; private String instanceName; private Integer networkInterfaceQueueNumber; private String ownerAccount; private Long ownerId; private String password; private Boolean recyclable; private RemoteConnectionOptions remoteConnectionOptions; private String resourceOwnerAccount; private Long resourceOwnerId; private java.util.List < String > securityGroupIds; private String userData; private Builder() { super(); } private Builder(ModifyInstanceAttributeRequest request) { super(request); this.cpuOptions = request.cpuOptions; this.sourceRegionId = request.sourceRegionId; this.creditSpecification = request.creditSpecification; this.deletionProtection = request.deletionProtection; this.description = request.description; this.enableJumboFrame = request.enableJumboFrame; this.hostName = request.hostName; this.instanceId = request.instanceId; this.instanceName = request.instanceName; this.networkInterfaceQueueNumber = request.networkInterfaceQueueNumber; this.ownerAccount = request.ownerAccount; this.ownerId = request.ownerId; this.password = request.password; this.recyclable = request.recyclable; this.remoteConnectionOptions = request.remoteConnectionOptions; this.resourceOwnerAccount = request.resourceOwnerAccount; this.resourceOwnerId = request.resourceOwnerId; this.securityGroupIds = request.securityGroupIds; this.userData = request.userData; } /** * CpuOptions. */ public Builder cpuOptions(CpuOptions cpuOptions) { this.putQueryParameter("CpuOptions", cpuOptions); this.cpuOptions = cpuOptions; return this; } /** * SourceRegionId. */ public Builder sourceRegionId(String sourceRegionId) { this.putHostParameter("SourceRegionId", sourceRegionId); this.sourceRegionId = sourceRegionId; return this; } /** * The performance mode of the burstable instance. Valid values: *

* * * Standard * * Unlimited * * For more information about the performance modes of burstable instances, see [Overview](~~59977~~). */ public Builder creditSpecification(String creditSpecification) { this.putQueryParameter("CreditSpecification", creditSpecification); this.creditSpecification = creditSpecification; return this; } /** * The release protection attribute of the instance. This parameter specifies whether you can use the ECS console or call the [DeleteInstance](~~25507~~) operation to release the instance. *

* * > This parameter is applicable only to pay-as-you-go instances. The release protection attribute can protect instances against manual releases, but not against automatic releases. */ public Builder deletionProtection(Boolean deletionProtection) { this.putQueryParameter("DeletionProtection", deletionProtection); this.deletionProtection = deletionProtection; return this; } /** * The instance description. The description must be 2 to 256 characters in length, and cannot start with `http://` or `https://`. *

* * This parameter is empty by default. */ public Builder description(String description) { this.putQueryParameter("Description", description); this.description = description; return this; } /** * Specifies whether to enable the Jumbo Frame feature for the MTU of the instance. *

* * * true * * * false * * You can enable the Jumbo Frame feature for only specific instance types. For more information, see [MTUs](~~200512~~). */ public Builder enableJumboFrame(Boolean enableJumboFrame) { this.putQueryParameter("EnableJumboFrame", enableJumboFrame); this.enableJumboFrame = enableJumboFrame; return this; } /** * The hostname of the instance. Take note of the following items: *

* * * When you modify the hostname of an instance, the instance must not be in the Creating (Pending) or Starting (Starting) state. Otherwise, the new hostname and the configurations in `/etc/hosts` cannot take effect. You can call the [DescribeInstances](~~25506~~) operation to query the state of the instance. * * After you modify the hostname, you must call the [RebootInstance](~~25502~~) operation for the new hostname to take effect. * * The following limits apply to the hostnames of instances that run different operating systems: * * * For Windows Server, the hostname must be 2 to 15 characters in length and can contain letters, digits, and hyphens (-). It cannot start or end with a hyphen (-), contain consecutive hyphens (-), or contain only digits. * * For other operating systems such as Linux, the hostname must be 2 to 64 characters in length. You can use periods (.) to separate a hostname into multiple segments. Each segment can contain letters, digits, and hyphens (-). The hostname cannot contain consecutive periods (.) or hyphens (-). It cannot start or end with a period (.) or a hyphen (-). */ public Builder hostName(String hostName) { this.putQueryParameter("HostName", hostName); this.hostName = hostName; return this; } /** * The instance ID. */ public Builder instanceId(String instanceId) { this.putQueryParameter("InstanceId", instanceId); this.instanceId = instanceId; return this; } /** * The name of the instance. The name must be 2 to 128 characters in length. It must start with a letter but cannot start with `http://` or `https://`. It can contain letters, digits, colons (:), underscores (\_), and hyphens (-). */ public Builder instanceName(String instanceName) { this.putQueryParameter("InstanceName", instanceName); this.instanceName = instanceName; return this; } /** * The number of queues supported by the primary ENI. */ public Builder networkInterfaceQueueNumber(Integer networkInterfaceQueueNumber) { this.putQueryParameter("NetworkInterfaceQueueNumber", networkInterfaceQueueNumber); this.networkInterfaceQueueNumber = networkInterfaceQueueNumber; return this; } /** * OwnerAccount. */ public Builder ownerAccount(String ownerAccount) { this.putQueryParameter("OwnerAccount", ownerAccount); this.ownerAccount = ownerAccount; return this; } /** * OwnerId. */ public Builder ownerId(Long ownerId) { this.putQueryParameter("OwnerId", ownerId); this.ownerId = ownerId; return this; } /** * The password of the instance. The password must be 8 to 30 characters in length and contain at least three of the following character types: uppercase letters, lowercase letters, digits, and special characters. Special characters include: *

* * ``` * * ()`~!@#$%^&*-_+=|{}[]:;\"<>,.?/ * * ``` * * For Windows instances, passwords cannot start with a forward slash (/). * * > For security reasons, we recommend that you use HTTPS to send requests if `Password` is specified. */ public Builder password(String password) { this.putQueryParameter("Password", password); this.password = password; return this; } /** * > This parameter is in invitational preview and is not publicly available. */ public Builder recyclable(Boolean recyclable) { this.putQueryParameter("Recyclable", recyclable); this.recyclable = recyclable; return this; } /** * > This parameter is in invitational preview and is not publicly available. */ public Builder remoteConnectionOptions(RemoteConnectionOptions remoteConnectionOptions) { this.putQueryParameter("RemoteConnectionOptions", remoteConnectionOptions); this.remoteConnectionOptions = remoteConnectionOptions; return this; } /** * ResourceOwnerAccount. */ public Builder resourceOwnerAccount(String resourceOwnerAccount) { this.putQueryParameter("ResourceOwnerAccount", resourceOwnerAccount); this.resourceOwnerAccount = resourceOwnerAccount; return this; } /** * ResourceOwnerId. */ public Builder resourceOwnerId(Long resourceOwnerId) { this.putQueryParameter("ResourceOwnerId", resourceOwnerId); this.resourceOwnerId = resourceOwnerId; return this; } /** * The IDs of replacement security groups. *

* * * All security group IDs must be unique. * * The instance is moved from the current security groups to the replacement security groups. If you want the instance to remain in the current security groups, you must add the IDs of the current security groups to the list. * * You can move the instance to security groups of a different type. However, the list cannot contain the IDs of both basic and advanced security groups. * * The specified security groups and instance must belong to the same virtual private cloud (VPC). * * The valid values of N are based on the maximum number of security groups to which the instance can belong. For more information, see [Limits](~~25412#SecurityGroupQuota1~~). * * New security groups become valid for the instance after a short latency. */ public Builder securityGroupIds(java.util.List < String > securityGroupIds) { this.putQueryParameter("SecurityGroupIds", securityGroupIds); this.securityGroupIds = securityGroupIds; return this; } /** * The user data of the instance. User data must be encoded in Base64. *

* * The size of the user data cannot exceed 16 KB before it is encoded in Base64. We recommend that you do not pass in confidential information such as passwords and private keys in plaintext. If you must pass in confidential information, we recommend that you encrypt and Base64-encode the information before you pass it in. Then, you can decode and decrypt the information in the same way within the instance. */ public Builder userData(String userData) { this.putQueryParameter("UserData", userData); this.userData = userData; return this; } @Override public ModifyInstanceAttributeRequest build() { return new ModifyInstanceAttributeRequest(this); } } public static class CpuOptions extends TeaModel { @NameInMap("TopologyType") private String topologyType; private CpuOptions(Builder builder) { this.topologyType = builder.topologyType; } public static Builder builder() { return new Builder(); } public static CpuOptions create() { return builder().build(); } /** * @return topologyType */ public String getTopologyType() { return this.topologyType; } public static final class Builder { private String topologyType; /** * The CPU topology type of the instance. Valid values: *

* * - ContinuousCoreToHTMapping: The Hyper-Threading (HT) technology allows continuous threads to run on the same core in the CPU topology of the instance. * * - DiscreteCoreToHTMapping: The HT technology allows discrete threads to run on the same core in the CPU topology of the instance. * * This parameter is empty by default. * * >- This parameter is supported only by specific instance families. For more information about the supported instance families, see [View and modify the CPU topology](~~2636059~~). * >- Before you specify this parameter, make sure that the instance is in the Stopped state. */ public Builder topologyType(String topologyType) { this.topologyType = topologyType; return this; } public CpuOptions build() { return new CpuOptions(this); } } } public static class RemoteConnectionOptions extends TeaModel { @NameInMap("Password") private String password; @NameInMap("Type") private String type; private RemoteConnectionOptions(Builder builder) { this.password = builder.password; this.type = builder.type; } public static Builder builder() { return new Builder(); } public static RemoteConnectionOptions create() { return builder().build(); } /** * @return password */ public String getPassword() { return this.password; } /** * @return type */ public String getType() { return this.type; } public static final class Builder { private String password; private String type; /** * > This parameter is in invitational preview and is not publicly available. */ public Builder password(String password) { this.password = password; return this; } /** * > This parameter is in invitational preview and is not publicly available. */ public Builder type(String type) { this.type = type; return this; } public RemoteConnectionOptions build() { return new RemoteConnectionOptions(this); } } } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy