Azure REST API (4) 在Python环境下,使用Azure REST API
《Windows Azure Platform 系列文章目录》
之前遇到的项目中,客户需要在Python环境下,监控Azure VM的CPU利用率,在这里简单记录一下。
笔者的环境是Windows 10,如果需要Python开发,首先需要准备以下环境:
1.安装Python,下载地址:https://www.python.org/downloads/,我这里分别安装了Python 2.7.15和Python 3.7.0
2.安装PyCharm,下载地址:https://www.jetbrains.com/pycharm/download/#section=windows
选择导入开发环境配置文件,我们选择不导入。
3.配置PyCharm,我们配置运行环境:

4.因为笔者用的是Azure China服务,我们在上图中,需要增加相应的package。我们查询到package名字为mcazurerm

5.然后对mcazurerm进行配置,我们点击External Libraries,Site-packages,mcazurerm,然后点击settings.py
增加SNAPSHOT_API = '2016-04-30-preview'。如下图:

6.获得azure tenant id, appid, app secret, 订阅id,资源组名称,虚拟机名称。具体可以参考之前的内容:
https://www.cnblogs.com/threestone/p/9343146.html
7.vmlist.py的代码如下,分别实现了2个方法,list VM和获得CPU利用率。
#!/usr/bin/env python
# -*- coding:utf8 -*-
import xdrlib ,sys
import xlrd
import mcazurerm
import json
import mcazurerm.restfns
#from restfns import do_delete, do_get, do_get_next, do_patch, do_post, do_put
#from settings import azure_rm_endpoint, SNAPSHOT_API
#from adalfns import get_access_token
import datetime tenant_id = '这里输入tenantid'
app_id = '这里输入appid'
app_secret = '这里输入appsecret' subscription_id = '这里输入订阅ID' location = 'chinaeast'
rg = '这里输入资源组名称'
vmname = '这里输入Azure RM机器名'
vmname2= '这里输入另外要监控的机器名' newapiversion='2016-09-01'
# create an authentication token
access_token = mcazurerm.get_access_token(
tenant_id,
app_id,
app_secret
) def listvm(access_token, subscription_id, resource_group):
endpoint = ''.join([mcazurerm.settings.azure_rm_endpoint,
'/subscriptions/', subscription_id,
'/resourceGroups/', resource_group,
'/providers/Microsoft.Compute/virtualMachines',
'?api-version=', mcazurerm.settings.SNAPSHOT_API])
return mcazurerm.restfns.do_get(endpoint,access_token) def GetCPU(access_toke,subscription_id,resource_group):
endpoint = "".join([mcazurerm.settings.azure_rm_endpoint,
"/subscriptions/", subscription_id,
"/resourceGroups/", resource_group,
"/providers/Microsoft.Compute/virtualMachines/",vmname,
"/providers/microsoft.insights/metrics"
"?$filter=(name.value eq 'Percentage CPU') and timeGrain eq duration'PT1M'",
" and startTime eq 2018-08-22T08:19:26.2644638Z and endTime eq 2018-08-23T08:19:29.0454921Z",
"&api-version=",newapiversion
]) print(endpoint)
return mcazurerm.restfns.do_get(endpoint,access_token) def GetNetworkIn(access_toke,subscription_id,resource_group):
endpoint = "".join([mcazurerm.settings.azure_rm_endpoint,
"/subscriptions/", subscription_id,
"/resourceGroups/", resource_group,
"/providers/Microsoft.Compute/virtualMachines/",vmname,
"/providers/microsoft.insights/metrics"
"?$filter=(name.value eq 'Network In') and timeGrain eq duration'PT1M'",
" and startTime eq 2018-08-22T08:19:26.2644638Z and endTime eq 2018-08-23T08:19:29.0454921Z",
"&api-version=",newapiversion
]) return mcazurerm.restfns.do_get(endpoint,access_token) #https://docs.microsoft.com/en-us/rest/api/monitor/activitylogs/list#get_activity_logs_with_filter_and_select #By reource group
def GetOperationByResourceGroup(access_toke,subscription_id,resource_group):
endpoint = "".join([mcazurerm.settings.azure_rm_endpoint,
"/subscriptions/", subscription_id,
"/providers/microsoft.insights/eventtypes/management/values",
"?api-version=", newapiversion,
"&$filter=eventTimestamp ge '2018-08-01T20:00:00Z' and eventTimestamp le '2018-08-23T20:00:00Z' and resourceGroupName eq '",rg,
"'" ])
return mcazurerm.restfns.do_get(endpoint,access_token) #by resource URI
resourceuri="".join(["/subscriptions/",subscription_id ,"/resourceGroups/",rg,
"/providers/Microsoft.Compute/VirtualMachines/",vmname2]) def GetOperationByResourceURI(access_toke,subscription_id,resource_group):
endpoint = "".join([mcazurerm.settings.azure_rm_endpoint,
"/subscriptions/", subscription_id,
"/providers/microsoft.insights/eventtypes/management/values",
"?api-version=", newapiversion,
"&$filter=eventTimestamp ge '2018-08-01T20:00:00Z' and eventTimestamp le '2018-08-23T20:00:00Z' and resourceUri eq '",resourceuri,
"'" ])
return mcazurerm.restfns.do_get(endpoint,access_token) vmlistreturn1 = listvm(access_token,subscription_id,rg)
vmlistreturn2 = GetCPU(access_token,subscription_id,rg) vmlistreturn3 = GetNetworkIn(access_token,subscription_id,rg)
vmlistreturn4 = GetOperationByResourceGroup(access_token,subscription_id,rg)
vmlistreturn5 = GetOperationByResourceURI(access_token,subscription_id,rg) print(vmlistreturn2)
print(vmlistreturn3)
print(vmlistreturn4)
print(vmlistreturn5)
8.其他REST API,可以参考Azure MSDN文档:
https://docs.microsoft.com/en-us/rest/api/compute/virtualmachines
9.另外如果需要监控Azure China CDN流量的话,请参考下面的内容。我们点击下图的CDN Manage

