本示例介绍如何使用Alibaba Cloud SDK for Java调用RDS的CreateNatGateway接口创建一个NAT网关。

前提条件

  • 使用Alibaba Cloud SDK for Java,您需要一个阿里云账号和访问密钥(AccessKey)。 请在阿里云控制台中的AccessKey管理页面上创建和查看您的AccessKey。
  • 确保您已经安装了Alibaba Cloud SDK for Java,准确的SDK版本号,请参见 阿里云开发工具包(SDK)
    <dependencies>
        <!-- https://mvnrepository.com/artifact/com.aliyun/aliyun-java-sdk-core -->
        <dependency>
            <groupId>com.aliyun</groupId>
            <artifactId>aliyun-java-sdk-core</artifactId>
            <version>4.4.3</version>
        </dependency>
        <!-- https://mvnrepository.com/artifact/com.aliyun/aliyun-java-sdk-vpc -->
        <dependency>
            <groupId>com.aliyun</groupId>
            <artifactId>aliyun-java-sdk-vpc</artifactId>
            <version>3.0.5</version>
        </dependency>
    </dependencies>

示例代码

说明

在调用本接口创建NAT网关时,请注意:

  • 目前不支持NAT网关与自建SNAT网关(使用一台ECS作为SNAT网关)在VPC中并存。
  • NAT网关创建后,系统会在VPC的路由表中自动添加一条目标网段为0.0.0.0/0,下一跳为NAT网关的路由条目,用于将流量路由到NAT网关。
  • 如果在创建NAT网关前,VPC的路由表中已经存在一条目标网段为0.0.0.0/0的路由条目,请先删除该路由条目。否则,无法创建NAT网关。
import java.util.ArrayList;
import java.util.List;
import java.util.UUID;
import com.aliyuncs.DefaultAcsClient;
import com.aliyuncs.IAcsClient;
import com.aliyuncs.exceptions.ClientException;
import com.aliyuncs.profile.DefaultProfile;
import com.aliyuncs.vpc.model.v20160428.CreateNatGatewayRequest;
import com.aliyuncs.vpc.model.v20160428.CreateNatGatewayResponse;
import com.google.gson.Gson;

/**
 * 使用CreateNatGateway接口创建一个NAT网关
 */
public class CreateNatGateway {
    public static void main(String[] args) {
        // 初始化请求参数
        DefaultProfile profile = DefaultProfile.getProfile(
                 "<your-region-id>",// 地域ID
                 "<your-access-key-id>",// 您的AccessKey ID
                 "<your-access-key-secret>");// 您的AccessKey Secret
        IAcsClient client = new DefaultAcsClient(profile);
        // 配置请求参数
        CreateNatGatewayRequest request = new CreateNatGatewayRequest();
        // VPC的ID。
        request.setVpcId("vpc-bp1t36rn9l53iwbsf8x2q");
        //  随机字符串,用于保证请求的幂等性。
        request.setClientToken(UUID.randomUUID().toString());
        // NAT网关的描述
        request.setDescription("test test test test");
        // Nat网关的名称
        request.setName("hhh112233");
        // NAT网关的规格。
        // 取值:小型 Small(默认值):中型 Middle:大型 Large:超大型 XLarge.1:
        request.setSpec("Small");

        // 构建BandwidthPackage参数
        List<CreateNatGatewayRequest.BandwidthPackage> bandwidthPackageList = new ArrayList<CreateNatGatewayRequest.BandwidthPackage>();
        CreateNatGatewayRequest.BandwidthPackage bandwidthPackage1 = new CreateNatGatewayRequest.BandwidthPackage();
        // NAT带宽包中的公网IP数量,取值范围:1-50。
        bandwidthPackage1.setIpCount(5);
        // 第N个共享带宽包的带宽值,取值范围:5-5000
        bandwidthPackage1.setBandwidth(5);
        // 第n个共享带宽包的可用区。不指定该参数时,系统将随机分配一个可用区。
        bandwidthPackage1.setZone("cn-hangzhou-b");
        // 第n个共享带宽包中的线路ISP类型,默认为BGP(多线)。
        bandwidthPackage1.setISP("BGP");
        bandwidthPackageList.add(bandwidthPackage1);
        request.setBandwidthPackages(bandwidthPackageList);

        try {
            // 发送请求获取返回结果
            CreateNatGatewayResponse response = client.getAcsResponse(request);
            // 处理返回结果
            System.out.println(new Gson().toJson(response));
        } catch (ClientException e) {
            System.out.println("ErrCode:" + e.getErrCode());
            System.out.println("ErrMsg:" + e.getErrMsg());
            System.out.println("RequestId:" + e.getRequestId());
        }
    }
}
			
说明 更多参数和接口信息,请参见API概览