电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

您的位置:首頁技術(shù)文章
文章詳情頁

python中watchdog文件監(jiān)控與檢測(cè)上傳功能

瀏覽:2日期:2022-07-06 17:33:07

引言

上一篇介紹完了觀察者模式的原理,本篇想就此再介紹一個(gè)小應(yīng)用,雖然我也就玩了一下午,是當(dāng)時(shí)看observer正好找到的,以及還有Django-observer,但Django很久沒用了,所以提下這個(gè)作為一個(gè)筆記。

watchdog介紹

Watchdog的中文的“看門狗”,有保護(hù)的意思。最早引入Watchdog是在單片機(jī)系統(tǒng)中,由于單片機(jī)的工作環(huán)境容易受到外界磁場(chǎng)的干擾,導(dǎo)致程序“跑飛”,造成整個(gè)系統(tǒng)無法正常工作,因此,引入了一個(gè)“看門狗”,對(duì)單片機(jī)的運(yùn)行狀態(tài)進(jìn)行實(shí)時(shí)監(jiān)測(cè),針對(duì)運(yùn)行故障做一些保護(hù)處理,譬如讓系統(tǒng)重啟。這種Watchdog屬于硬件層面,必須有硬件電路的支持。Linux也引入了Watchdog,在Linux內(nèi)核下,當(dāng)Watchdog啟動(dòng)后,便設(shè)定了一個(gè)定時(shí)器,如果在超時(shí)時(shí)間內(nèi)沒有對(duì)/dev/Watchdog進(jìn)行寫操作,則會(huì)導(dǎo)致系統(tǒng)重啟。通過定時(shí)器實(shí)現(xiàn)的Watchdog屬于軟件層面。

嗯,這樣的嘛。好像上面這段話沒啥用,連成為談資都不行。我也是直接百度第一篇復(fù)制一段當(dāng)做介紹,習(xí)慣使然。(手動(dòng)狗頭)

