Combat pratique : comment utiliser Python pour surveiller automatiquement les dossiers afin de terminer le déploiement du service

王林
Libérer: 2023-05-09 10:46:07
avant
1466 Les gens l'ont consulté

实战 | 如何用 Python 自动化监控文件夹完成服务部署!

Bonjour à tous, je m'appelle Peng Tao !

Lors du déploiement récent de projets frontaux, vous devez télécharger le package compressé du projet frontal dans le répertoire /tmp du serveur d'applications via l'hôte bastion, puis entrer dans le serveur d'applications et utiliser la commande mv pour déplacer le fichier compressé. dans le répertoire de paramètres du projet Nginx. 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 expliquera comment utiliser Python pour surveiller les dossiers afin de faciliter le déploiement des services.

1. Préparation

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 rappellera une fonction d'événement, nous pouvons écrire une logique personnalisée à l'intérieur pour répondre à nos besoins.

# 安装依赖包
pip3 install watchdog
Copier après la connexion

Adresse du projet :

​https://www.php.cn/link/690e6de4e3e2c0916b6160d9959d156b​​​

2. le dossier Table des matières

from watchdog.observers import Observer
...
# 创建一个监听器,用来监听文件夹目录
observer = Observer()
...
Copier après la connexion

Ensuite, créez 2 objets de gestion d'événements.

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 remplace le répertoire. Méthode d'événement "Nouveau ou modifié", terminez l'opération de déplacement du fichier compressé :

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))
Copier après la connexion

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 du fichier compressé :

...
 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压缩包!')
...
Copier après la connexion

Ensuite, démarrez ce qui précède via l'écouteur Deux tâches de surveillance d'événements

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()
...
Copier après la connexion

Enfin, nous passons 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.log
Copier après la connexion

3. Résumé

Grâce aux opérations ci-dessus, chaque fois que je passe la machine bastion, téléchargez le fichier de projet compressé zip frontal dans le répertoire /tmp du serveur d'applications, et le programme effectuera automatiquement les opérations suivantes et terminera automatiquement le déploiement de l'application.

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!

Étiquettes associées:
source:51cto.com
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal