本文实例讲述了Python3编程实现获取阿里云ECS实例及监控的方法。分享给大家供大家参考,具体如下:
#!/usr/bin/env python3.5
# -*- coding:utf8 -*-
try: import httplib
except ImportError:
import http.client as httplib
import sys,datetime
import urllib
import urllib.request
import urllib.error
import urllib.parse
import time
import json
import base64
import hmac,ssl
import uuid
from hashlib import sha1
# 解决 访问ssl网站证书的问题
try:
_create_unverified_https_context = ssl._create_unverified_context
except AttributeError:
# Legacy Python that doesn't verify HTTPS certificates by default
pass
else:
# Handle target environment that doesn't support HTTPS verification
ssl._create_default_https_context = _create_unverified_https_context
class aliyunclient:
def __init__(self):
self.access_id = '阿里云access_id'
self.access_secret ='阿里云secret'
#监控获取ECS URL
self.url = 'https://ecs.aliyuncs.com'
# #签名
def sign(self,accessKeySecret, parameters):
sortedParameters = sorted(parameters.items(), key=lambda parameters: parameters[0])
canonicalizedQueryString = ''
for (k,v) in sortedParameters:
canonicalizedQueryString += '&' + self.percent_encode(k) + '=' + self.percent_encode(v)
stringToSign = 'GET&%2F&' + self.percent_encode(canonicalizedQueryString[1:]) # 使用get请求方法
bs = accessKeySecret +'&'
bs = bytes(bs,encoding='utf8')
stringToSign = bytes(stringToSign,encoding='utf8')
h = hmac.new(bs, stringToSign, sha1)
# 进行编码
signature = base64.b64encode(h.digest()).strip()
return signature
def percent_encode(self,encodeStr):
encodeStr = str(encodeStr)
res = urllib.request.quote(encodeStr)
res = res.replace('+', '%20')
res = res.replace('*', '%2A')
res = res.replace('%7E', '~')
return res
# 构建除共公参数外的所有URL
def make_url(self,params):
timestamp = time.strftime("%Y-%m-%dT%H:%M:%SZ", time.gmtime())
parameters = {
'Format' : 'JSON',
'Version' : '2014-05-26',
'AccessKeyId' : self.access_id,
'SignatureVersion' : '1.0',
'SignatureMethod' : 'HMAC-SHA1',
'SignatureNonce' : str(uuid.uuid1()),
'TimeStamp' : timestamp,
}
for key in params.keys():
parameters[key] = params[key]
signature = self.sign(self.access_secret,parameters)
parameters['Signature'] = signature
url = self.url + "/?" + urllib.parse.urlencode(parameters)
return url
def do_action(self,params):
url = self.make_url(params)
# print(url)
request = urllib.request.Request(url)
try:
conn = urllib.request.urlopen(request)
response = conn.read().decode()
except urllib.error.HTTPError as e:
print(e.read().strip())
raise SystemExit(e)
try:
res = json.loads(response)
except ValueError as e:
raise SystemExit(e)
return res
# 继承原始类
class client(aliyunclient):
def __init__(self,InstanceIds):
aliyunclient.__init__(self)
self.InstanceIds = InstanceIds
# ECS 区域
self.RegionId = "cn-shanghai"
# 时间UTC转换
def timestrip(self):
UTCC = datetime.datetime.utcnow()
utcbefore5 = UTCC - datetime.timedelta(minutes =5)
Endtime = datetime.datetime.strftime(UTCC, "%Y-%m-%dT%H:%M:%SZ")
StartTime = datetime.datetime.strftime(utcbefore5, "%Y-%m-%dT%H:%M:%SZ")
return (StartTime,Endtime)
def DescribeInstanceMonitorData(self):
'''
构造实例监控序列函数
'''
self.tt = self.timestrip()
action_dict ={"StartTime":self.tt[0],"Endtime":self.tt[1],"Action":"DescribeInstanceMonitorData","RegionId":self.RegionId,"InstanceId":self.InstanceId}
return action_dict
def DescribeInstances(self):
'''
构建实例配置查询函数
'''
action_dict = {"Action":"DescribeInstances","RegionId":self.RegionId,"InstanceIds":self.InstanceIds}
return action_dict
def alis_main(self):
res = self.do_action(self.DescribeInstances())
listarry = len(res["Instances"]["Instance"])
a = {}
cpu = 0
InternetBandwidth = 0
instanlist = {"data":a}
# 调用所有符合条件的实例配置数据
for i in range(0,listarry):
self.InstanceId = res["Instances"]["Instance"][i]["InstanceId"]
BandwidthOUT = res["Instances"]["Instance"][i]["InternetMaxBandwidthOut"]
# 调用计算该实例的监控数据
monitordata = self.do_action(self.DescribeInstanceMonitorData())
data = monitordata["MonitorData"]["InstanceMonitorData"]
for i in range(0,len(data)):
cpu += data[i]["CPU"]
InternetBandwidth += data[i]["InternetBandwidth"]
# 对该实例数据生成字典
arry = {"BandwidthOUT":BandwidthOUT,"cpu":cpu/len(data),"InternetBandwidth":InternetBandwidth/len(data)}
# 将新数据重构到原字典数据
a.setdefault(self.InstanceId,arry)
return instanlist
if __name__ == "__main__":
# 传实例ID 列表进去
clt= client(["i-11cy8adf2x"])
res = clt.alis_main()
print(res)
# 获取的结果如下:
{'data': {'i-11cy8adf2x': {'InternetBandwidth': 0.0, 'cpu': 4.0, 'BandwidthOUT': 4}}}
# 解释 获取所有实例的 当前配置的带宽值 当前占用的CPU% 当前占用的出口带宽 kbps
更多关于Python相关内容可查看本站专题:《Python Socket编程技巧总结》、《Python数据结构与算法教程》、《Python函数使用技巧总结》、《Python字符串操作技巧汇总》、《Python入门与进阶经典教程》及《Python文件与目录操作技巧汇总》
希望本文所述对大家Python程序设计有所帮助。
# Python3
# 阿里云
# ECS实例
# 监控
# 利用Python+阿里云实现DDNS动态域名解析的方法
# 阿里云 CentOS7.4 安装 Python3.6的方法讲解
# 在阿里云服务器上配置CentOS+Nginx+Python+Flask环境
# python脚本使用阿里云slb对恶意攻击进行封堵的实现
# 进阶
# 操作技巧
# 相关内容
# 数据结构
# 给大家
# 更多关于
# 所述
# 符合条件
# 程序设计
# 使用技巧
# 重构
# 编程技巧
# 讲述了
# https
# ecs
# url
# secret
相关文章:
如何高效利用200m空间完成建站?
合肥做个网站多少钱,合肥本地有没有比较靠谱的交友平台?
成都网站制作价格表,现在成都广电的单独网络宽带有多少的,资费是什么情况呢?
如何快速生成高效建站系统源代码?
建站之星logo尺寸如何设置最合适?
C++时间戳转换成日期时间的步骤和示例代码
建站之星导航菜单设置与功能模块配置全攻略
建站之星如何优化SEO以实现高效排名?
详解一款开源免费的.NET文档操作组件DocX(.NET组件介绍之一)
自助网站制作软件,个人如何自助建网站?
如何在服务器上三步完成建站并提升流量?
济南网站制作的价格,历城一职专官方网站?
猪八戒网站制作视频,开发一个猪八戒网站,大约需要多少?或者自己请程序员,需要什么程序员,多少程序员能完成?
网站建设制作、微信公众号,公明人民医院怎么在网上预约?
网站制作大概多少钱一个,做一个平台网站大概多少钱?
建站主机服务器选购指南:轻量应用与VPS配置解析
网站制作多少钱一个,建一个论坛网站大约需要多少钱?
如何在Windows 2008云服务器安全搭建网站?
如何零成本快速生成个人自助网站?
深圳网站制作平台,深圳市做网站好的公司有哪些?
图册素材网站设计制作软件,图册的导出方式有几种?
如何快速生成橙子建站落地页链接?
如何在Golang中引入测试模块_Golang测试包导入与使用实践
建站之星代理如何获取技术支持?
微信h5制作网站有哪些,免费微信H5页面制作工具?
免费网站制作模板下载,除了易企秀之外还有什么H5平台可以制作H5长页面,最好是免费的?
香港服务器网站测试全流程:性能评估、SEO加载与移动适配优化
如何在阿里云部署织梦网站?
网站制作怎么样才能赚钱,用自己的电脑做服务器架设网站有什么利弊,能赚钱吗?
唐山网站制作公司有哪些,唐山找工作哪个网站最靠谱?
代刷网站制作软件,别人代刷火车票靠谱吗?
企业在线网站设计制作流程,想建设一个属于自己的企业网站,该如何去做?
北京网站制作费用多少,建立一个公司网站的费用.有哪些部分,分别要多少钱?
视频网站app制作软件,有什么好的视频聊天网站或者软件?
大连企业网站制作公司,大连2025企业社保缴费网上缴费流程?
建站主机系统SEO优化与智能配置核心关键词操作指南
如何通过多用户协作模板快速搭建高效企业网站?
如何构建满足综合性能需求的优质建站方案?
建站之星2.7模板快速切换与批量管理功能操作指南
济南专业网站制作公司,济南信息工程学校怎么样?
如何在Tomcat中配置并部署网站项目?
建站主机类型有哪些?如何正确选型
如何快速查询网址的建站时间与历史轨迹?
如何规划企业建站流程的关键步骤?
如何在香港服务器上快速搭建免备案网站?
建站之星安全性能如何?防护体系能否抵御黑客入侵?
建站之星伪静态规则如何设置?
C++ static_cast和dynamic_cast区别_C++静态转换与动态类型安全转换
儿童网站界面设计图片,中国少年儿童教育网站-怎么去注册?
如何通过万网虚拟主机快速搭建网站?
*请认真填写需求信息,我们会在24小时内与您取得联系。