python實(shí)現(xiàn)監(jiān)控阿里云賬戶余額功能
背景
由于阿里云oss,cdn消耗錢的速度比較快,在不知道的情況下,服務(wù)就被停了,影響比較大。所以想做個(gè)監(jiān)控。百度一下阿里云賬戶余額 api 還真有;于是開(kāi)啟了踩坑之路。
查閱資料創(chuàng)建accessKeyId和accessKeySecret
- 官方文檔(感覺(jué)并不細(xì)致) https://help.aliyun.com/document_detail/87997.html?spm=a2c6h.13066369.0.0.59e4581eaxXH1O
- sdk https://developer.aliyun.com/sdk?spm=5176.12818093.resource-links.dsdk_platform.488716d022QXo0
- 看了官方文檔后還是有點(diǎn)懵逼,后面Google了這個(gè)關(guān)鍵字
QueryAccountBalanceRequest才看到真正的樣例代碼https://developer.aliyun.com/ask/132002(感覺(jué)這塊資料很少呀,aliyun-python-sdk-bssopenapi居然沒(méi)寫在sdk安裝列表里面,在社區(qū)找到的)。 - 創(chuàng)建accessKeyId,鼠標(biāo)懸停到右上角


擼碼階段
要安裝的依賴
sudo pip install aliyun-python-sdk-core -i https://mirrors.aliyun.com/pypi/simple/
sudo pip install aliyun-python-sdk-bssopenapi -i https://mirrors.aliyun.com/pypi/simple/
from aliyunsdkcore import client
from aliyunsdkbssopenapi.request.v20171214 import QueryAccountBalanceRequest
from aliyunsdkcore.profile import region_provider
# 檢查賬戶余額
def check_account(name, accessKeyId, accessKeySecret, valve, notify_emails):
region_provider.add_endpoint('BssOpenApi', 'cn-hangzhou', 'business.aliyuncs.com')
clt = client.AcsClient(accessKeyId, accessKeySecret, 'cn-hangzhou')
request = QueryAccountBalanceRequest.QueryAccountBalanceRequest()
request.set_accept_format("JSON")
result = clt.do_action_with_exception(request)
print(result)
下面是我封裝的檢查賬戶余額,如果低于閥值就給要通知的人發(fā)郵件。 monitor_balance.py
# -*-coding: UTF-8 -*-
'''
監(jiān)控阿里云賬戶余額
zhouzhongqing
2019年12月14日20:21:11
sudo pip install aliyun-python-sdk-core -i https://mirrors.aliyun.com/pypi/simple/
sudo pip install aliyun-python-sdk-bssopenapi -i https://mirrors.aliyun.com/pypi/simple/
https://developer.aliyun.com/ask/132002
'''
import os
import time
import sched
import smtplib
from email.mime.text import MIMEText
from email.header import Header
from aliyunsdkcore import client
from aliyunsdkbssopenapi.request.v20171214 import QueryAccountBalanceRequest
from aliyunsdkcore.profile import region_provider
import json
from decimal import Decimal
# qq郵箱smtp服務(wù)器
host_server = 'smtp.qq.com'
# sender_qq為發(fā)件人的qq號(hào)碼
sender_qq = '1030907690@qq.com'
# pwd為qq郵箱的授權(quán)碼
pwd = 'xxxxxx'
# 發(fā)件人的郵箱
sender_qq_mail = '1030907690@qq.com'
# 第一個(gè)參數(shù)確定任務(wù)的時(shí)間,返回從某個(gè)特定的時(shí)間到現(xiàn)在經(jīng)歷的秒數(shù)
# 第二個(gè)參數(shù)以某種人為的方式衡量時(shí)間
schedule = sched.scheduler(time.time, time.sleep);
def send_mail(receiver, name, balance, valve):
# 收件人郵箱
# receiver = '1030907690@qq.com'
# 郵件的正文內(nèi)容
mail_content = '您好,目前賬戶%s,余額為%s,低于閥值%s,請(qǐng)知悉!' % (name, balance, valve)
# 郵件標(biāo)題
mail_title = '%s余額監(jiān)控通知郵件' % (name)
# ssl登錄
smtp = smtplib.SMTP_SSL(host_server)
# set_debuglevel()是用來(lái)調(diào)試的。參數(shù)值為1表示開(kāi)啟調(diào)試模式,參數(shù)值為0關(guān)閉調(diào)試模式
smtp.set_debuglevel(0)
smtp.ehlo(host_server)
smtp.login(sender_qq, pwd)
msg = MIMEText(mail_content, "plain", 'utf-8')
msg["Subject"] = Header(mail_title, 'utf-8')
msg["From"] = sender_qq_mail
msg["To"] = receiver
smtp.sendmail(sender_qq_mail, receiver, msg.as_string())
smtp.quit()
#解析配置
def parse_account():
f = open("monitor.json")
lines = f.read()
data = json.loads(lines)
f.close()
return data
# 檢查賬戶余額
def check_account(name, accessKeyId, accessKeySecret, valve, notify_emails):
region_provider.add_endpoint('BssOpenApi', 'cn-hangzhou', 'business.aliyuncs.com')
clt = client.AcsClient(accessKeyId, accessKeySecret, 'cn-hangzhou')
request = QueryAccountBalanceRequest.QueryAccountBalanceRequest()
request.set_accept_format("JSON")
result = clt.do_action_with_exception(request)
# print(result)
res_json = json.loads(str(result, encoding="utf-8"))
print(res_json)
if res_json is not None and res_json["Code"] == "200":
availableAmount = res_json["Data"]["AvailableAmount"]
if Decimal(availableAmount) < Decimal(valve):
print("%s低于閥值 " % name)
notify_email_arr = notify_emails.split(",")
for email in notify_email_arr:
send_mail(email, name, availableAmount, valve)
def start_check():
try:
data = parse_account();
for item in data:
print("檢查%s" % item["name"])
check_account(item["name"], item["accessKeyId"], item['accessKeySecret'], item['valve'],
item['notifyEmail'])
# send_mail("1030907690@qq.com","恭喜你888","50","100")
except Exception as e:
print("program error %s " % e)
finally:
print("finally print!")
def perform_command(cmd, inc):
# 安排inc秒后再次運(yùn)行自己,即周期運(yùn)行
schedule.enter(inc, 0, perform_command, (cmd, inc));
os.system(cmd);
start_check();
def timming_exe(cmd, inc=60):
# enter用來(lái)安排某事件的發(fā)生時(shí)間,從現(xiàn)在起第n秒開(kāi)始啟動(dòng)
schedule.enter(inc, 0, perform_command, (cmd, inc))
# 持續(xù)運(yùn)行,直到計(jì)劃時(shí)間隊(duì)列變成空為止
schedule.run()
if __name__ == '__main__':
print("start")
print("show time after 60 seconds:");
#timming_exe("echo %time%", 60); # 每間隔多少秒執(zhí)行
timming_exe("date", 60); # 每間隔多少秒執(zhí)行
print("end")
'''
AvailableAmount String 可用額度
MybankCreditAmount String 網(wǎng)商銀行信用額度
AvailableCashAmount String 現(xiàn)金余額
Currency String 幣種。取值范圍:CNY:人民幣,USD:美元,JPY:日元
CreditAmount String 信控余額
'''
- 還有個(gè)json文件配置
monitor.json - 里面分別代表的是名稱,發(fā)起郵件通知賬戶余額閥值,id,密鑰,通知的郵箱(可以多個(gè),逗號(hào)
,分割)。
[{"name":"恭喜你888","valve": "100","accessKeyId":"xxx","accessKeySecret":"xxx","notifyEmail":1030907690@qq.com}]
運(yùn)行效果


