JClouds:如何将新卷附加到 AWS EC2 实例

JClouds: How to attach a new volume to an AWS EC2 instance

我正在尝试使用 JClouds 将新卷附加到我的实例。但是我找不到办法。

    final String POLL_PERIOD_TWENTY_SECONDS = String.valueOf(SECONDS.toMillis(20));

    Properties overrides = new Properties();
    overrides.setProperty(ComputeServiceProperties.POLL_INITIAL_PERIOD, POLL_PERIOD_TWENTY_SECONDS);
    overrides.setProperty(ComputeServiceProperties.POLL_MAX_PERIOD, POLL_PERIOD_TWENTY_SECONDS);

    Iterable<Module> modules = ImmutableSet.<Module> of(new SshjSshClientModule(), new SLF4JLoggingModule());
    //Iterable<Module> modules = ImmutableSet.<Module> of(new SshjSshClientModule());

    ComputeServiceContext context = ContextBuilder.newBuilder("aws-ec2")
            .credentials("valid user", "valid password")
            .modules(modules)
            .overrides(overrides)
            .buildView(ComputeServiceContext.class);
    ComputeService computeService = context.getComputeService();

    // Ubuntu AMI
    Template template = computeService.templateBuilder()
            .locationId("us-east-1")
            .imageId("us-east-1/ami-7c807d14")
            .hardwareId("t1.micro")
            .build();

    // This line creates the volume but does not attach it
    template.getOptions().as(EC2TemplateOptions.class).mapNewVolumeToDeviceName("/dev/sdm", 100, true);

    Set<? extends NodeMetadata> nodes = computeService.createNodesInGroup("m456", 1, template);

    for (NodeMetadata nodeMetadata : nodes) {
        String publicAddress = nodeMetadata.getPublicAddresses().iterator().next();
        //String privateAddress = nodeMetadata.getPrivateAddresses().iterator().next();
        String username = nodeMetadata.getCredentials().getUser();
        String password = nodeMetadata.getCredentials().getPassword();
        // [...]
        System.out.println(String.format("ssh %s@%s  %s", username, publicAddress, password));
        System.out.println(nodeMetadata.getCredentials().getPrivateKey());
    }

如何创建附加卷到目录“/var”? 如何创建具有更多硬盘 space 的实例?

您可以使用 jclouds 中的 ElasticBlockStoreApi。您已经创建了实例,所以像这样创建并附加卷:

// Get node
NodeMetadata node = Iterables.getOnlyElement(nodes);

// Get AWS EC2 API
EC2Api ec2Api = computeServiceContext.unwrapApi(EC2Api.class);

// Create 100 GiB Volume
Volume volume = ec2Api.getElasticBlockStoreApi().get()
        .createVolumeInAvailabilityZone(zoneId, 100);

// Attach to instance
Attachment attachment = ec2Api.getElasticBlockStoreApi().get()
        .attachVolumeInRegion(region, volume.getId(), node.getId(), "/dev/sdx");

现在,你已经连接了一个 EBS 卷,并且 VM 已经为它创建了一个块设备,你只需要 运行 正确的命令将它挂载到 /var 目录,这将取决于您的特定操作系统。您可以 运行 这样的脚本:

// Run script on instance
computeService.runScriptOnNode(node.getId(),
        Statements.exec("mount /dev/sdx /var"));