Maison > Article > développement back-end > Génial, utilisez Python pour automatiser le déploiement de services !
Lors du déploiement récent de projets frontaux, vous devez d'abord télécharger le package compressé du projet front-end dans le répertoire /tmp du serveur d'applications via la machine bastion, puis entrer dans le serveur d'applications et utiliser la commande mv pour déplacer le fichier compressé dans le répertoire des paramètres du projet Nginx, et enfin utilisez la commande unzip pour décompresser le fichier afin de terminer le déploiement du projet.
Une analyse minutieuse montre que la plupart des opérations sont des actions répétitives et que l'exécution manuelle de ces opérations réduira considérablement l'efficacité du travail.
Cet article explique comment utiliser Python pour surveiller les dossiers afin de faciliter le déploiement du service.
Nous présenterons ici une bibliothèque de dépendances Python "watchdog"
Elle peut être utilisée pour surveiller les modifications de fichiers dans un certain répertoire de fichiers, y compris : la suppression, la modification, l'ajout, etc., chaque opération will En rappelant une fonction d'événement, nous pouvons écrire une logique personnalisée en interne pour répondre à nos besoins.
# 安装依赖包 pip3 install watchdog
Adresse du projet :
https://www.php.cn/link/47841cc9e552bd5c40164db7073b817b
from watchdog.observers import Observer ... # 创建一个监听器,用来监听文件夹目录 observer = Observer() ...
PS : Cet objet hérite de la classe "FileSystemEventHandler".
Ils sont utilisés respectivement pour surveiller le répertoire "/tmp" et le répertoire "/home/project/frontend". Supposons que les objets d'événement soient nommés obj1 et obj2
obj1 est responsable de la surveillance du répertoire /tmp et. réécrit la méthode d'événement "Nouveau ou Modifié" pour terminer l'opération de déplacement des fichiers compressés :
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 est responsable de la surveillance du répertoire /home/project/frontend, et réécrit également la méthode d'événement "Nouveau ou Modifié" pour terminer l'opération de décompression de fichiers compressés :
... 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压缩包!') ...Ensuite, via l'écouteur, démarrez les tâches d'écoute pour les deux événements ci-dessus :
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() ...Enfin, nous utilisons la commande "nohup" sur le serveur pour laisser le programme de surveillance de fichiers s'exécuter en arrière-plan.
# 在后台运行 # 项目文件:watch_folder.py # 日志文件:watch_folder.log nohup python3 -u watch_folder.py > watch_folder.log 2>&1 & # 查看日志: cat watch_folder.log3. Résumé
J'ai téléchargé le code source de l'article sur le backend et j'ai répondu avec le mot-clé "watchdog" pour obtenir le code source complet.
Si vous pensez que l'article est bon, aimez-le et partagez-le, car ce sera pour moi la plus forte motivation pour continuer à publier davantage d'articles de haute qualité !
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!