python2.6 监听tomcat io并发量,并记录到数据库

背景:通过python脚本记录下tomcat的io访问量,并记录到数据库,通过数据分析日常访问量
'''
@author: Jacobpc
'''
import os
import time
import datetime
import sys
import threading
import subprocess
import MySQLdb


tomcatprocess="tomcat"
def get_process_id(name):
    child = subprocess.Popen(["pgrep","-f",name],stdout=subprocess.PIPE,shell=False)
    response = child.communicate()[0]
    return response


def gettomcatIoNum():
    tomcatpid = get_process_id(tomcatprocess)        
    print "tomcat pid is %s"%(tomcatpid)     
     
    number = os.popen("lsof -p 4154 | wc -l").read()
    print "io number is %s"%(number)      
    return number




def recordTomcatIo():
    number = gettomcatIoNum()
    dt=datetime.datetime.now().strftime("%Y-%m-%d %H:%M:%S")  
    
    sql = "insert into cnf_tomcat_io(number,create_date) values ('%s','%s')"%(number,dt)
    print "get data number is %s time is %s"%(number,dt)
    
    db = MySQLdb.connect("11.8.x.x", "name", "password", "database", charset='utf8' )
    cursor = db.cursor()
    try:
        cursor.execute(sql)
        db.commit()
    except:
        # Rollback in case there is any error
        db.rollback()
    db.close()
    print "inert data success"
    global timer 
    timer = threading.Timer(60, recordTomcatIo)
    timer.start()
    


timer = threading.Timer(2,recordTomcatIo)
timer.start()

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值