开发者社区> Carl_奕然> 正文
阿里云
为了无法计算的价值
打开APP
阿里云APP内打开

Python3,仅仅2段代码,就实现项目代码自动上传及部署,再也不需要Jenkins了。

简介: Python3,仅仅2段代码,就实现项目代码自动上传及部署,再也不需要Jenkins了。
+关注继续查看

1、引言


小鱼:你在手动打包,要先rm - rf ,再 go away ??

小屌丝:鱼哥,你在说啥嘞, 我可是正经人…

小鱼:那你干啥,手动打包,没有Jenkins吗,没有自动打包工具吗?

小屌丝:如果能Jenkins自动发布,我还干啥费劲的执行手动打包。

小鱼:不能Jenkins?跨域了? 不能安装? 还是不会自动打包?

小屌丝:一来是跨域,其次,无法在目标服务器部署Jenkins,所以,只能手动打包上传…

小鱼:这样啊, 那你你应该庆幸,你遇到我了。。。。

小屌丝:鱼哥,那你的意思,你有好的方法了!

小鱼:必须的,今天分享一个,不用Jenkins,只用区区2段代码,就完成项目自动上传和部署。

小屌丝:鱼哥, v5 ~ ~


2、代码实战


在实际的工作中,遇到小屌丝的那种情况,也是很常见的。

发版的时候,需要部署到客户的服务器,但是,客户的服务器,对安装软件有着非常严格的要求,这个时候,

大部分的同学,都是手动打包,上传,部署。


为了解放同学的双手,小鱼,今天就来搞一个自动上传部署,而且还带监控的功能。



2.1 模块安装

我们需要依赖python的第三方库就是:watchdog


老规矩,pip 安装


pip install watchdog

其它安装方式,直接看这两篇:


《Python3,选择Python自动安装第三方库,从此跟pip说拜拜!!》

《Python3:我低调的只用一行代码,就导入Python所有库!》


2.2 实现思路


在撸码前, 常规操作是,思考+规划 = 实现思路:


创建监听器;

创建事件处理对象;

执行监听器,监听事件处理对象;

在服务器执行脚本;

有了明确的思路,我们就来事撸码。


2.3 代码示例


2.3.1 创建监听器

代码示例

# -*- coding:utf-8 -*-
# @Time   : 2022-09-09
# @Author : Carl_DJ
import os
from watchdog.observers import Observer
#创建一个监听器,用于监听文件夹目录
observer = Observer()
#创建2个事件处理对象
'分别用来监听 [/tmp]目录 、[/opt/project/projectName]目录'

2.3.2 创建事件处理对象

代码示例一:对/tmp文件进行监听


# -*- coding:utf-8 -*-
# @Time   : 2022-09-09
# @Author : Carl_DJ
from watchdog.events import *
import ntpath
import shutil
import zipfile
'''
实现功能:
 1、负责 监听 /tmp 目录,
 2、事件方法:新建&修改
 3、执行压缩文件移动
'''
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_tmp(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))

代码示例二:对//opt/project/projectName文件进行监听


# -*- coding:utf-8 -*-
# @Time   : 2022-09-09
# @Author : Carl_DJ
...
    def start_opt(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('压缩包出现问题,无法进行解压操作!')

2.3.3 启动事件监听

代码示例


# -*- coding:utf-8 -*-
# @Time   : 2022-09-09
# @Author : Carl_DJ
import time
if __name__ == "__main__":
    # 待监听的文件夹目录
    watch_folder = "/tmp/"
    # 项目目标文件夹目录
    target_folder = "/opt/project/projectName/"
    # 监听文件夹名称,即:项目压缩包名称
    watch_tags = ['project1.zip', 'project2.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()

2.4 启动运行


最后,我们就在目标服务器,启动运行脚本。


文件命名:


脚本文件:watchdog_folder.py

日志文件:watchdog_floder.log

nohup python3 -u watchdog_folder.py > watchdog_floder.log 2>&1 &

3、总结


看到这里,今天的分享差不多就结束了。

回顾一下,今天的的内容,大体思路:

先创建监听器→再创建事件处理对象→启动监听器,对事件进行监听处理→最后在服务器上启动命令执行。

版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

相关文章
Git:Python代码开发到服务器上测试实践
Git:Python代码开发到服务器上测试实践
0 0
热加载技术:修改Python代码并实时查看结果 ⛵
本文讲解Python热加载技术,以及Reloading工具库的使用。暂停运行的代码,修改补充后重新运行,意味着训练了数个小时的模型参数被舍弃。热加载技术可以解决这个问题。
0 0
在Pycharm上编写Airtest脚本的常见问题,希望你可以避开
在Pycharm上编写Airtest脚本的常见问题,希望你可以避开
0 0
SourceTree配置BeyondCompare代码冲突解决工具
SourceTree配置BeyondCompare代码冲突解决工具
0 0
安装上 Octotree 插件让你更加方便的阅读 gitHub 中的代码
安装上 Octotree 插件让你更加方便的阅读 gitHub 中的代码
0 0
导入别人的项目源码,如何才可以正常运行呢???
犹犹豫豫,不断有人问,开始写的时候是十月份,后来对某些只是为了应付大作业的人,我实在不想写,搁置两个月,今天有一个问的,一气之下,找到草稿,最后一次更新自己当初bug不断的图书管理系统。 1:本来不想写此篇博客的,但是之前上传一个关于图书管理系统的源码,好心网友下载了,然后直接说不好使,404,报错,等等问题,但是我想说,那也许是你对工具运用不够熟练,自己没有搞清楚一些问题,这里特别用一篇博客来证明我上传的源码,没有问题。
1121 0
jenkins中RobotFramework用例错误截图打不开解决方法
具体表现为:执行用例报错,打开open_log.html查看日志,发现错误截图显示未找到,如图: 解决方案 配置Robotframework插件必要设置即可解决 原因分析 测试用例日志是robot-plugin目录下面log.
1344 0
在项目中切换thinkphp框架的版本
学习使用thinkphp 的过程中,由于thinkphp不断的升级,有时在3.0上的代码就不一能在3.1.3上使用, 百思不得其解啊,没有办法还要工作啊,不知道怎么处理,先写吧, 将thinkphp3.0  3.1.2 3.1.3三个版本的核心放到项目目录,然后在index.php中修改成合适的版本 define('CORE', 'ThinkPHP2'); require(CORE
817 0
+关注
Carl_奕然
CSDN博客专家,51CTO博主专家,51认证讲师,资深测试开发专家,金牌面试官,职场面试培训及规划师。
文章
问答
文章排行榜
最热
最新
相关电子书
更多
Python第五讲——关于爬虫如何做js逆向的思路
立即下载
前端自动化测试
立即下载
低代码开发师(初级)实战教程
立即下载