在python中文件監(jiān)控主要有兩個(gè)庫,一個(gè)是pyinotify ( https://github.com/seb-m/pyinotify/wiki ),一個(gè)是watchdog(http://pythonhosted.org/watchdog/)。pyinotify依賴于Linux平臺(tái)的inotify,后者則對(duì)不同平臺(tái)的的事件都進(jìn)行了封裝。

watchdog使用

在python中可以直接通過pip安裝:

pip install watchdog -i https://pypi.tuna.tsinghua.edu.cn/simple

watchdog主要采用觀察者模型。主要有三個(gè)角色:observer,event_handler,被監(jiān)控的文件夾。三者原本是獨(dú)立的,主要通過observer.schedule函數(shù)將三者串起來。

事件類(event):

watchdog.events.FileSystemEvent(event_type, src_path, is_directory=False) event_type為事件類型,為moved、deleted、created或modified的其中之一 src_path為觸發(fā)該事件的文件或目錄路徑 is_directory為該事件是否由一個(gè)目錄觸發(fā)

watchdog能實(shí)現(xiàn)在不同平臺(tái)下都能兼容,并監(jiān)控相關(guān)事件,但是如果在Windows下,是有很多問題的,具體的會(huì)在后面提出,那懂了事件類,我們就可以看看事件處理方法:

那現(xiàn)在有了處

def on_created(event): print(f'hey, {event.src_path} has been created!')def on_deleted(event): print(f'Someone deleted {event.src_path}!')def on_modified(event): print(f'hey buddy, {event.src_path} has been modified')def on_moved(event): print(f'ok ok ok, someone moved {event.src_path} to {event.dest_path}')

理事件的函數(shù),就需要在主程序里創(chuàng)建一個(gè)監(jiān)聽程序了:

path = '.' go_recursively = True my_observer = Observer() my_observer.schedule(my_event_handler, path, recursive=True)

observer.schedule(event_handler, path, recursive=False)相當(dāng)于實(shí)例化監(jiān)聽對(duì)象,監(jiān)控指定路徑path,該路徑觸發(fā)任何事件都會(huì)調(diào)用event_handler來處理,如果path是目錄,則recursive=True則會(huì)遞歸監(jiān)控該目錄的所有變化。每一次調(diào)用schedule()對(duì)一個(gè)路徑進(jìn)行監(jiān)控處理就叫做一個(gè)watch,schedule()方法會(huì)返回這個(gè)watch,接著可以對(duì)這個(gè)watch做其他操作,如為該watch增加多個(gè)event處理器等。

那了解到這里,就可以寫一個(gè)demo程序進(jìn)行測(cè)試了:

from watchdog.observers import Observerfrom watchdog.events import *import timeclass FileEventHandler(FileSystemEventHandler): def __init__(self): FileSystemEventHandler.__init__(self) def on_moved(self, event): if event.is_directory: print('directory moved from {0} to {1}'.format(event.src_path,event.dest_path)) else: print('file moved from {0} to {1}'.format(event.src_path,event.dest_path)) def on_created(self, event): if event.is_directory: print('directory created:{0}'.format(event.src_path)) else: print('file created:{0}'.format(event.src_path)) def on_deleted(self, event): if event.is_directory: print('directory deleted:{0}'.format(event.src_path)) else: print('file deleted:{0}'.format(event.src_path)) def on_modified(self, event): if event.is_directory: print('directory modified:{0}'.format(event.src_path)) else: print('file modified:{0}'.format(event.src_path))if __name__ == '__main__': observer = Observer() event_handler = FileEventHandler() observer.schedule(event_handler,r'D:codedingshirenwu',True) observer.start() try: while True: time.sleep(1) except KeyboardInterrupt: observer.stop() observer.join()

代碼參考自python中文件變化監(jiān)控-watchdog

不過這里只是監(jiān)控了單個(gè),我們可以通過循環(huán)來監(jiān)控多個(gè)文件夾:

dirs = [r’D:codedingshirenwu’, r’D:codetuiliu’]for dir in dirs: event_handler = FileEventHandler() observer.schedule(event_handler, dir, True)observer.start()

到此為止,基本上已經(jīng)知道這個(gè)模塊到底怎么用了,但當(dāng)我準(zhǔn)備在事件里加一個(gè)上傳機(jī)制的時(shí)候,發(fā)現(xiàn)Windows下的一些問題。Windows下watchdog并沒有權(quán)限去監(jiān)控文件是否完整。即我有一個(gè)大文件,2G的視頻即使是內(nèi)部百M(fèi)傳輸,也需要幾十秒的時(shí)間,但watchdog只能接收到文件創(chuàng)建的時(shí)間就立刻進(jìn)行了文件上傳,而不是同Linux并使用的inotify,似乎沒有什么好的辦法,我也只是能上傳一些比較小的如圖片等秒傳秒下的文件,下面為我的代碼:

import loggingimport queueimport threadingimport timeimport watchdog.observers as observersimport watchdog.events as eventsfrom ftplib import FTPlogger = logging.getLogger(__name__)SENTINEL = Nonedef upload(f, remote_path, local_path): fp = open(local_path, 'rb') buf_size = 1024 f.storbinary('STOR {}'.format(remote_path), fp, buf_size) fp.close()class MyEventHandler(events.FileSystemEventHandler): def on_any_event(self, event): super(MyEventHandler, self).on_any_event(event) queue.put(event) def __init__(self, queue): self.queue = queuedef process(queue): while True: event = queue.get() logger.info(event) print(event.key) # tuple (’modified’, ’C:UsersadminDesktop公司文件testGitHubisadb.idea’, True) if (event.key)[0] == 'created': upload(ftp, remote_path, event.src_path)if __name__ == ’__main__’: logging.basicConfig(level=logging.DEBUG, format=’[%(asctime)s %(threadName)s] %(message)s’, datefmt=’%H:%M:%S’) ftp = FTP() ftp.connect('x.x.x.x', 21) # 第一個(gè)參數(shù)可以是ftp服務(wù)器的ip或者域名,第二個(gè)參數(shù)為ftp服務(wù)器的連接端口,默認(rèn)為21 ftp.login(username, password) # 匿名登錄直接使用ftp.login() queue = queue.Queue() num_workers = 4 pool = [threading.Thread(target=process, args=(queue,)) for i in range(num_workers)] for t in pool: t.daemon = True t.start() event_handler = MyEventHandler(queue) observer = observers.Observer() observer.schedule( event_handler, path=r’C:UsersadminDesktop公司文件testGitHubisadb’, recursive=True) observer.start() try: while True: time.sleep(1) except KeyboardInterrupt: observer.stop() observer.join()

建立了一個(gè)工作線程池,而不是累積文件系統(tǒng)事件,該線程從一個(gè)公共隊(duì)列中獲取任務(wù)。上傳文件我是寫了一個(gè)類調(diào)用,但那個(gè)文件找不到了。。所以改用了函數(shù),這里會(huì)有問題是:IOError: [Errno 13] Permission denied: u’D:pycharmtest.mp4’

然后再Stack Overflow找到了一個(gè)解決方案:當(dāng)上傳一個(gè)大文件的時(shí)候,同時(shí)上傳一個(gè)空文本,記錄這個(gè)文件的大小,然后對(duì)這個(gè)文件進(jìn)行輪詢,只有當(dāng)該文件的大小不再發(fā)生變化時(shí),我們認(rèn)為這個(gè)文件已經(jīng)生成成功,這時(shí)再考慮上傳,不過我也就寫個(gè)demo,太麻煩了。。。如果有人有更好的方式,可以評(píng)論或者私信我。

到此這篇關(guān)于python中watchdog文件監(jiān)控與檢測(cè)上傳的文章就介紹到這了,更多相關(guān)python watchdog監(jiān)控文件內(nèi)容請(qǐng)搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!

標(biāo)簽: Python 編程
相關(guān)文章:
主站蜘蛛池模板: 智能交通网_智能交通系统_ITS_交通监控_卫星导航_智能交通行业 | 广州企亚 - 数码直喷、白墨印花、源头厂家、透气无手感方案服务商! | 防爆型气象站_农业气象站_校园气象站_农业四情监测系统「山东万象环境科技有限公司」 | 沈阳激光机-沈阳喷码机-沈阳光纤激光打标机-沈阳co2激光打标机 | 杭州荣奥家具有限公司-浙江办公家具,杭州办公家具厂 | 衡阳耐适防护科技有限公司——威仕盾焊接防护用品官网/焊工手套/焊接防护服/皮革防护手套 | 深圳网站建设-高端企业网站开发-定制网页设计制作公司 | 道达尔润滑油-食品级润滑油-道达尔导热油-合成导热油,深圳道达尔代理商合-深圳浩方正大官网 | 垃圾清运公司_环卫保洁公司_市政道路保洁公司-华富环境 | 喷漆房_废气处理设备-湖北天地鑫环保设备有限公司 | 培训中心-海南香蕉蛋糕加盟店技术翰香原中心官网总部 | 合肥制氮机_合肥空压机厂家_安徽真空泵-凯圣精机 | 打孔器,打孔钳厂家【温州新星德牌五金工具】| 混合反应量热仪-高温高压量热仪-微机差热分析仪DTA|凯璞百科 | 字典-新华字典-在线字典查字-字典趣| 吲哚菁绿衍生物-酶底物法大肠菌群检测试剂-北京和信同通科技发展有限公司 | 不锈钢法兰-碳钢法兰-法兰盘生产加工厂家-[鼎捷峰]-不锈钢法兰-碳钢法兰-法兰盘生产加工厂家-[鼎捷峰] | 新能源汽车教学设备厂家报价[汽车教学设备运营18年]-恒信教具 | 高精度-恒温冷水机-螺杆式冰水机-蒸发冷冷水机-北京蓝海神骏科技有限公司 | 今日娱乐圈——影视剧集_八卦娱乐_明星八卦_最新娱乐八卦新闻 | UV固化机_UVLED光固化机_UV干燥机生产厂家-上海冠顶公司专业生产UV固化机设备 | 广东西屋电气有限公司-广东西屋电气有限公司 | 电伴热系统施工_仪表电伴热保温箱厂家_沃安电伴热管缆工业技术(济南)有限公司 | 煤粉取样器-射油器-便携式等速飞灰取样器-连灵动 | _网名词典_网名大全_qq网名_情侣网名_个性网名 | 物流公司电话|附近物流公司电话上门取货 | 纸塑分离机-纸塑分离清洗机设备-压力筛-碎浆机厂家金双联环保 | 能量回馈_制动单元_电梯节能_能耗制动_深圳市合兴加能科技有限公司 | 电车线(用于供电给电车的输电线路)-百科 | 泰安办公家具-泰安派格办公用品有限公司| 柔性输送线|柔性链板|齿形链-上海赫勒输送设备有限公司首页[输送机] | 污水处理设备维修_污水处理工程改造_机械格栅_过滤设备_气浮设备_刮吸泥机_污泥浓缩罐_污水处理设备_污水处理工程-北京龙泉新禹科技有限公司 | 木材烘干机,木炭烘干机,纸管/佛香烘干设备-河南蓝天机械制造有限公司 | 软启动器-上海能曼电气有限公司| 校园气象站_超声波气象站_农业气象站_雨量监测站_风途科技 | 玉米深加工设备|玉米加工机械|玉米加工设备|玉米深加工机械-河南成立粮油机械有限公司 | 彭世修脚_修脚加盟_彭世修脚加盟_彭世足疗加盟_足疗加盟连锁_彭世修脚技术培训_彭世足疗 | 高压互感器,电流互感器,电压互感器-上海鄂互电气科技有限公司 | 东莞螺丝|东莞螺丝厂|东莞不锈钢螺丝|东莞组合螺丝|东莞精密螺丝厂家-东莞利浩五金专业紧固件厂家 | CTP磁天平|小电容测量仪|阴阳极极化_双液系沸点测定仪|dsj电渗实验装置-南京桑力电子设备厂 | 高柔性拖链电缆_卷筒电缆_耐磨耐折聚氨酯电缆-玖泰特种电缆 |