Python学习打call第六十七天:将获取的指标封装成接口提供API请求调用

1.将阿里云的监控指标推送到企业微信

  • (1)首先需要在项目的根路径下,创建utils包,用于存放项目的其他数据接口;

  • (2)然后在utils包下,创建一个wechat_send.py模块, 用于给用户封装企业微信的接口,提供给外界调用;

import requests
import json

class Wechat_Info:
    def __init__(self):
        self.partyID = '1'
        self.corpID = 'ww5cfabaf35ce8cd7b'
        self.secret = 'uiwvmNj8f1IVy3QYrZ62WePGFKA_BsIPmHigq3TRydM'
        self.agentID = '1000002'
        self.token = None

    def __get_token(self, corpid, secret):
        Url = "https://qyapi.weixin.qq.com/cgi-bin/gettoken"
        Data = {
            "corpid": corpid,
            "corpsecret": secret
        }
        r = requests.get(url=Url, params=Data)
        token = r.json()['access_token']
        return token

    def send_message(self, message):
        url = "https://qyapi.weixin.qq.com/cgi-bin/message/send?access_token={}".format(
            self.__get_token(self.corpID, self.secret))
        data = {
            "toparty": self.partyID,
            "msgtype": "text",
            "agentid": self.agentID,
            "text": {
                "content": message
            },
            "safe": "0"
        }
        result = requests.post(url=url, data=json.dumps(data))
        return result.text
if __name__ == '__main__':
    wechat_info = Wechat_Info()
    result = wechat_info.send_message('微信测试')
    print(result)
  • (3)由于partyIDcorpIDsecretagentID都是配置信息,需要引入一个读取配置文件的库configparser
安装:
pip install configparser
  • (4)为了管理所有的配置文件还需要创建一个配置文件目录cfg,可以在cfg目录下创建配置文件,如xkd.conf文件;
[Wechat]
party_id = 1
corp_id = ww5cfabaf35ce8cd7b
secret = uiwvmNj8f1IVy3QYrZ62WePGFKA_BsIPmHigq3TRydM
agent_id = 1000002
  • (5)然后可以在utils包下,创建一个const_file.py文件,依赖作为项目中全局常量的引用;
import os
PROJECT_DIR = os.path.dirname(os.path.dirname(os.path.abspath(__file__)))
CONFIG_DIR = os.path.join(PROJECT_DIR, 'cfg')
# 指定配置文件的路径
CONFIG_FILE = os.path.join(CONFIG_DIR, 'xkd.conf')
  • (6)接着修改wechat_send.py模块接口(配置中的信息都是明文的,在项目开发中,最好将重要的配置信息进行加密,可以使用base64进行加密和解密);
import requests
import json
from configparser import ConfigParser
from utils.const_file import CONFIG_FILE

class Wechat_Info:
    def __init__(self):
        self.wechat_info = self.__get_config_info()

    def __get_config_info(self):
        parser = ConfigParser()
        parser.read(CONFIG_FILE)
        wechat_info = {}
        wechat_info['party_id'] = parser.get('Wechat', 'party_id')
        wechat_info['corp_id'] = parser.get('Wechat', 'corp_id')
        wechat_info['secret'] = parser.get('Wechat', 'secret')
        wechat_info['agent_id'] = parser.get('Wechat', 'agent_id')
        return wechat_info

    def __get_token(self, corpid, secret):
        Url = "https://qyapi.weixin.qq.com/cgi-bin/gettoken"
        Data = {
            "corpid": corpid,
            "corpsecret": secret
        }
        r = requests.get(url=Url, params=Data)
        token = r.json()['access_token']
        return token
    def send_message(self, message):
        url = "https://qyapi.weixin.qq.com/cgi-bin/message/send?access_token={}".format(
            self.__get_token(self.wechat_info.get('corp_id'), self.wechat_info.get('secret')))
        data = {
            "toparty": self.wechat_info.get('party_id'),
            "msgtype": "text",
            "agentid": self.wechat_info.get('agent_id'),
            "text": {
                "content": message
            },
            "safe": "0"
        }
        result = requests.post(url=url, data=json.dumps(data))
        return result.text
if __name__ == '__main__':
    wechat_info = Wechat_Info()
    result = wechat_info.send_message('微信测试')
    print(result)
  • (7)在utils包下,创建aliyun_monitor.py文件,封装阿里云的云监控数据的接口;

  • (8)然后编辑xkd.conf配置文件,添加阿里云RAM access keyaccess key secretregion id

[Wechat]
party_id = 1
corp_id = wwabdfbc8feeee095a
secret = NY2nQE1cavlug_IuyMoRlIZDIOdsDS4KMpo_81XWslo
agent_id = 1000002

[ALIYUN]
access_key = LTAIxdvbuz2MD74Z
access_key_secret = I2b7O1UJmkjfgHVC4i7Atb8gGXwAbU
region_id = cn-shenzhen
  • (9)编辑aliyun_monitor.py文件;
from aliyunsdkcore import client
from aliyunsdkcms.request.v20180308 import QueryMetricListRequest
from datetime import datetime, timedelta
import json
from configparser import ConfigParser
from utils.const_file import CONFIG_FILE

