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