加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 综合聚焦 > 服务器 > Windows > 正文

windows azure rest api – 创建虚拟机

发布时间:2020-12-14 03:59:09 所属栏目:Windows 来源:网络整理
导读:我正在研究使用 Windows Azure REST API在Windows Azure环境中创建虚拟机.查看Windows Azure REST API reference,我发现应该向POST请求发出的URL是: https://management.core.windows.net/subscription-id/services/hostedservices/cloudservice-name/deplo
我正在研究使用 Windows Azure REST API在Windows Azure环境中创建虚拟机.查看Windows Azure REST API reference,我发现应该向POST请求发出的URL是:

https://management.core.windows.net/<subscription-id>/services/hostedservices/<cloudservice-name>/deployments/<deployment-name>/roles

我在这里的困惑是关于< cloudservice-name>的需要.和< deployment-name>.实际上,如果我直接登录到我的Windows Azure订阅门户并通过菜单创建虚拟机,我就不必指定cloudservice-name或deployment-name.我所做的就是为VM选择一个图像(centos,ubuntu,windows等),为VM选择一个风格(xsmall,small,large等)并单击“Create”,几分钟后创建VM .

鉴于我可以通过这种方式创建VM,我无法理解为什么我必须传递< cloudservice-name>和< deployment-name> REST API curl调用中的参数以及传递给这些参数的值.事实上,我的订阅中没有部署,也没有打算订阅.我想要的只是创建一个我可以使用的虚拟机.

我是否可以跳过这些参数,仍然可以在Azure订阅中创建虚拟机?即只是通过传递< subscription-id>?

以前使用Windows Azure REST API的人或者具有Windows Azure专业知识的人是否会对此有所了解并帮助澄清?

更新于2013年7月31日星期三:再次感谢您对我的问题的反馈.我想更新一下,我能够最终使用REST API调用创建虚拟机.但奇怪的是,创建虚拟机只能成功运行一次.随后,当我尝试使用不同的名称创建VM时,它出现了“暂存部署被阻止”之类的错误.因此,为了理智,我继续删除现有的VM并进行了一些帐户清理.我尝试了POST操作再次创建VM,现在发生的事情是POST响应回复正常,带有202 Accepted消息,但尽管如此,我还是看不到在我的Azure帐户中创建的VM.我不知道在哪里以及如何开始解决这个问题,因为我既没有收到错误,也没有创建VM.

我发布在我发布的用于创建VM的整个XML请求主体下面:

<Deployment xmlns="http://schemas.microsoft.com/windowsazure" xmlns:i="http://www.w3.org/2001/XMLSchema-instance">
  <Name>Staging</Name>
  <DeploymentSlot>Staging</DeploymentSlot>
  <Label>stk_curl_label_1</Label>
  <RoleList>
    <Role>
      <RoleName>stk_curl_role_1</RoleName>
      <RoleType>PersistentVMRole</RoleType>
      <ConfigurationSets>
        <ConfigurationSet>
          <ConfigurationSetType>WindowsProvisioningConfiguration</ConfigurationSetType>
          <ComputerName>stkVm1</ComputerName>
          <AdminPassword>Password123</AdminPassword>
          <EnableAutomaticUpdates>false</EnableAutomaticUpdates>
        </ConfigurationSet>
      </ConfigurationSets>
      <OSVirtualHardDisk>
        <HostCaching>ReadWrite</HostCaching>
        <DiskLabel>Visual studio ultimate</DiskLabel>
        <DiskName>stk_disk_1</DiskName>
        <MediaLink>http://stk11.blob.core.windows.net/communityimages/visual_studio_ultimate.vhd</MediaLink>
        <SourceImageName>03f55de797f546a1b29d1b8d66be687a__Visual-Studio-2013-Preview-Ultimate-12.0.20617.1</SourceImageName>
      </OSVirtualHardDisk>
      <RoleSize>ExtraSmall</RoleSize>
    </Role>
  </RoleList>
</Deployment>

而且我正在接受我收到的卷曲电话响应的尾部:

> User-Agent: curl/7.15.5 (x86_64-redhat-linux-gnu) libcurl/7.15.5 OpenSSL/0.9.8b zlib/1.2.3 libidn/0.6.5
> Host: management.core.windows.net
> Accept: */*
> x-ms-version: 2012-03-01
> Content-Type: application/xml
> Content-Length: 1236
> Expect: 100-continue
>
* SSLv3,TLS handshake,Hello request (0):
SSLv3,Client hello (1):
SSLv3,Server hello (2):
SSLv3,CERT (11):
SSLv3,Request CERT (13):
SSLv3,Server finished (14):
SSLv3,Client key exchange (16):
SSLv3,CERT verify (15):
SSLv3,TLS change cipher,Finished (20):
SSLv3,Finished (20):
HTTP/1.1 100 Continue
HTTP/1.1 202 Accepted
< Cache-Control: no-cache
< Content-Length: 0
< Server: 33.0.6198.68 (rd_rdfe_stable.130710-0833) Microsoft-HTTPAPI/2.0
< x-ms-servedbyregion: ussouth
< x-ms-request-id: b2f3dd01319049a5a6728bbdbcde6c4a
< Date: Wed,31 Jul 2013 17:26:54 GMT
* Connection #0 to host management.core.windows.net left intact
* Closing connection #0
* SSLv3,TLS alert,Client hello (1):

你可以清楚地看到,它是一个“202 Accepted”响应.但正如我之前提到的,尽管如此,当我查看我的Azure帐户时,我看不到正在创建VM.

非常感谢任何有关如何找出导致其无法正常工作的根本原因的专家见解/想法?

解决方法

你所看到的是门户幕后的一点魔力.部署虚拟机时,它确实最终位于Cloud Service容器中.最近这个更改在门户网站中变得更加明显,之前他们正在隐藏这个.当人们删除VM或将其他VM添加到同一组(以前称为“附加到”)时,云服务将显示在门户中.人们对这是什么感到困惑,只是引起了更多的问题.

现在,在门户中,系统会提示您提供云服务.如果您在快速创建时询问DNS名称(并在其旁边显示.cloudapp.net),那么这就是您提供的Cloud Service名称.当您通过Gallery进行创建时,在第3步中要求创建新的Cloud Service或选择已存在的Cloud Service更为明显.

要通过REST API执行所需操作,您需要提前创建云服务,或者在创建VM之前调用.此外,您提供的链接用于添加Cloud Service角色,而不是创建虚拟机.对于那个REST API调用,您将要使用它:http://msdn.microsoft.com/en-us/library/windowsazure/jj157194.aspx它仍然需要云服务,但不需要部署名称.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读