class CloudMonitor:
    def __init__(self):
        self.ram_info = self.__get_ram_info()
        self.clt = client.AcsClient(self.ram_info.get('access_key'), self.ram_info.get('access_key_secret'), self.ram_info.get('region_id'))
        self.request = QueryMetricListRequest.QueryMetricListRequest()
        self.last_average = None

    def __get_ram_info(self):
        parser = ConfigParser()
        parser.read(CONFIG_FILE)
        ram_info = {}
        ram_info['access_key'] = parser.get('ALIYUN', 'access_key')
        ram_info['access_key_secret'] = parser.get('ALIYUN', 'access_key_secret')
        ram_info['region_id'] = parser.get('ALIYUN', 'region_id')
        return ram_info

    def __get_start_timestamp(self):
        start_datetime = datetime.now() - timedelta(minutes=3)
        start_timestamp = int(start_datetime.timestamp() * 1000)
        return start_timestamp

    def get_last_metric(self,instance_id, monitor_key):
        '''
        :param instance_id: ECS是实例ID
        :param monitor_key: 需要监控的指标
        :return:
        '''
        self.request.set_accept_format('json')
        self.request.set_Project('acs_ecs_dashboard')
        self.request.set_Metric('{}'.format(monitor_key))
        start_time = self.__get_start_timestamp()
        self.request.set_StartTime(start_time)
        self.request.set_EndTime(int(datetime.now().timestamp() * 1000))
        self.request.set_Dimensions("{'instanceId': '%s'}" % (instance_id))
        result = self.clt.do_action_with_exception(self.request)
        result = json.loads(result)
        data_str = result.get('Datapoints')
        data_list = json.loads(data_str)
        return data_list[-1]['Average']
if __name__ == '__main__':
    monitor  = CloudMonitor()
    result = monitor.get_last_metric('i-wz98bynewgl7gu3jqqb3', 'CPUUtilization')
    print(result)
  • (10)使用Django定时任务库,需要用到django-crontab;
pip install django-crontab
  • (11)然后在settings文件中添加django-crontab到INSTALLED_APPS;
INSTALLED_APPS = [
    'django.contrib.admin',
    'django.contrib.auth',
    'django.contrib.contenttypes',
    'django.contrib.sessions',
    'django.contrib.messages',
    'django.contrib.staticfiles',
    'users',
    'courses',
    'teachers',
    'schools',
    'rest_framework',
    'django_crontab',
]
  • (12)在users APP下创建一个cron.py文件,导入import CloudMonitorWechat_Info
from utils.aliyun_monitor import CloudMonitor
from utils.wechat_send import Wechat_Info
def send_aliyun_metric_to_wechat():
    monitor = CloudMonitor()
    wechat_info = Wechat_Info()
    result = monitor.get_last_metric('i-wz98bynewgl7gu3jqqb3', 'CPUUtilization')
    wechat_info.send_message('当前服务器CPU使用率是:{}'.format(result))
  • (13)在settings文件中配置定时任务CRONJOBS;
CRONJOBS = [
    ('* * * * *', 'users.cron.send_aliyun_metric_to_wechat')
]
  • (14)最后添加定时任务:python manage.py crontab add

2.configparser模块

  • 安装命令行:pip install configparser

  • ConfigParser是用来读取配置文件的模块,配置文件的格式跟windows下的ini配置文件相似,可以包含一个或多个section,每个section都有自己的option;

  • section 用 [sect_name] 表示,每个option是一个键值对,使用分隔符=:隔开;

  • 在 option 中分隔符两端的空格会被忽略掉;

  • 配置文件使用可以使用#进行注释;

3.django-crontab库

安装命令:
pip install django-crontab
  • django-crontab使用前需要添加到settings文件中的INSTALLED_APPS中;

  • 添加定时任务:python manage.py crontab add,注意如果修改了任务,也需要再次运行此命令;

  • 清除定时任务:python manage.py crontab remove

  • 显示定时任务:python manage.py crontab show

  • 注意django-crontab必须在Linux的crontab开启的情况下方可使用,不然会出现不执行的情况;

参考:https://www.9xkd.com/user/plan-view.html?id=2761461821

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 202,980评论 5 476
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,178评论 2 380
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 149,868评论 0 336
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,498评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,492评论 5 364
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,521评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,910评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,569评论 0 256
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,793评论 1 296
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,559评论 2 319
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,639评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,342评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,931评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,904评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,144评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,833评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,350评论 2 342

推荐阅读更多精彩内容

  • # Python 资源大全中文版 我想很多程序员应该记得 GitHub 上有一个 Awesome - XXX 系列...
    小迈克阅读 2,956评论 1 3
  • 模块间联系越多,其耦合性越强,同时表明其独立性越差( 降低耦合性,可以提高其独立性)。软件设计中通常用耦合度和内聚...
    riverstation阅读 2,058评论 0 8
  • 点我查看本文集的说明及目录。 本项目相关内容包括: 实现过程: CH7 创建在线商店 CH8 管理支付和订单 CH...
    学以致用123阅读 3,523评论 0 6
  • 我的2018年目标: 霸占舞台50场(含主持、点评、分享、比赛)(14次演讲比赛+5次主持(含不出局2次)+4次点...
    好听的暖阳阅读 109评论 0 1
  • 真正的成熟不是表面的衰老,而是心坎的丰硕;不是芳华的宅兆,而是真我的规复;不是经历的广泛,而是思惟的深度;不是自我...
    壹分钟童话阅读 239评论 0 0