python自動化運維腳本範例

1.列舉當前目錄以及全部子目錄下的文件,並打印出絕對路徑
#!/usr/bin/python
# coding=utf8

import os
import sys
 
if len(sys.argv) < 2:
  filepath="."
else:
  filepath=sys.argv[1]

for root,dirs,files in os.walk(filepath):
  for filename in files:
    path=os.path.join(root,filename)
    print path

2.寫一個函數,計算字符串中全部數字的和
#!/usr/bin/python
# coding=utf8

import sys

number="123456"

def Numsum(num):
  sum=0
  if len(num) > 0:
    for i in range(len(num)):
      if num[i] > '0' and num[i] < '9':
        sum=sum+int(num[i])
        print "sum=%s" % sum
     else:
       sys.exit(1)

if __name__ == '__main__':
  Numsum(number)

3.天天生成一個文件,並把磁盤的使用狀況寫到到這個文件中,文件名爲日期格式(yyyy-mm-dd),如2018-06-10.log    
#!/usr/bin/python
# coding=utf8

import time
import os
import getopt
import sys

disk_path="/root/disk"
memory_path="/root/memory"

if not os.path.exists(disk_path):
  os.makedirs(disk_path)

if not os.path.exists(memory_path):
  os.makedirs(memory_path)

def Disk(time):
  status=os.popen('df -hTP').readlines()
  a=''.join(status)
  f=open('/root/disk/'+time+'.log','w')
  f.write(a)
  f.close()

def Memory(time):
  status=os.popen('free -g').readlines()
  a=''.join(status)
  f=open('/root/memory/'+time+'.log','w')
  f.write(a)
  f.close()

time = time.strftime("%Y-%m-%d-%H:%M:%S")
options,args = getopt.getopt(sys.argv[1:],'-d-m',['disk_status','memory_status'])
for opt_name,opt_value in options:
  if opt_name in ('-d','--disk_status'):
    try:
      Disk(time)
      print "Disk_status Complete"
      exit()
    except:
      print "Fail"
  if opt_name in ('-m','--memory_status'):
    try:
      Memory(time)
      print "Memory_status Complete"
      exit()
    except:
      print "Fail"

4.從nginx日誌中統計出每一個IP的訪問量有多少,訪問量超過10次的ip,用防火牆禁止使用,併發送郵件,三天後再打開限制,
#!/usr/bin/python
#coding=utf8

import os
import subprocess
from email.mime.text import MIMEText
import smtplib

refuse_ip = '/etc/nginx/refuse_nginx'
sender = 'wjq@123'
receiver = 'wujqc@yonyou.com'
password = '123456'
subject = 'nginx ip refuse'

def SendMail(ip):
  try:
    print "11111"
    content = ip+' is refuse'
    msg = MIMEText(content,'plain','utf-8')
    msg['From'] = sender
    msg['To'] = receiver
    msg['Subject'] = subject
    server=smtplib.SMTP('localhost')
    server.sendmail(sender,receiver,msg.as_string())
    print "發送成功"
  except smtplib.SMTPException:
    print "發送失敗"
 
if not os.path.exists(refuse_ip):
  os.mknod(refuse_ip)

def nginx_protect(ip):
  f=open(refuse_ip,'r+')
  cmd='iptables -A INPUT -p tcp --dport 80 -s '+ip+' -j DROP'
  cmd2='at now + 1 minutes << EOF\niptables -D INPUT -p tcp --dport 80 -s '+ip+' -j DROP\nsed -i "s/'+ip+'//" /etc/nginx/refuse_nginx\nEOF'
  for i in f:
    if ip not in i:
      f.write(ip)
      os.popen(cmd)
      os.popen(cmd2)      
      SendMail(ip)
  print("ip 限制成功")
 
list=[]
nginx_file="/var/log/nginx/access.log"
f=file(nginx_file).readlines()
for i in f:
  nginx_ip=i.split()[0]
  list.append(nginx_ip)
nginxip=set(list)
for j in nginxip:
  num=list.count(j)
  if num > 10:
    nginx_protect(j)
  print "IP:%s NUM:%s" %  (j,num)

