获取rds的cpu和内存使用情况

python版本:2.7.12

#!/usr/bin/env python
#coding=utf-8

import time
import os, json, urllib, datetime, shutil
from aliyunsdkcore.client import AcsClient
from aliyunsdkcore.acs_exception.exceptions import ClientException
from aliyunsdkcore.acs_exception.exceptions import ServerException
from aliyunsdkrds.request.v20140815.DescribeDBInstancePerformanceRequest import DescribeDBInstancePerformanceRequest

now_time = datetime.datetime.now()
yes_time = now_time + datetime.timedelta(days = -1)
key_item="MySQL_MemCpuUsage"
logfilepath="/home/oralce/scripts/monitor_script/logdata/"
instance_list=["1","2","3","4","5","6"]

##获取rds cpu数据并写入文件
def get_cpudata(instance_id,logfile_name):
        client = AcsClient(‘xxxxx‘,‘xxxxx‘,‘xxxxx‘)
        request = DescribeDBInstancePerformanceRequest()
        request.set_accept_format(‘json‘)
        start_time = datetime.datetime.strftime(yes_time,‘%Y-%m-%d‘) + ‘T16:00Z‘
        end_time   = datetime.datetime.strftime(now_time,‘%Y-%m-%d‘) + ‘T16:00Z‘
        request.set_StartTime(start_time)
        request.set_EndTime(end_time)
        ##获取cpu和内存数据
        request.set_Key(key_item)
        request.set_DBInstanceId(instance_id)
        response = client.do_action_with_exception(request)
        result=json.loads(response)

        list = result[‘PerformanceKeys‘][‘PerformanceKey‘][0][‘Values‘][‘PerformanceValue‘];
        ##取最新一条数据
        list_length=len(list)
        last_row=list[list_length-1]
        check_utc_date =last_row[‘Date‘]

        ##utc时间转换北京时间
        check_date=utc2local(datetime.datetime.strptime(check_utc_date, "%Y-%m-%dT%H:%M:%SZ"))
        check_value = last_row[‘Value‘]

        ##数据拼接
        cpu_data=instance_id + ‘|‘ + datetime.datetime.strftime(check_date,‘%Y-%m-%d %H:%M:%S‘) + ‘|‘ + check_value.replace("&","|")

        logfile=logfilepath + logfile_name
        ##写入文件
        with open(logfile, mode=‘a‘) as filename:
                filename.write(cpu_data)
                filename.write(‘\n‘)

##UTC时间转换成本地时间,参数为datetime类型
def utc2local(utc_st):
    now_stamp = time.time()
    local_time = datetime.datetime.fromtimestamp(now_stamp)
    utc_time = datetime.datetime.utcfromtimestamp(now_stamp)
    offset = local_time - utc_time
    local_st = utc_st + offset
    return local_st

if __name__ == ‘__main__‘:
        for instance_id in instance_list:
            ##1实例
            if instance_id =="1" :
                logfile="1_cpu.log"
            ##2实例
            if instance_id =="2" :
                logfile="2_cpu.log"
            ##3实例
            if instance_id =="3" :
                logfile="3_cpu.log"
            ##4实例
            if instance_id =="4" :
                logfile="4_cpu.log"
            ##5实例
            if instance_id =="5" :
                logfile="5_cpu.log"
            ##6实例
            if instance_id =="6" :
                logfile="6_cpu.log"

            get_cpudata(instance_id,logfile)

原文地址:https://www.cnblogs.com/hxlasky/p/11196327.html

时间: 2024-10-08 15:05:40

获取rds的cpu和内存使用情况的相关文章

编程实现获取linux服务器cpu、内存和磁盘使用率

proc文件系统介绍 /proc文件系统是一个伪文件系统,它只存在内存当中,而不占用外存空间.它以文件系统的方式为内核与进程提供通信的接口.用户和应用程序可以通过/proc得到系统的信息,并可以改变内核的某些参数.由于系统的信息,如进程,是动态改变的,所以用户或应用程序读取/proc目录中的文件时,proc文件系统是动态从系统内核读出所需信息并提交的. /proc目录中有一些以数字命名的目录,它们是进程目录.系统中当前运行的每一个进程在/proc下都对应一个以进程号为目录名的目录/proc/pi

编程获取linux的CPU使用率内存占用率

