Heim > Artikel > Backend-Entwicklung > Großartig, verwenden Sie Python, um die Servicebereitstellung zu automatisieren!
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 den Befehl mv verwenden, um es zu verschieben Kopieren Sie die komprimierte Datei in das Nginx-Projekteinstellungsverzeichnis und dekomprimieren Sie sie schließlich mit dem Befehl „unzip“, um 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 verwendet werden, um Dateiänderungen in einem bestimmten Dateiverzeichnis zu überwachen, einschließlich: Löschen, Ändern, Hinzufügen usw. bei jedem Vorgang Wenn wir eine Ereignisfunktion zurückrufen, können wir intern benutzerdefinierte Logik schreiben, um unsere Anforderungen zu erfüllen.
# 安装依赖包 pip3 install watchdog
Projektadresse:
https://www.php.cn/link/47841cc9e552bd5c40164db7073b817b
from watchdog.observers import Observer ... # 创建一个监听器,用来监听文件夹目录 observer = Observer() ...
PS: Dieses Objekt erbt von der Klasse „FileSystemEventHandler“.
Sie werden verwendet, um das Verzeichnis „/tmp“ bzw. das Verzeichnis „/home/project/frontend“ zu überwachen. Angenommen, die Ereignisobjekte heißen obj1 und obj2.
obj1 ist für die Überwachung des Verzeichnisses /tmp verantwortlich schreibt die Ereignismethode „Neu oder geändert“ neu, um den Verschiebevorgang komprimierter Dateien 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 von komprimierten Dateien:
... 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 wir über den Listener die Überwachungsaufgaben für die beiden oben genannten Ereignisse:
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() ...Abschließend 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.log3. Zusammenfassung
Ich habe den Quellcode im Artikel im Backend hochgeladen und antworte mit dem Schlüsselwort „watchdog“, um den vollständigen Quellcode zu erhalten.
Wenn Sie den Artikel gut finden, liken und teilen Sie ihn bitte, denn das wird für mich die stärkste Motivation sein, weiterhin weitere qualitativ hochwertige Artikel herauszugeben!
Das obige ist der detaillierte Inhalt vonGroßartig, verwenden Sie Python, um die Servicebereitstellung zu automatisieren!. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!