Python3编程实现获取阿里云ECS实例及监控的方法
发布时间 - 2026-01-11 02:51:02 点击率:次本文实例讲述了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
相关栏目:
【
网站优化151355 】
【
网络推广146373 】
【
网络技术251813 】
【
AI营销90571 】
相关推荐:
如何在万网ECS上快速搭建专属网站?
Laravel如何使用Contracts(契约)进行编程_Laravel契约接口与依赖反转
Win11应用商店下载慢怎么办 Win11更改DNS提速下载【修复】
Laravel Blade模板引擎语法_Laravel Blade布局继承用法
Laravel如何使用缓存系统提升性能_Laravel缓存驱动和应用优化方案
开心动漫网站制作软件下载,十分开心动画为何停播?
如何在万网主机上快速搭建网站?
如何用VPS主机快速搭建个人网站?
LinuxShell函数封装方法_脚本复用设计思路【教程】
手机网站制作平台,手机靓号代理商怎么制作属于自己的手机靓号网站?
javascript如何操作浏览器历史记录_怎样实现无刷新导航
Laravel如何实现事件和监听器?(Event & Listener实战)
如何获取PHP WAP自助建站系统源码?
如何快速上传自定义模板至建站之星?
如何在宝塔面板中创建新站点?
如何快速配置高效服务器建站软件?
如何彻底卸载建站之星软件?
美食网站链接制作教程视频,哪个教做美食的网站比较专业点?
极客网站有哪些,DoNews、36氪、爱范儿、虎嗅、雷锋网、极客公园这些互联网媒体网站有什么差异?
Laravel如何使用Guzzle调用外部接口_Laravel发起HTTP请求与JSON数据解析【详解】
如何快速建站并高效导出源代码?
phpredis提高消息队列的实时性方法(推荐)
如何在阿里云通过域名搭建网站?
jquery插件bootstrapValidator表单验证详解
laravel怎么为应用开启和关闭维护模式_laravel应用维护模式开启与关闭方法
轻松掌握MySQL函数中的last_insert_id()
青岛网站建设如何选择本地服务器?
Android Socket接口实现即时通讯实例代码
瓜子二手车官方网站在线入口 瓜子二手车网页版官网通道入口
如何正确选择百度移动适配建站域名?
Linux网络带宽限制_tc配置实践解析【教程】
高端网站建设与定制开发一站式解决方案 中企动力
清除minerd进程的简单方法
Laravel怎么实现支付功能_Laravel集成支付宝微信支付
Laravel如何将应用部署到生产服务器_Laravel生产环境部署流程
JavaScript中的标签模板是什么_它如何扩展字符串功能
javascript基本数据类型及类型检测常用方法小结
香港服务器网站生成指南:免费资源整合与高速稳定配置方案
Java Adapter 适配器模式(类适配器,对象适配器)优缺点对比
如何在IIS中配置站点IP、端口及主机头?
如何在云服务器上快速搭建个人网站?
Laravel如何实现邮箱地址验证功能_Laravel邮件验证流程与配置
Laravel如何配置和使用缓存?(Redis代码示例)
JavaScript如何实现类型判断_typeof和instanceof有什么区别
专业商城网站制作公司有哪些,pi商城官网是哪个?
用yum安装MySQLdb模块的步骤方法
Laravel如何创建自定义Artisan命令?(代码示例)
如何在局域网内绑定自建网站域名?
绝密ChatGPT指令:手把手教你生成HR无法拒绝的求职信
微信小程序 闭包写法详细介绍