Linux下提供top.ps命令查看当前cpu.mem使用情况,简要介绍如下: 一.使用ps查看进程的资源占用 ps -aux 查看进程信息时,第三列就是CPU占用. [[email protected] utx86]# ps -aux | grep my_process Warning: bad syntax, perhaps a bogus '-'? See /usr/share/doc/procps-3.2.7/FAQ root   14415  3.4  0.9   37436  203

VMware ESXi中不能显示CPU及内存使用情况的解决方法

今天一个网友问我,他管理的机房有4台ESXi 5.1的服务器,其中三台ESXi Server不能显示各个虚拟机占用的CPU.内存情况了,如图1-1所示. 图1-1在"虚拟机"选项卡中不能显示每个启动虚拟机的资源占用情况 另外,在VMware ESXi的"摘要"中,CPU与内存的使用情况也统计出错,如图1-2所示. 图1-2 摘要统计出错 在出现这个问题时,各个ESXi Server上的虚拟机可以正常启动.关闭,并且各虚拟机运行的系统及应用不受影响. 从上面两个图我看

Linux查看CPU和内存使用情况总结

Linux查看CPU和内存使用情况:http://www.cnblogs.com/xd502djj/archive/2011/03/01/1968041.html 在做Linux系统优化的时候,物理内存是其中最重要的一方面.自然的,Linux也提供了非常多的方法来监控宝贵的内存资源的使用情况.下面的清单详细的列出了Linux系统下通过视图工具或命令行来查看内存使用情况的各种方法. 1. /proc/meminfo 查看RAM使用情况最简单的方法是通过/proc/meminfo.这个动态更新的虚拟

Linux查看CPU和内存使用情况详解

在系统维护的过程中,随时可能有需要查看 CPU 使用率,并根据相应信息分析系统状况的需要.在 CentOS 中, 可以通过 top 命令来查看 CPU 使用状况.运行 top 命令后,CPU 使用状态会以全屏的方式显示,并且会处在对话的 模式 -- 用基于 top 的命令,可以控制显示方式等等.退出 top 的命令为 q (在 top 运行中敲 q 键一次). 1.top top命令是Linux下常用的性能分析工具,能够实时显示系统中各个进程的资源占用状况,类似于Windows的任务 管理器.可

Linux查看CPU和内存使用情况

在系统维护的过程中,随时可能有需要查看 CPU 使用率,并根据相应信息分析系统状况的需要.在 CentOS 中,可以通过 top 命令来查看 CPU 使用状况.运行 top 命令后,CPU 使用状态会以全屏的方式显示,并且会处在对话的模式 -- 用基于 top 的命令,可以控制显示方式等等.退出 top 的命令为 q (在 top 运行中敲 q 键一次). top命令是Linux下常用的性能分析工具,能够实时显示系统中各个进程的资源占用状况,类似于Windows的任务管理器 可以直接使用top命

Linux查看CPU和内存使用情况(转)

在系统维护的过程中,随时可能有需要查看 CPU 使用率,并根据相应信息分析系统状况的需要.在 CentOS 中,可以通过 top 命令来查看 CPU 使用状况.运行 top 命令后,CPU 使用状态会以全屏的方式显示,并且会处在对话的模式 -- 用基于 top 的命令,可以控制显示方式等等.退出 top 的命令为 q (在 top 运行中敲 q 键一次). top命令是Linux下常用的性能分析工具,能够实时显示系统中各个进程的资源占用状况,类似于Windows的任务管理器 可以直接使用top命

Linux查看CPU和内存使用情况【转】

转自:http://www.cnblogs.com/xd502djj/archive/2011/03/01/1968041.html 在系统维护的过程中,随时可能有需要查看 CPU 使用率,并根据相应信息分析系统状况的需要.在 CentOS 中,可以通过 top 命令来查看 CPU 使用状况.运行 top 命令后,CPU 使用状态会以全屏的方式显示,并且会处在对话的模式 -- 用基于 top 的命令,可以控制显示方式等等.退出 top 的命令为 q (在 top 运行中敲 q 键一次). top

Linux 带宽、CPU、内存占用情况

iftop 查看带宽占用情况(总)yum install -y iftop 安装iftopnethogs 查看进程流量 curl http://218.5.73.233:8060/ip.php 查看出口ip 查看当前线程:ps -ef|grep javaps -ef|gerp com.meiya.main(包名) 1.CPU使用率情况命令:top 备注:用户占用CPU1.5%,系统占用CPU1.5%,空闲95.3%,其他占用1.7%:2.内存使用率情况命令:free -g 备注:内存总大小15G