python3小脚本-监控服务器性能并插入mysql数据库

操作系统:

centos版本 7.4
防火墙 关闭
selinux 关闭
python版本 3.6
mysql版本 5.7

#操作系统性能脚本

[[email protected] sql]# cat cpu_mac.py

#!/usr/bin/env python3

#coding:utf-8

import subprocess

def monitor(frist_invoke=1):

shell_command = ‘sar 1 1| grep "^Average:"‘

status,result = subprocess.getstatusoutput(shell_command)

if status != 0:

value_dic = {‘status‘: status}

else:

value_dic = {}

#print(‘---res:‘,result)

user,nice,system,iowait,steal,idle = result.split()[2:]

#拿回监控数据后保存为字典

value_dic= {

‘user‘: user,

‘nice‘: nice,

‘system‘: system,

‘idle‘: idle,

‘status‘: status

}

return value_dic

if __name__ == ‘__main__‘:

print(monitor())

#获取服务器性能后使用python3插入数据库脚本

[[email protected] sql]# cat /root/sql/class_sql.py

import pymysql

import cpu_mac

from datetime import datetime

db = pymysql.connect("192.168.10.100", "root", "root", "dx_monitor", charset="utf8")

#获取当前时间

NOW = datetime.now()

#获取当前时间,并格式化

TIME_DATE = NOW.strftime("%Y-%m-%d %H:%M:%S")

#获取当前时间,并格式化为年月

MONITOR_DATE = NOW.strftime("%Y_%m")

class monitor:

def __init__(self, db, MONITOR_DATE, TIME_DATE):

self.db = db

self.MONITOR_DATE = MONITOR_DATE

self.TIME_DATE = TIME_DATE

def create_table(self):

#获取当前数据库游标

cursor = self.db.cursor()

#查看当前数据表是否存在

date_sql = "DROP TABLE IF EXISTS res_monitor_{0}".format(self.MONITOR_DATE)

try:

#创建数据表

sql = """

CREATE TABLE  res_monitor_self.MONITOR_DATE (

id int UNSIGNED AUTO_INCREMENT,

user varchar(20) NOT NULL,

nice varchar(20) NOT NULL,

system varchar (20) NOT NULL,

idle  varchar(20) NOT NULL,

status varchar(20) NOT NULL,

date DATETIME,

PRIMARY KEY( id )

)ENGINE=InnoDB DEFAULT CHARSET=utf8;

""".format(self.MONITOR_DATE)

#判断数据表

data = cursor.execute(date_sql)

#执行创建表

cursor.execute(sql)

self.db.close()

#print("Database version : %s" % data)

#print("表创建成功")

except :

print(‘表错误‘)

data = cursor.execute(date_sql)

cursor.execute(sql)

self.db.close()

print("Database version : %s" % data)

print("表创建成功")

cursor.close()

self.db.close()

def insert_table(self):

de = cpu_mac.monitor()

#插入数据到数据库表空间

sql = "INSERT INTO res_monitor_{0} (user, nice, system, idle, status, date) VALUES (%s, %s, %s, %s, %s, %s)".format(self.MONITOR_DATE)

cursor = db.cursor()

T = (( de[‘user‘]), (de[‘nice‘]), (de[‘system‘]), (de[‘idle‘]), (de[‘status‘]), (self.TIME_DATE))

try:

#执行表

cursor.execute(sql, T)

self.db.commit()

print(‘监控数据插入ok‘)

#     print(‘ok 123‘)

#     # sql = "INSERT INTO res_monitor_{0} (user, nice, system, idle, status, date) VALUES ({1}, {2}, {3}, {4}, {5})".format(MONITOR_DATE, de[‘user‘], de[‘nice‘], de[‘system‘], de[‘idle‘], de[‘status‘])

#

#     print(sql)

#

#     # cursor.execute(sql, T)

#     print(‘监控数据插入ok‘)

except:

self.db.rollback()

print(‘监控数据插入错误‘)

cursor.close()

self.db.close()

if __name__ == ‘__main__‘:

db_sql = monitor(db,MONITOR_DATE,TIME_DATE)

#db_sql.create_table()

db_sql.insert_table()

#写入定时任务

[[email protected] sql]# crontab -l

* * * * * /usr/bin/python3 /root/sql/class_sql.py

#连接数据库

[[email protected] ~]# mysql -uroot -proot -h192.168.10.100

#创建的库

#创建的表

#执行的最终结果

原文地址:https://www.cnblogs.com/zhaop8078/p/12239830.html

时间: 2024-10-26 20:11:14

python3小脚本-监控服务器性能并插入mysql数据库的相关文章

PHP Apache Access Log 分析工具 拆分字段成CSV文件并插入Mysql数据库分析

现在需要分析访问日志,怎么办? 比如分析D:\Servers\Apache2.2\logs\access2014-05-22.log http://my.oschina.net/cart/针对这个问题特意开发了一款小工具分析Apache 日志,拆分字段成CSV文件并插入Mysql数据库分析 <?php $date = '2014-05-22'; file_put_contents($date.'.csv', ''); file_put_contents($date.'.csv', '"IP

