Heim > Artikel > Backend-Entwicklung > Praktischer Kampf: So verwenden Sie Python, um Ordner automatisch zu überwachen und die Dienstbereitstellung abzuschließen
Hallo zusammen, ich bin Peng Tao!
Wenn Sie kürzlich Front-End-Projekte bereitstellen, müssen Sie das komprimierte Paket des Front-End-Projekts über den Bastion-Host in das Verzeichnis /tmp des Anwendungsservers hochladen, dann den Anwendungsserver aufrufen und die komprimierte Datei mit dem Befehl mv verschieben Verwenden Sie abschließend den Befehl „unzip“, um die Datei in das Nginx-Projekteinstellungsverzeichnis zu dekomprimieren und die Bereitstellung des Projekts abzuschließen.
Eine sorgfältige Analyse zeigt, dass es sich bei den meisten Vorgängen um sich wiederholende Vorgänge handelt und die manuelle Ausführung dieser Vorgänge die Arbeitseffizienz erheblich verringert.
In diesem Artikel erfahren Sie, wie Sie mit Python Ordner überwachen, um die Bereitstellung des Dienstes zu unterstützen.
Hier stellen wir eine Python-Abhängigkeitsbibliothek „Watchdog“ vor
Sie kann zum Überwachen von Dateiänderungen in einem bestimmten Dateiverzeichnis verwendet werden, einschließlich: Löschen, Ändern, Hinzufügen usw., jeder Vorgang wird zurückgerufen Wenn wir eine Ereignisfunktion haben, können wir benutzerdefinierte Logik hineinschreiben, um unsere Anforderungen zu erfüllen.
# 安装依赖包 pip3 install watchdog
Projektadresse:
https://www.php.cn/link/690e6de4e3e2c0916b6160d9959d156b
from watchdog.observers import Observer ... # 创建一个监听器,用来监听文件夹目录 observer = Observer() ...
Erstellen Sie dann zwei Ereignisbehandlungsobjekte.
PS: Dieses Objekt erbt von der Klasse „FileSystemEventHandler“.
Sie werden verwendet, um das Verzeichnis „/tmp“ bzw. das Verzeichnis „/home/project/frontend“ zu überwachen. Gehen Sie davon aus, dass die Ereignisobjekte obj1 und obj2 heißen.
obj1 ist für die Überwachung des Verzeichnisses /tmp verantwortlich und überschreibt das Ereignismethode „Neu oder geändert“, um den Verschiebevorgang der komprimierten Datei abzuschließen:
from watchdog.events import * import ntpath import shutil import zipfile def get_filename(filepath): """ 根据文件夹目录,获取文件名称(待后缀) :param filepath: :return: """ return ntpath.basename(filepath) class FileMoveHandler(FileSystemEventHandler): def __init__(self): FileSystemEventHandler.__init__(self) ... # 文件新建 def on_created(self, event): # 新建文件夹 if event.is_directory: # print("directory created:{0}".format(event.src_path)) pass # 新建文件 else: # print("file created:{0}".format(event.src_path)) filename = get_filename(event.src_path) # 如果属于前端的4个项目压缩包,开始文件夹的操作 if filename in watch_tags: self.start(filename) ... def on_modified(self, event): if event.is_directory: # print("directory modified:{0}".format(event.src_path)) pass else: # print("file modified:{0}".format(event.src_path)) filename = get_filename(event.src_path) if filename in watch_tags: self.start(filename) ... def start(self, filename): """ 文件处理逻辑 :param filename: :return: """ try: # 文件名不带后缀 filename_without_suffix = filename.split(".")[0] # 源文件路径(压缩包文件) source_file_path = watch_folder + filename # 目标文件路径(压缩包文件) target_file_path = target_folder + filename # 目标项目文件夹(目标项目) target_project_path = target_folder + filename_without_suffix # 1、复制文件到目标文件夹 print(f"拷贝源目录{source_file_path},目标文件夹:{target_folder}") # 删除目标文件夹下的压缩文件 if os.path.exists(target_file_path): os.remove(target_file_path) # 移动文件到目标文件夹中 shutil.move(source_file_path, target_folder) # 2、清空目标文件夹中内的所有文件夹(如果存在) # 如果不存在,新建一个文件夹 if os.path.exists(target_project_path): shutil.rmtree(target_project_path, ignore_errors=True) print(f"项目{filename_without_suffix}移动成功!") except Exception as e: print("部署失败,错误原因:", str(e.args))
obj2 ist für die Überwachung des Verzeichnisses /home/project/frontend verantwortlich und schreibt außerdem die Ereignismethode „Neu oder geändert“ neu, um den Dekomprimierungsvorgang abzuschließen der komprimierten Datei:
... def start(self, filename): # 文件名不带后缀 filename_without_suffix = filename.split(".")[0] # 目标文件路径(压缩包文件) target_file_path = target_folder + filename # 目标项目文件夹(目标项目) target_project_path = target_folder + filename_without_suffix r = zipfile.is_zipfile(target_file_path) if r: fz = zipfile.ZipFile(target_file_path, 'r') for file in fz.namelist(): fz.extract(file, target_folder) else: print('这不是一个正常的zip压缩包!') ...
Dann starten Sie das Obige über den Listener. Zwei Ereignisüberwachungsaufgaben
import time ... if __name__ == "__main__": # 待监听的文件夹目录 watch_folder = "/tmp/" # 项目目标文件夹目录 target_folder = "/home/project/frontend/" # 监听文件夹名称,即:项目压缩包名称 watch_tags = ['proj1.zip', 'proj2.zip', 'proj3.zip', 'proj4.zip'] # 创建一个监听器,用来监听文件夹目录 observer = Observer() # 创建两个事件处理对象 move_handler = FileMoveHandler() unzip_handler = FileUnzipHandler() # 启动监控任务 # 参数分别是:观察者、监听目录、是否监听子目录 observer.schedule(move_handler, watch_folder, True) observer.schedule(unzip_handler, target_folder, True) observer.start() try: while True: time.sleep(1) except KeyboardInterrupt: observer.stop() observer.join() ...
Schließlich verwenden wir den Befehl „nohup“ auf dem Server, um das Dateiüberwachungsprogramm im Hintergrund laufen zu lassen
# 在后台运行 # 项目文件:watch_folder.py # 日志文件:watch_folder.log nohup python3 -u watch_folder.py > watch_folder.log 2>&1 & # 查看日志: cat watch_folder.log
3. Zusammenfassung
Das obige ist der detaillierte Inhalt vonPraktischer Kampf: So verwenden Sie Python, um Ordner automatisch zu überwachen und die Dienstbereitstellung abzuschließen. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!