首页 > 解决方案 > 适用于 Java 的 Google Cloud 客户端库:insertInstance() 导致 UnavailableException

问题描述

我正在尝试使用 Cloud API Client Library for Java 创建一个实例。我已经完成了不同的 Builder 类,使用控制台中的“等效 REST”按钮查看我可能缺少哪些项目,但现在调用insertInstance()返回 UnavailableException。检查控制台我发现没有创建任何内容。谁能帮我找出我做错了什么?所有 URL 似乎都是正确的:当它们不正确时,我会得到一个带有详细错误的有用异常。

常量是我的设置脚本的SETUP_NO_BOT文本,它创建一个用户,从存储桶中复制文件,诸如此类。然而,这不应该是问题,因为那样我会期望一个正在运行的虚拟机在启动日志中出现错误。

我能找到的所有示例都使用了较旧的com.google.api.services包或com.google.cloud.compute.deprecated包,并且都没有使用可比较的类结构。

如果我在 URL 中使用错误的相同代码(现在由getUrl()调用产生),我会得到一个很好的错误返回。此版本始终返回 503。

    private Instance createInstance() {
        logger.debug("createInstance(): Creating boot disk based on \"{}\".", getBaseImage());
        AttachedDiskInitializeParams diskParams;
        if (ifSet(getBaseImageProject())) {
            diskParams = AttachedDiskInitializeParams.newBuilder()
                    .setSourceImage(getUrl(getBaseImageProject(), "images", getBaseImage()))
                    .setDiskSizeGb("10")
                    .setDiskType(getUrl(context, "diskTypes", "pd-standard"))
                    .build();
        }
        else {
            diskParams = AttachedDiskInitializeParams.newBuilder()
                    .setSourceImage(getUrl("images", getBaseImage()))
                    .setDiskSizeGb("10")
                    .setDiskType(getUrl(context, "diskTypes", "pd-standard"))
                    .build();
        }
        AttachedDisk disk = AttachedDisk.newBuilder()
                .setType("PERSISTENT")
                .setBoot(true)
                .setMode("READ_WRITE")
                .setAutoDelete(true)
                .setDeviceName(getName())
                .setInitializeParams(diskParams)
                .build();

        logger.debug("createInstance(): Creating network interface to network \"{}\".", getNetwork());
        AccessConfig accessConfig = AccessConfig.newBuilder()
                .setName("External NAT")
                .setType("ONE_TO_ONE_NAT")
                .setNetworkTier("PREMIUM")
                .build();
        NetworkInterface netIntf = NetworkInterface.newBuilder()
                .setNetwork(getUrl(context, "networks", getNetwork()))
                .setSubnetwork(getRegionalUrl(context, "subnetworks", "default"))
                .addAccessConfigs(accessConfig)
                .build();

        logger.debug("createInstane(): Creating startup script metadata.");
        Items metadataItems = Items.newBuilder()
                .setKey("startup-script")
                .setValue(SETUP_NO_BOT)
                .build();
        Metadata metadata = Metadata.newBuilder()
                .addItems(metadataItems)
                .build();

        logger.debug("createInstance(): Create the instance...");
        Instance inst = Instance.newBuilder()
                .setName(getName())
                .setZone(getUrl(context, "zones", context.getZone()))
                .setMachineType(getZonalUrl(context, "machineTypes", getMachineType()))
                .addDisks(disk)
                .setCanIpForward(false)
                .addNetworkInterfaces(netIntf)
                .setMetadata(metadata)
                .build();
        return gceUtil.createInstance(inst) ? gceUtil.getInstance(getName()) : null;
    }

createInstance 非常简单:

    /**
     * Create an {@link Instance}.
     */
    public boolean createInstance(Instance instance) {
        logger.debug("createInstance(): project = \"{}\", zone = \"{}\".", getProjectName(), getZoneName());

        Operation response = instClient.insertInstance(ProjectZoneName.of(getProjectName(), getZoneName()), instance);

        return isHttp2xx(response);
    }

标签: javaapigoogle-cloud-sdk

解决方案


推荐阅读