python用作监控

一.python日志模块

二.python数据库连接

三.时间处理模块

四.python传递参数给shell

五.发送邮件(py2.7)

六.python计划任务

七.supervisor

/etc/supervisor.conf
[program:check]
command = python /data/remote_back/checkbackup.py
directory = /data/remote_back
user = root

[email protected]_TMN_Data:[/data/remote_back]supervisorctl 
check          RUNNING    pid 5771, uptime 19:15:25

八.综合实例

#coding:utf-8
import threading
import MySQLdb
from datetime import datetime
import time,os
import smtplib
from email.mime.text import MIMEText
#from log import logger
import logging
def get_log():
    logging.basicConfig(level=logging.DEBUG,
    format=‘%(asctime)s %(filename)s[line:%(lineno)d] %(levelname)s %(message)s‘,
    datefmt=‘%a, %d %b %Y %H:%M:%S‘,
    filename=‘myapp.log‘,
    filemode=‘w‘)
    logger = logging.getLogger(‘root‘)
    return logger
def get_con():
    host = "120.138.75.88"
    port = 5849
    logsdb = "serverlist"
    user = "xxxx"
    password = "xxxxx"
    con = MySQLdb.connect(host=host, user=user, passwd=password, db=logsdb, port=port, charset="utf8")
    return con

def calculate_time():
    now = time.mktime(datetime.now().timetuple())-60*2
    result = time.strftime(‘%Y-%m-%d %H:%M:%S‘, time.localtime(now))
    return result
def backup_time():
    now = time.mktime(datetime.now().timetuple())-60*2
    result = time.strftime(‘%Y%m%d‘, time.localtime(now))
    backupresult = str(result)
    return backupresult

def get_data(agent):
    select_time = calculate_time()
    get_log().info("select time:"+select_time)
    sql = ‘SELECT COUNT(DISTINCT gamedatadbname) FROM gameserverinfo WHERE agent="%s" and isdelete!=1  ORDER BY zone‘ %(agent)
    conn = get_con()
    cursor = conn.cursor()
    cursor.execute(sql)
    results = cursor.fetchall()
    num1 = results[0]
    num = num1[0]
    cursor.close()
    conn.close()
    return num
def get_backupdata(agent):
#    backupnum = os.popen(‘ls *`date +%Y%m%d04`* |wc -l‘).read().strip(‘\n‘)
    shijian = ‘*‘ + backup_time() + ‘04‘ +‘*‘
    guize = "%s" %(agent) + shijian
    os.environ[‘guize‘] = str(guize)
    backupnum = os.popen(‘ls $guize |wc -l‘).read().strip(‘\n‘)
    return backupnum
    
def check():
    numdata = int(get_data(‘ynvng‘))
    backupnum = int(get_backupdata(‘ynvng‘))
    if numdata == backupnum:
        result = "备份成功"
    else:
        result = "备份失败"
    return result
def send_email(content):
 
    sender = "[email protected]"
    receiver = ["[email protected]","[email protected]"]
    host = ‘smtp.163.com‘
    port = 465
    msg = MIMEText(content)
    msg[‘From‘] = "[email protected]"
    msg[‘To‘] = "[email protected]"
    msg[‘Subject‘] = "vng backup check"
 
    try:
        smtp = smtplib.SMTP_SSL(host, port)
        smtp.login(sender, ‘xxxx‘)
        smtp.sendmail(sender, receiver, msg.as_string())
        get_log().info("send email success")
    except Exception, e:
        get_log().error(e)
#	print e
def task():
#    get_data = get_data()
#    get_backupdata= get_backupdata()
    while True:
    	data = get_data(‘ynvng‘)
    	backupdata= get_backupdata(‘ynvng‘)

	shijian = backup_time()
        get_log().info("monitor running")
        results = check()

	print results
	get_log().info(results)
        if results == "备份成功":
            content = "越南备份成功"
        else:
            content = "越南备份失败"
	print content,data,backupdata
        send_email(content + " 备份时间:" + shijian + "   应该备份个数: " + str(data) + "   备份个数:" +  str(backupdata))
        time.sleep(720*60)