5.寫一個腳本計算出全部進程所佔用內存大小
#!/usr/bin/python
# coding=utf8

import os

list=[]
cmd='ps aux'
sum=0
status=os.popen(cmd).readlines()
for i in status:
  a=i.split()[5]
  list.append(a)
for i in list[1:-1]:
  sum=sum+int(i)
print "%s:%sB" % (list[0],sum)

6.MySQL狀態監控
#!/usr/bin/python
#coding=utf8

import MySQLdb

host="localhost"
user="wjq"
passwd="123456"
db="test"

Com_insert="show global status like 'Com_insert';"
Com_update="show global status like 'Com_update';"
Com_select="show global status like 'Com_select';"
Com_delete="show global status like 'Com_delete';"
Open_tables="show global status like 'Open_tables';"
Qcache_hits="show global status like 'Qcache_hits';"

def getConn(host,user,passwd,db):
  try:
    conn = MySQLdb.connect(host,user,passwd,db)
    return conn
  except:
    print("數據庫鏈接失敗")

def getValue(conn,query):
  cursor = conn.cursor()
  getNum = cursor.execute(query)
  if getNum > 0:
    data = cursor.fetchone()
  return int(data[1])

if __name__ == '__main__':
  conn=getConn(host,user,passwd,db)
  Com_insert=getValue(conn,Com_insert)
  Com_update=getValue(conn,Com_update)
  Com_select=getValue(conn,Com_select)
  Com_delete=getValue(conn,Com_delete)
  Open_tables=getValue(conn,Open_tables)
  Qcache_hits=getValue(conn,Qcache_hits)
  print "\t*****MySQL Status*****"
  print "\tCom_insert:%s\n" % Com_insert
  print "\tCom_update:%s\n" % Com_update
  print "\tCom_select:%s\n" % Com_select
  print "\tCom_delete:%s\n" % Com_delete
  print "\tOpen_tables:%s\n" % Open_tables
  print "\tQcache_hits:%s\n" % Qcache_hits

7.自定義密碼長度,生成隨機密碼
#!/usr/bin/python
# coding=utf8
import random

list=[]
def Passwd(num):
  for i in range(int(num)):
    a=random.randrange(0,int(num))
    if i == a:
      b1=random.randint(0,9)
      list.append(str(b1))
    else:
      b2=chr(random.randint(65,90))
      list.append(b2)  
  b3=''.join(list)
  return b3    

if __name__ == '__main__':
  num=raw_input("生成密碼的長度爲:")
  password=Passwd(num)
  print password

8.python實現mysql的zabbix監控腳本

#!/usr/bin/python
#coding=utf8

import MySQLdb
import sys

host="localhost"
user="wjq"
passwd="123456"
db="test"
Com_insert="show global status like 'Com_insert';"
Com_update="show global status like 'Com_update';"
Com_select="show global status like 'Com_select';"
Com_delete="show global status like 'Com_delete';"
Open_tables="show global status like 'Open_tables';"
Qcache_hits="show global status like 'Qcache_hits';"

def getConn(host,user,passwd,db):
  try:
    a = MySQLdb.connect(host,user,passwd,db)
    return a
  except:
    print "數據庫鏈接失敗"

def getValue(conn,query):
  try:
    cursor = conn.cursor()
    getNum = cursor.execute(query)
    if getNum > 0:
      data = cursor.fetchone()
      return int(data[1])
  except:
    print "查詢失敗"

conn = getConn(host,user,passwd,db)
if sys.argv[1] == 'insert':    
  Com_insert = getValue(conn,Com_insert)
  print Com_insert  
elif sys.argv[1] == 'delete':
  Com_delete = getValue(conn,Com_delete)
  print Com_delete
elif sys.argv[1] == 'select':
  Com_select = getValue(conn,Com_select)
  print Com_select
elif sys.argv[1] == 'update':
  Com_update = getValue(conn,Com_update)
  print Com_update
elif sys.argv[1] == 'table_num':
  Open_tables = getValue(conn,Open_tables)
  print Open_tables
elif sys.argv[1] == 'cache_hit':
  Qcache_hits = getValue(conn,Qcache_hits)
  print Qcache_hitspython

相關文章
相關標籤/搜索