10.在弹出的窗口中,找到安全管理,秘钥管理。如下图:

11.点击创建秘钥,如下图:

12.获取到秘钥的ID和Key

13.在Python中,增加如下代码:
cdnsubscription_id = 'CDN所在的订阅ID'
cdnendpoint_id='CDN上面的Endpoint ID,具体的返回方法请参考下面的步骤' apiversion='1.0'
cdnkeyid='输入上面步骤的cdnkeyid'
cdnkeyvalue='输入上面步骤的cdnkey value' def calculate_authorization_header(request_url, request_time, key_id, key_value, http_method):
""" Calculate the authorization header.
@request_url: Complete request URL with scheme, host, path and queries
@request_time: UTC request time with format yyyy-MM-dd hh:mm:ss
@key_id: API key ID
@key_value: API key value
@http_method: Http method in upper case """
urlparts = urlparse.urlparse(request_url)
queries = urlparse.parse_qs(urlparts.query)
ordered_queries = collections.OrderedDict(sorted(queries.items()))
message = "%s\r\n%s\r\n%s\r\n%s" % (urlparts.path, ", ".join(['%s:%s' % (key, value[0]) for (key, value) in ordered_queries.items()]), request_time, http_method)
digest = hmac.new(bytearray(key_value, "utf-8"), bytearray(message, "utf-8"), hashlib.sha256).hexdigest().upper()
return "AzureCDN %s:%s" % (key_id, digest) requesturl= "".join(["https://restapi.cdn.azure.cn/subscriptions/", cdnsubscription_id,
"/endpoints?apiVersion=",apiversion
])
currentUTCTime = datetime.datetime.utcnow().strftime("%Y-%m-%d %H:%M:%S")
CDNheader = calculate_authorization_header(requesturl,currentUTCTime,cdnkeyid,cdnkeyvalue,'GET') #这个接口 返回CDN Endpoint ID
CDNlist= mcazurerm.restfns.do_CDNget(requesturl,currentUTCTime,CDNheader) #https://docs.azure.cn/zh-cn/cdn/cdn-api-get-subscription-volume
#startTime yyyy-MM-ddThh:mm:ssZ
#endTime yyyy-MM-ddThh:mm:ssZ
#granularity PerFiveMinutes,PerHour,PerDay requesturl= "".join(["https://restapi.cdn.azure.cn/subscriptions/", cdnsubscription_id,
"/endpoints/",cdnendpoint_id,
"/volume?apiVersion=",apiversion,
"&startTime=2018-08-18T00:00:00Z&endTime=2018-08-20T06:32:53Z&granularity=PerHour"
]) currentUTCTime = datetime.datetime.utcnow().strftime("%Y-%m-%d %H:%M:%S")
CDNheader = calculate_authorization_header(requesturl,currentUTCTime,cdnkeyid,cdnkeyvalue,'GET')
CDNlist= mcazurerm.restfns.do_CDNget(requesturl,currentUTCTime,CDNheader)
14.修改restfns.py,增加方法:
def do_CDNget(endpoint, requestdate, access_token):
headers = {
"x-azurecdn-request-date": requestdate,
"Authorization": access_token
}
return requests.get(endpoint, headers=headers).json()
Azure REST API (4) 在Python环境下,使用Azure REST API的更多相关文章
- Python环境下NIPIR(ICTCLAS2014)中文分词系统使用攻略
一.安装 官方链接:http://pynlpir.readthedocs.org/en/latest/installation.html 官方网页中介绍了几种安装方法,大家根据个人需要,自行参考!我采 ...
- python环境下实现OrangePi Zero寄存器访问及GPIO控制
最近入手OrangePi Zero一块,程序上需要使用板子上自带的LED灯,在网上一查,不得不说OPi的支持跟树莓派无法相比.自己摸索了一下,实现简单的GPIO控制方法,作者的Zero安装的是Armb ...
- 图像处理基本工具——Python 环境下的 Pillow( PIL )
由于笔者近期的研究课题与图像后处理有关,需要通过图像处理工具对图像进行变换和处理,进而生成合适的训练图像数据.该系列文章即主要记录笔者在不同的环境下进行图像处理时常用的工具和库.在 Python 环境 ...
- 关于python环境下的opencv安装
吐槽: 这一天我终于记起了这个博客.今天搞python环境下的opencv,又弄了一天,很烦躁.之前配置VS的opencv也是花了好久的时间,然后突然发现之前记录在电脑上的文档都找不到了,于是决定还是 ...
- windows下多Python环境指定pip安装模块到对应Python环境下
专栏:Python基础教程目录 专栏:使用PyQt开发图形界面Python应用 专栏:PyQt入门学习 老猿Python博文目录 老猿在windows下装了2套Python,一套是直接安装的Pytho ...
- ARM 环境下使用azure powershell 从远程blob中拉去vhd 并创建虚拟机
最近需要从指定公共访问的blob中复制vhd到自己的订阅存储账户,并使用vhd创建AZURE ARM虚拟机(非经典版),而且在portal.azure.cn中无法实现虚拟机映像创建等功能,于是自己使用 ...
- python环境下安装virtualenv,virtualenvwrapper
在使用 Python 开发的过程中,工程一多,难免会碰到不同的工程依赖不同版本的库的问题: 亦或者是在开发过程中不想让物理环境里充斥各种各样的库,引发未来的依赖灾难. 此时,我们需要对于不同的工程使用 ...
- Python环境下如何安装爬虫需求的一些库
是在CMD环境下的: request库pip install request 回车 pandas库 同理,pip install pandas :这里需要声明下,这个是不一定成功的,刚入门稍微看了一点 ...
- Win32环境下代码注入与API钩子的实现(转)
本文详细的介绍了在Visual Studio(以下简称VS)下实现API钩子的编程方法,阅读本文需要基础:有操作系统的基本知识(进程管理,内存管理),会在VS下编写和调试Win32应用程序和动态链接库 ...
随机推荐
- 2.32 js几种定位方法总结
2.32 js几种定位方法总结 前言本篇总结了几种js常用的定位元素方法,并用js点击按钮,对input输入框输入文本 一.以下总结了5种js定位的方法除了id是定位到的是单个element元素对象, ...
- Angular 插值字符串
<!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title> ...
- 导出文件为excle
handleOutPut() { const searchData=this.state.searchData; let url = commonData.baseMerchantUrl + &quo ...
- 第十三次CCF第四题 1803——04 博弈
我又写了一个简洁版的2.0: 可以作为博弈搜索树的模板 : https://www.cnblogs.com/xidian-mao/p/9389974.html 废话ps: 开始觉得这是一道简单得博弈 ...
- 重绘和回流(reflow和repaint)
由于DOM操作会导致浏览器的回流,回流需要花费大量的时间进行样式计算和节点重绘与渲染,所以应当尽量减少回流次数. 以下是几种常见的减少重绘和回流的方法: 一.不要一项一项的更改页面的样式,尽量一口气写 ...
- 【递推】【HDOJ】
http://acm.hdu.edu.cn/showproblem.php?pid=2501 Tiling_easy version Time Limit: 1000/1000 MS (Java/Ot ...
- hdu1796 How many integers can you find 容斥原理
Now you get a number N, and a M-integers set, you should find out how many integers which are small ...
- CH4907 作诗
题意 4907 作诗 0x49「数据结构进阶」练习 描述 神犇SJY虐完HEOI之后给傻×LYD出了一题:SHY是T国的公主,平时的一大爱好是作诗.由于时间紧迫,SHY作完诗之后还要虐OI,于是SHY ...
- oracle数据库丢失数据文件、控制文件、重做日志文件、初始化文件恢复方法
rman target/ list backup; 查看是否已备份,如果没有,那就不知道了 模拟故障,删除/u01/app/oracle/oradata/ORCL文件夹下的所有文件 sqlplus ...
- oracle使用一条语句批量插入多条数据
例如我有一个test表 create table (stuid int,name varchar(20); 插入多条数据,注意不能直接使用insert into test values(1,'a'), ...