国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁(yè) > 編程 > Python > 正文

python監(jiān)控文件或目錄變化

2019-11-25 16:45:08
字體:
來(lái)源:轉(zhuǎn)載
供稿:網(wǎng)友

本文實(shí)例實(shí)現(xiàn)的功能是監(jiān)控一個(gè)文件或目錄的變化,如果有變化,把文件上傳備份至備份主機(jī),并且要監(jiān)控上傳過(guò)程是否有問(wèn)題等,具體內(nèi)容如下

#!/usr/bin/env python#coding=utf-8##Status wd gs/ccs sql file changed#文件有變化上傳至備份主機(jī),上傳之后驗(yàn)證文件是否正確#import paramiko,os,sys,datetime,time,MySQLdbfrom pyinotify import WatchManager, Notifier, ProcessEvent, IN_DELETE, IN_CREATE,IN_MODIFY'''CREATE TABLE `wddel_log.status_sql` ( `ip` varchar(16) NOT NULL COMMENT '機(jī)器IP', `tar_name` varchar(50) NOT NULL COMMENT '備份文件名字', `md5` varchar(50) NOT NULL COMMENT '備份文件MD5', `flag` int(2) NOT NULL COMMENT '0:成功;1:失敗', `error_log` varchar(100) NOT NULL COMMENT '錯(cuò)誤日志', `uptime` datetime NOT NULL COMMENT '更新時(shí)間', KEY `ip` (`ip`), KEY `uptime` (`uptime`)) ENGINE=InnoDB DEFAULT CHARSET=utf8'''#日志表創(chuàng)建腳本GM_path='/home/asktao/'center_hostname='192.168.1.100'center_username='root'center_password='123456'center_port=63008def log2db(ip,tar_name,md5,flag,error='0'):#刪除日志入庫(kù)  try:    tar_name = os.path.split(tar_name)[1]    now = time.strftime("%Y-%m-%d %H:%M:%S")    conn = MySQLdb.connect(host = '192.168.1.104',user = 'root',passwd = '1q2w3e4r',charset='utf8',connect_timeout=20)    cursor = conn.cursor()    sql = "SELECT ip FROM wddel_log.status_sql WHERE ip='%s'" % ip    cursor.execute(sql)    res = cursor.fetchall()    if len(res)==0:      inster_sql = "insert into wddel_log.status_sql VALUES('%s','%s','%s',%s,'%s','%s')" % (ip,tar_name,md5,flag,error,now)      cursor.execute(inster_sql)      conn.commit()    else:      update_sql = "UPDATE wddel_log.status_sql SET md5='%s',flag='%s',error_log='%s',uptime='%s' WHERE ip='%s'" % (md5,flag,error,now,ip)      cursor.execute(update_sql)      conn.commit()    cursor.close()    conn.close()  except Exception,e:    print edef find_ip():#獲取本地eth0的IP地址  ip = os.popen("/sbin/ip a|grep 'global eth0'").readlines()[0].split()[1].split("/")[0]  if "192.168." in ip:    ip = os.popen("/sbin/ip a|grep 'global eth1'").readlines()[0].split()[1].split("/")[0]  return ipdef md5sum(file_name):#驗(yàn)證sql打包文件的MD5  if os.path.isfile(file_name):    f = open(file_name,'rb')    py_ver = sys.version[:3]    if py_ver == "2.4":      import md5 as hashlib    else:      import hashlib      md5 = hashlib.md5(f.read()).hexdigest()      f.close()      return md5  else:    return 0def center_md5(file_name):#上傳至備份中心的文件的MD5  try:    s=paramiko.SSHClient()    s.set_missing_host_key_policy(paramiko.AutoAddPolicy())    s.connect(hostname = center_hostname,port=center_port,username=center_username, password=center_password)    conm = "/usr/bin/md5sum %s" % file_name    stdin,stdout,stderr=s.exec_command(conm)    result = stdout.readlines()[0].split()[0].strip()    s.close()    return result  except Exception,e:    return edef back_file(ip,tar_name,tar_md5):#上傳文件到備份中心  remote_dir='/data/sql'  file_name=os.path.join(remote_dir,os.path.split(tar_name)[1])  try:    t=paramiko.Transport((center_hostname,center_port))    t.connect(username=center_username,password=center_password)    sftp=paramiko.SFTPClient.from_transport(t)    sftp.put(tar_name,file_name)    t.close()    #print "%s back_file OK" % tar_name    os.remove(tar_name)    remot_md5=center_md5(file_name)    if remot_md5 == tar_md5:      log2db(ip,tar_name,tar_md5,0)    else:      log2db(ip,tar_name,tar_md5,1,'remot_md5!=tar_md5')  except Exception,e:    #print "connect error!"    log2db(ip,tar_name,tar_md5,1,e)    os.remove(tar_name)def back_sql():#執(zhí)行備份  ip = find_ip()  tar_name = "/tmp/%s.tar.gz" % ip  sql_conn = "/usr/bin/find %s -type f -name '*.sql'|/usr/bin/xargs /bin/tar zcvPf %s" % (GM_path,tar_name)  sql_tar = os.popen(sql_conn).readlines()  tar_md5 = md5sum(tar_name)  if tar_md5 != 0:    back_file(ip,tar_name,tar_md5)  else:    error_log = "%s not find" % tar_name    log2db(ip,tar_name,tar_md5,0,error_log)class PFilePath(ProcessEvent):#文件變化的觸發(fā)  def process_IN_CREATE(self, event):    if os.path.splitext(event.name)[1] == ".sql":      text = "Create file: %s " % os.path.join(event.path, event.name)      #print text      back_sql()  def process_IN_MODIFY(self, event):    if os.path.splitext(event.name)[1] == ".sql":      text = "Modify file: %s " % os.path.join(event.path, event.name)      #print text      back_sql()def FSMonitor():#主監(jiān)控函數(shù)  back_sql()#運(yùn)行腳本先備份sql文件  wm = WatchManager()  mask = IN_CREATE |IN_MODIFY  notifier = Notifier(wm, PFilePath())  wdd = wm.add_watch(GM_path, mask, rec=True)  print 'now starting monitor %s' % (GM_path)  while True:    try :      notifier.process_events()      if notifier.check_events():        notifier.read_events()    except KeyboardInterrupt:      notifier.stop()      breakif __name__ == "__main__":  FSMonitor()

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助。

發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 化德县| 连城县| 宁安市| 准格尔旗| 宣威市| 中西区| 隆安县| 察隅县| 天峨县| 法库县| 丁青县| 蒙城县| 九台市| 威宁| 开远市| 柘荣县| 临颍县| 芒康县| 安徽省| 咸宁市| 恩平市| 津市市| 积石山| 隆林| 伊宁市| 子长县| 罗平县| 黄山市| 文安县| 墨竹工卡县| 成武县| 天津市| 化州市| 贵德县| 洪泽县| 永胜县| 普兰县| 六盘水市| 玉溪市| 吉水县| 琼中|