【Azure Developer】编写Python SDK代码实现从China Azure中VM Disk中创建磁盘快照Snapshot

本文涉及的产品
可观测监控 Prometheus 版,每月50GB免费额度
性能测试 PTS,5000VUM额度
应用实时监控服务-应用监控,每月50GB免费额度
简介: 本文介绍如何使用Python SDK为中国区微软云(China Azure)中的虚拟机磁盘创建快照。通过Azure Python SDK的Snapshot Class,指定`location`和`creation_data`参数,使用`Copy`选项从现有磁盘创建快照。代码示例展示了如何配置Default Azure Credential,并设置特定于中国区Azure的`base_url`和`credential_scopes`。参考资料包括官方文档和相关API说明。

问题描述

需要为中国区微软云(China Azure)中的虚拟机磁盘(VM Disk)创建快照, 官方文档中只有az cli(az snapshot create)脚本,并没有介绍使用Python SDK的办法,需要编写代码来实现快照的创建。

 

问题解答

Azure Python SDK 的 Snapshot Class文档提供了参数说明,如 location 为创建Snapshot资源的位置(必须填写,如China North 3, China East 2等)。另外,最主要的参数是 creation_data,包含Disk的详细信息。

  • create_option :列举了创建磁盘的可能来源。必填。已知值为:“Empty”、“Attach”、“FromImage”、“Import”、“Copy”、“Restore”、“Upload”、“CopyStart”、“ImportSecure”、“UploadPreparedSecure”和“Import”。本文示例是要从已有的Disk中创建快照用于复制还原,所以选择 Copy 。
  • source_resource_id:此处为源VM Disk的资源ID,如:'/subscriptions/x-x-x-x/resourceGroups/xxxxx/providers/Microsoft.Compute/disks/xxxxxxx'

 

根据以上内容,示例的Python代码如下:


from azure.identity import DefaultAzureCredential
from azure.mgmt.compute import ComputeManagementClient

# Set your subscription ID and resource group name
subscription_id = ' '
resource_group_name = 'xxx-RG'
snapshot_name = 'xxxx'
source_disk_id = '/subscriptions/x-x-x-x/resourceGroups/xxxxx/providers/Microsoft.Compute/disks/xxxxxxx'

# Create a ComputeManagementClient object
credential = DefaultAzureCredential()

compute_client = ComputeManagementClient(credential, subscription_id,base_url="https://management.chinacloudapi.cn/", credential_scopes=["https://management.chinacloudapi.cn/.default"])


# Define the snapshot parameters
snapshot_params = {
    'location': 'China North 3',
    'creation_data': {
        'create_option': 'Copy',
        'source_resource_id': source_disk_id
    }
}

# Create the snapshot
snapshot = compute_client.snapshots.begin_create_or_update(
    resource_group_name,
    snapshot_name,
    snapshot_params
).result()

print(snapshot)

注释

1:使用Default Azure Credential,在执行代码的环境中配置环境变量:AZURE_TENANT_ID, AZURE_CLIENT_ID 和 AZURE_CLIENT_SECRET

2:在中国区Azure中,需要指定 ComputeManagementClient 对象的 base_urlcredential_scopes, 它们的值是固定的。如需要在Global Azure中使用,可以不用这两个参数值。

  • base_url="https://management.chinacloudapi.cn/"
  • credential_scopes=["https://management.chinacloudapi.cn/.default"]

 

代码执行效果图:

 

参考资料

DefaultAzureCredential (EnvironmentCredential) Class : https://learn.microsoft.com/en-us/dotnet/api/azure.identity.environmentcredential?view=azure-dotnet

创建虚拟硬盘的快照 : https://docs.azure.cn/zh-cn/virtual-machines/snapshot-copy-managed-disk?tabs=cli

Snapshot Class : https://learn.microsoft.com/zh-cn/python/api/azure-mgmt-compute/azure.mgmt.compute.v2022_03_02.models.snapshot?view=azure-python

CreationData Class : https://learn.microsoft.com/zh-cn/python/api/azure-mgmt-compute/azure.mgmt.compute.v2022_03_02.models.creationdata?view=azure-python

 

 

 


 

 

当在复杂的环境中面临问题,格物之道需:浊而静之徐清,安以动之徐生。 云中,恰是如此!

相关文章
|
1月前
|
API 开发工具 Python
|
1月前
|
存储 XML 开发工具
【Azure Storage Account】利用App Service作为反向代理, 并使用.NET Storage Account SDK实现上传/下载操作
本文介绍了如何在Azure上使用App Service作为反向代理,以自定义域名访问Storage Account。主要内容包括: 1. **设置反向代理**:通过配置`applicationhost.xdt`和`web.config`文件,启用IIS代理功能并设置重写规则。 2. **验证访问**:测试原生URL和自定义域名的访问效果,确保两者均可正常访问Storage Account。 3. **.NET SDK连接**:使用共享访问签名(SAS URL)初始化BlobServiceClient对象,实现通过自定义域名访问存储服务。
|
5月前
|
Java 开发工具 Windows
【Azure App Service】在App Service中调用Stroage SDK上传文件时遇见 System.OutOfMemoryException
System.OutOfMemoryException: Exception of type 'System.OutOfMemoryException' was thrown.
|
6月前
|
JavaScript 前端开发 开发工具
【Azure Developer】使用JavaScript通过SDK进行monitor-query的client认证报错问题
AADSTS90002: Tenant 'xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx' not found. Check to make sure you have the correct tenant ID and are signing into the correct cloud. Check with your subscription administrator, this may happen if there are no active subscriptions for the tenant.
|
7月前
|
Kubernetes API 开发工具
【Azure Developer】通过SDK(for python)获取Azure服务生命周期信息
需要通过Python SDK获取Azure服务的一些通知信息,如:K8S版本需要更新到指定的版本,Azure服务的维护通知,服务处于不健康状态时的通知,及相关的操作建议等内容。
90 18
|
2月前
|
前端开发 Java Shell
【08】flutter完成屏幕适配-重建Android,增加GetX路由,屏幕适配,基础导航栏-多版本SDK以及gradle造成的关于fvm的使用(flutter version manage)-卓伊凡换人优雅草Alex-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草Alex
【08】flutter完成屏幕适配-重建Android,增加GetX路由,屏幕适配,基础导航栏-多版本SDK以及gradle造成的关于fvm的使用(flutter version manage)-卓伊凡换人优雅草Alex-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草Alex
227 20
【08】flutter完成屏幕适配-重建Android,增加GetX路由,屏幕适配,基础导航栏-多版本SDK以及gradle造成的关于fvm的使用(flutter version manage)-卓伊凡换人优雅草Alex-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草Alex
|
8月前
|
JavaScript 前端开发 Java
[Android][Framework]系统jar包,sdk的制作及引用
[Android][Framework]系统jar包,sdk的制作及引用
225 0
|
5月前
|
Java Linux API
Android SDK
【10月更文挑战第21天】
179 1
|
6月前
|
程序员 开发工具 Android开发
Android|使用阿里云推流 SDK 实现双路推流不同画面
本文记录了一种使用没有原生支持多路推流的阿里云推流 Android SDK,实现同时推送两路不同画面的流的方法。
117 7
|
8月前
|
开发工具 Android开发
解决Android运行出现NDK at /Library/Android/sdk/ndk-bundle did not have a source.properties file
解决Android运行出现NDK at /Library/Android/sdk/ndk-bundle did not have a source.properties file
323 4
解决Android运行出现NDK at /Library/Android/sdk/ndk-bundle did not have a source.properties file
下一篇
oss创建bucket