如果是正式環(huán)境部署的話可以用這個(gè)命令,可以后臺(tái)運(yùn)行,日志輸出到 nohup.out:
nohup python -u monitor_balance.py > nohup.out 2>&1 &
總結(jié)
以上所述是小編給大家介紹的python實(shí)現(xiàn)監(jiān)控阿里云賬戶余額功能,希望對(duì)大家有所幫助,如果大家有任何疑問(wèn)請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!
如果你覺(jué)得本文對(duì)你有幫助,歡迎轉(zhuǎn)載,煩請(qǐng)注明出處,謝謝!
- Python3遠(yuǎn)程監(jiān)控程序的實(shí)現(xiàn)方法
- Python遠(yuǎn)程視頻監(jiān)控程序的實(shí)例代碼
- 用Python的Flask框架結(jié)合MySQL寫一個(gè)內(nèi)存監(jiān)控程序
- Python實(shí)現(xiàn)監(jiān)控程序執(zhí)行時(shí)間并將其寫入日志的方法
- Python寫的服務(wù)監(jiān)控程序?qū)嵗?/a>
- Python監(jiān)控服務(wù)器實(shí)用工具psutil使用解析
- python psutil監(jiān)控進(jìn)程實(shí)例
- 使用 Supervisor 監(jiān)控 Python3 進(jìn)程方式
- python3.8 微信發(fā)送服務(wù)器監(jiān)控報(bào)警消息代碼實(shí)現(xiàn)
- 基于python3監(jiān)控服務(wù)器狀態(tài)進(jìn)行郵件報(bào)警
- 基于python監(jiān)控程序是否關(guān)閉
相關(guān)文章
Python連接Mssql基礎(chǔ)教程之Python庫(kù)pymssql
這篇文章主要給大家介紹了關(guān)于Python連接Mssql基礎(chǔ)教程之Python庫(kù)pymssql的相關(guān)資料,文中分別介紹了連接數(shù)據(jù)庫(kù)、游標(biāo)使用注意事項(xiàng)、游標(biāo)返回行為字典變量、使用with語(yǔ)句(上下文管理器)以及調(diào)用存儲(chǔ)過(guò)程等的實(shí)現(xiàn),需要的朋友可以參考下2018-09-09
python語(yǔ)言是免費(fèi)還是收費(fèi)的?
在本篇文章里小編給大家分享的是關(guān)于python語(yǔ)言是否免費(fèi)的相關(guān)知識(shí)點(diǎn),需要的朋友們可以學(xué)習(xí)下。2020-06-06
python實(shí)現(xiàn)顏色rgb和hex相互轉(zhuǎn)換的函數(shù)
這篇文章主要介紹了python實(shí)現(xiàn)顏色rgb和hex相互轉(zhuǎn)換的函數(shù),可實(shí)現(xiàn)將rgb表示的顏色轉(zhuǎn)換成hex值的功能,非常具有實(shí)用價(jià)值,需要的朋友可以參考下2015-03-03
使用pandas讀取表格數(shù)據(jù)并進(jìn)行單行數(shù)據(jù)拼接的詳細(xì)教程
這篇文章主要介紹了使用pandas讀取表格數(shù)據(jù)并進(jìn)行單行數(shù)據(jù)拼接的詳細(xì)教程,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2021-03-03
python 簡(jiǎn)單的繪圖工具turtle使用詳解
這篇文章主要介紹了python 簡(jiǎn)單的繪圖工具turtle使用詳解的相關(guān)資料,需要的朋友可以參考下2017-06-06
對(duì)python中dict和json的區(qū)別詳解
今天小編就為大家分享一篇對(duì)python中dict和json的區(qū)別詳解,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2018-12-12

