Génial, utilisez Python pour automatiser le déploiement de services !

王林
Libérer: 2023-04-14 13:49:03
avant
2082 Les gens l'ont consulté

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.

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

Adresse du projet :

//m.sbmmt.com/link/47841cc9e552bd5c40164db7073b817b​​

2. écoute du dossier de fichiers répertoire :
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. 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))
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 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压缩包!')
...
Copier après la connexion

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

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.log
Copier après la connexion
3. Résumé

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

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!

É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