python 从csv文件插入mysql数据库

一个工作遇到的问题,将excel文件的内容插入到mysql数据库中. 总体思路是 excel文件-->转换成csv文件-->csv文件读取-->读取数据插入mysql数据库 用到python的两个库csv和MySQLdb 下面是具体的code: 代码中数据库部分没啥好记录的,特别记录一下csv库的用法: # Insert data from csv file.csv_file = file('3D_PTlabs.csv', 'rb')csv_reader = csv.reader(csv

web 项目:解决插入 MySQL 数据库时中文乱码问题

背景:在做 javaweb 项目的时,前台传递的中文最后插入数据库的时候总是出现乱码现象. 解决方案 ? A.不管是使用 Idea.eclipse,确定自己的项目所使用的字符集是 UTF-8. ? B.查看 MySQL的字符集是否是 UTF-8.打开 Dos 窗口,输入:mysql -u root -p, 在输入密码即可进入数据库.进入数据库输入命令 :show variables like 'character%';查看数据库的字符集,如下图: ? MySQL 的默认编码是 Latin1,不支

关于hibernate插入mysql数据库中文数据乱码处理

这几天在学习hibernate,在程序中将利用hibernate将数据插入的mysql数据库的时候,发现出现了中文乱码,在网上搜索了好长时间,大概的解决方法都是修改my.ini的配置文件,修改为gbk,但是插入数据还是出现乱码的情况.不过最后还是解决了.下面就说一下解决的方法. 1.找到MySql Server Instance onfiguration Wizard管理器,重新配置mysql.如图.前面的配置可以一路下一步,到了图中这一步要修改语言为gbk. 2.要删除之前建立的数据库,重新利

JDBC操作数据库,第一:jsp插入mysql数据库,坎坷摸索分享

JSP连接数据库,坎坷摸索了好久,现在终于做好了,分享一下,希望对更多热爱编程学习的人有所帮助!!!谢谢 第一:首先准备的就是已经安装好Mysql,这里不做多叙述,百度可以做到. 然后在mysql数据库中做如下操作: 需要注意的是自己创建的数据库的名字,和数据表的名字,这两个和后面写的程序息息相关,所以必须引起重视 第二步:就可以开始写程序了. 首先是Book类,这里最需要注意的是起的包名,真的很重要,真的很重要,真的很重要,重要的事情说三遍 1 package com.ningmeng; 2

cmd控制台插入mysql数据库中文信息时,插入失败的解决办法

故障码: mysql> insert into t1(name,sex,age,address) values('张三','男',11,'沙河'); ERROR 1366 (HY000): Incorrect string value: '\xD5\xC5\xC8\xFD' for column 'name' at row 1 该故障是由于中文编码不一致导致的数据插入失败所致. 一般mysql数据库在插入中文信息时出错的情况无外乎就是中文编码不一致所致.而目前支持中文的编码格式基本上有utf-8

Linux Shell脚本之利用mysqldump备份MySQL数据库(详细注解)

设计该脚本的一些设计.编写考虑: 该脚本适用于编译安装mysql和通过yum或apt-get等安装方式 该脚本可以反复执行,不会重复覆盖数据 可增加,删除N天前的备份以节省磁盘空间 充分利用mysqldump的自带锁表功能.刷新日志.复制等功能 利用mysqldump命令备份MySQL数据库的脚本(不带注释版,适合生产环境使用) #!/bin/bash MYSQLDBUSERNAME=root MYSQLDBPASSWORD=password MYSQBASEDIR=/usr/local/mys

使用log4net无法将日志记录插入mysql数据库解决办法

写在前面 今天没事研究了下,将日志文件写入mysql数据库,因为新公司用的数据库也是mysql,项目中需要将日志信息写入数据库,没办法,就研究了下.在使用过程中遇到一个很蛋疼的问题.最后解决了,郁闷了半天.这里做一下记录,以免再犯. 之前写个这方面的文章,关于配置信息,可参考我的这篇文章:Log4Net日志记录两种方式 解决办法 问题就出在我直接将log4net写入数据库的配置文件log4net.config直接复制过来在项目中使用了,当然是修改了连接字符串,提供程序等与mysql相关的配置.配

性能08篇-MySQL数据库性能基础

创建数据库测试计划: 创建10个并发用户,每个用户发送两个SQL请求到数据库服务器,每个用户都会运行测试3遍.因此,总共发送的测试数目是(10并发用户)*(2请求)*(重复3遍)=60JDBC请求.要构建这一测试计划,测试人员需要使用到的测试元件包括:线程组(Thread Group).JDBC请求(JDBC Request).图形结果(Graph Results). ?  1.添加并发用户 首先要做的是添加线程组,并修改其默认配置. 2.添加JDBC请求 定义JDBC请求需要完成的操作.选中线