def run_monitor():
    monitor = threading.Thread(target=task)
    monitor.start()
 
 
if __name__ == "__main__":
    run_monitor()

九.运行效果

程序运行效果图

时间: 2024-10-22 11:33:58

python用作监控的相关文章

使用python程序监控云服务器的带宽

将一些不重要的服务迁移到云服务上,有些下载什么的,为了防止带宽超了,python做了一个监控程序.用python3写的,由于和python2有些区别,特记录下来备查. 代码如下: #this is for monitor qingcloud# coding=utf-8import base64import hmacimport urllibimport urllib.parsefrom hashlib import sha256import urllib.requestimport dateti

[python] 系统监控

每分钟 采集一次linux信息,采集到的数据暂存到本地sqlite 10分钟通过http上报一次 sqlite库中保存7天的过期数据 monitor4a.out是所有输出,monitor4a.log是INFO级别以上的日志(100MB的5个日志文件循环) python v2.6.6-2.7.8通过 #!/usr/bin/env python # _*_ coding:UTF-8 _*_ __author__ = 'shanl' import socket store_root_dir= ".&q

python多线程监控指定目录

import win32file import tempfile import threading import win32con import os dirs=["C:\\WINDOWS\\TEMP",tempfile.gettempdir()] def start_monitor(path_to_watch): h_directory = win32file.CreateFile(path_to_watch, win32con.GENERIC_READ , win32con.FIL

python性能监控初试

标 题: python性能监控初试作 者: itdef链 接: http://www.cnblogs.com/itdef/p/3990765.html 欢迎转帖 请保持文本完整并注明出处 之前性能统计都是使用的C C++  统计windows性能 后来想尝试使用图标显示数据的时候发现了PYTHON 而且python可以跨平台 为以后尝试监控linux系统做准备 这里尝试了用python获取磁盘使用率 并用matplotlib制作饼图 #!/usr/bin/env python # -*- cod

python——nagios监控nginx日志 request_time

遇到问题:nginx日志包含非常重要的信息.比如upstream_response_time 和request_time.现需求监控改值. 解决问题:编写python脚本,通过nagios check_nrpe 插件完成监控. 前提了解: nginx日志格式: log_format  main  '$remote_addr |$time_local| $request | $status | $body_byte s_sent | $http_referer | $http_user_agent

shell vs python脚本监控http请求

各写一个shell和python脚本来监控http请求,并在服务不可用的时候重启服务. 监控的连接为: http://192.168.1.101:5022/product http://192.168.1.101:5024/module shell脚本如下,配合crontab计划任务每一分钟执行一次检查: #!/bin/bash # This shell is used to moniter 192.168.1.101 port 5022 & 5024 date  #在crontab里用来记录l

zabbix使用Python实现监控MongoDB副本集状态

公司有 Windows 和 Linux 服务器,都搭建了 MongoDB 副本集,并且都要在 zabbix 平台中实现监控.Linux 系统直接使用 shell 脚本即可实现,但是 Windows 系统的不太好实现,我这里使用 Python 来实现.下面脚本同样适用于Linux系统(在 Windows server 2012 和 Centos7.3 系统都验证成功) 思路: 1.安装Python2.7 2.采用 Python 的 pymongo 模块来连接 mongodb 数据库,并认证授权 3

使用python脚本监控weblogic

1.python的脚本如下: 1 ############################################################################### 2 #created on 2013-07-09 3 #author : zhaolijun 4 #used to get weblogic server runtime infomation 5 #wls_ver:weblogic 10.3.5.0 6 #########################

python实现监控URL的一个值小于规定的值--邮件报警

监控URL的一个值小于规定的值--邮件报警 #!/usr/bin/env python #-*- coding:utf-8 -*- __author__ = 'liudong' import urllib,sys,urllib,json,smtplib from email.mime.text import MIMEText mailto_list=['[email protected]'] mail_host="smtp.exmail.qq.com" mail_user="