Deploy Springboot With Python

本贴最后更新于 1780 天前,其中的信息可能已经时移世易

python 自动全量,增量部署脚本
运行在 python3+ 下 命令 python3 deploy.py app springboot
----------------> app (应用部署目录) springboot (应用 zip 包名称)
必须在用户目录下新建 Releases 目录,把此脚本放到下面命名为 deploy.py
项目目录 ~/app/application/ 其中 app 要先自己手动创建
自用 仅做参考 可以结合 http://www.liumj.cn/articles/2019/04/20/1555736649588.html

# Program: springboot项目部署
import datetime
import os
import re
import shutil
import stat
import sys
import tarfile
import zipfile

# Home目录
HomePath = os.path.expanduser('~')

#config 可配置项
# 我自己的环境  其他环境去掉下面这句
# HomePath = HomePath + "/PycharmProjects/insteadShell"
# 是否备份
isbackUp = False
# 增量部署默认只会覆盖jar/war/lib下的包,需要强制覆盖的配置需要额外添加
# 强制需要覆盖的文件 例子:force_instead_file= ["data"] 
force_instead_file= []





backUpDirName = '/backup'
allFileToDeploy = []
dirName = ''
dirPath = ''
HomePath = HomePath + "/"
ReleasePath = os.path.expanduser(HomePath + 'Releases/')


# 移动文件
def movefile(srcfile, dstfile):
    fpath, fname = os.path.split(dstfile)  # 分离文件名和路径
    if not os.path.exists(fpath):
        os.makedirs(fpath)  # 创建路径
    shutil.move(srcfile, dstfile)  # 移动文件

# 备份
def makeBakDir(application_path):
    if not os.path.exists(application_path + backUpDirName):
        os.makedirs(application_path + backUpDirName)
    return application_path + backUpDirName

# tar 打包
def tar(fname, fpath):
    t = tarfile.open(fname + ".tar", "w")
    for root, dir, files in os.walk(fpath):
        for file in files:
            fullpath = os.path.join(root, file)
            if backUpDirName not in fullpath and "/log/" not in fullpath and "/logs/" not in fullpath and "/nohup.out" not in fullpath:
                t.add(fullpath)
    t.close()

# unzip 解压zip包
def un_zip(zipFileName, target):
    f = zipfile.ZipFile(ReleasePath + zipFileName + ".zip", 'r')
    for file in f.namelist():
        f.extract(file, target)
    f.close()

def exit(errorMsg):
    print(errorMsg)
    sys.exit(1)


#### 获取所有需要部署的项目添加到变量 allFileToDeploy
def allFileToDeployM():
    global allFileToDeploy
    global dirName
    global dirPath
    # 所有在Release目录下的zip文件
    allfiles = os.listdir(ReleasePath)
    allZipFiles = [re.sub(r".zip", "", f) for f in allfiles if re.search('.zip$', f)]
    if len(sys.argv) <= 1:
        exit("参数错误 无法部署")

    # 全部署  python3 deploy.py
    if len(sys.argv) == 2:
        if not os.path.isdir(HomePath + sys.argv[1]):
            exit("请输入正确的应用部署目录")
        dirName = sys.argv[1]
        dirPath = HomePath + sys.argv[1]
        allFileToDeploy = allZipFiles
        # asw = input('是否在目录:%s 部署所有应用(y:n)\n'%(dirName))
        # if (asw != 'y'):
        #     exit("停止部署")

    # 部署目录和项目 python3 deploy.py app id-center
    if len(sys.argv) >= 3:
        if not os.path.isdir(HomePath + sys.argv[1]):
            exit("请输入正确的应用部署目录")
        else:
            dirName = sys.argv[1]
            dirPath = HomePath + sys.argv[1]
            for i in range(len(sys.argv)):
                if (i >= 2):
                    if sys.argv[i] in allZipFiles:
                        allFileToDeploy.append(sys.argv[i])
                    else:
                        print("不存在应用:" + sys.argv[i] + ".zip")

    print("所有即将部署的应用:", allFileToDeploy)
    if len(allFileToDeploy) == 0:
        exit("没有需要部署的项目")
    # asw = input("是否开始部署(y:n)\n")
    # if asw == 'y':
    #     print("开始部署")
    # else:
    #     exit("停止部署")


# 开始部署 备份
def deployApplication():
    for application in allFileToDeploy:
        print("开始部署目录:", dirName, "下的:", application, "项目")
        # 全量部署
        dir_path = HomePath + dirName + '/'
        application_path = dir_path + application
        if not os.path.isdir(application_path):
            un_zip(application, dir_path)
            os.chdir(application_path)
            os.chmod(application_path + "/start.sh", stat.S_IRWXU)
            os.system(application_path + "/start.sh > nohup.out 2>&1 &")
        else:
            # 开始备份
            os.chdir(application_path)
            os.chmod(application_path + "/stop.sh", stat.S_IRWXU)
            os.system(application_path + "/stop.sh")
            os.chdir(makeBakDir(application_path))
            if isbackUp:
                otherStyleTime = datetime.datetime.now().strftime("%Y%m%d%H%M%S")
                tar(application + otherStyleTime, application_path)
            # 增量部署
            un_zip(application, HomePath + 'Releases/')
            application_release_path = HomePath + 'Releases/' + application + '/'
            if os.path.isfile(application_release_path + application + '.war'):
                if os.path.isfile(application_path + application + '.war'):
                    os.remove(application_path + "/" + application + ".war")
                shutil.copy(application_release_path + application + '.war',
                            application_path + "/" + application + ".war")
            else:
                if os.path.isfile(application_path + application + '.jar'):
                    os.remove(application_path + "/" + application + ".jar")
                shutil.copy(application_release_path + application + '.jar',
                            application_path + "/" + application + ".jar")
                if os.path.isdir(application_path + "/lib"):
                    shutil.rmtree(application_path + "/lib", True)
                shutil.copytree(application_release_path + '/lib', application_path + "/lib")
                # 补充剩余空缺文件
            listdir = os.listdir(application_path)
            re_listdir = os.listdir(application_release_path)
            for x in re_listdir:
                if x not in listdir or x in force_instead_file:
                    if os.path.isdir(application_release_path + x):
                        if os.path.isdir(application_path + "/" + x):
                            shutil.rmtree(application_path + "/" + x)
                        shutil.copytree(application_release_path + '/' + x, application_path + "/" + x)
                    else:
                        shutil.copy(application_release_path + '/' + x, application_path + "/" + x)
            if os.path.isfile(application_path + "/start.sh"):
                os.chdir(application_path)
                os.chmod(application_path + "/start.sh", stat.S_IRWXU)
                os.system(application_path + "/start.sh > nohup.out 2>&1 &")


def main():
    allFileToDeployM()
    deployApplication()
    print("部署成功")


if __name__ == '__main__':
    main()

  • Python

    Python 是一种面向对象、直译式电脑编程语言,具有近二十年的发展历史,成熟且稳定。它包含了一组完善而且容易理解的标准库,能够轻松完成很多常见的任务。它的语法简捷和清晰,尽量使用无异义的英语单词,与其它大多数程序设计语言使用大括号不一样,它使用缩进来定义语句块。

    535 引用 • 672 回帖 • 1 关注
  • 部署
    21 引用 • 280 回帖

相关帖子

欢迎来到这里!

我们正在构建一个小众社区,大家在这里相互信任,以平等 • 自由 • 奔放的价值观进行分享交流。最终,希望大家能够找到与自己志同道合的伙伴,共同成长。

注册 关于
请输入回帖内容 ...

推荐标签 标签

  • jsoup

    jsoup 是一款 Java 的 HTML 解析器,可直接解析某个 URL 地址、HTML 文本内容。它提供了一套非常省力的 API,可通过 DOM,CSS 以及类似于 jQuery 的操作方法来取出和操作数据。

    6 引用 • 1 回帖 • 459 关注
  • TensorFlow

    TensorFlow 是一个采用数据流图(data flow graphs),用于数值计算的开源软件库。节点(Nodes)在图中表示数学操作,图中的线(edges)则表示在节点间相互联系的多维数据数组,即张量(tensor)。

    20 引用 • 19 回帖 • 1 关注
  • 程序员

    程序员是从事程序开发、程序维护的专业人员。

    531 引用 • 3528 回帖
  • Vditor

    Vditor 是一款浏览器端的 Markdown 编辑器,支持所见即所得、即时渲染(类似 Typora)和分屏预览模式。它使用 TypeScript 实现,支持原生 JavaScript、Vue、React 和 Angular。

    311 引用 • 1666 回帖
  • 禅道

    禅道是一款国产的开源项目管理软件,她的核心管理思想基于敏捷方法 scrum,内置了产品管理和项目管理,同时又根据国内研发现状补充了测试管理、计划管理、发布管理、文档管理、事务管理等功能,在一个软件中就可以将软件研发中的需求、任务、bug、用例、计划、发布等要素有序的跟踪管理起来,完整地覆盖了项目管理的核心流程。

    5 引用 • 15 回帖 • 221 关注
  • ReactiveX

    ReactiveX 是一个专注于异步编程与控制可观察数据(或者事件)流的 API。它组合了观察者模式,迭代器模式和函数式编程的优秀思想。

    1 引用 • 2 回帖 • 126 关注
  • Scala

    Scala 是一门多范式的编程语言,集成面向对象编程和函数式编程的各种特性。

    13 引用 • 11 回帖 • 106 关注
  • MongoDB

    MongoDB(来自于英文单词“Humongous”,中文含义为“庞大”)是一个基于分布式文件存储的数据库,由 C++ 语言编写。旨在为应用提供可扩展的高性能数据存储解决方案。MongoDB 是一个介于关系数据库和非关系数据库之间的产品,是非关系数据库当中功能最丰富,最像关系数据库的。它支持的数据结构非常松散,是类似 JSON 的 BSON 格式,因此可以存储比较复杂的数据类型。

    90 引用 • 59 回帖 • 3 关注
  • 生活

    生活是指人类生存过程中的各项活动的总和,范畴较广,一般指为幸福的意义而存在。生活实际上是对人生的一种诠释。生活包括人类在社会中与自己息息相关的日常活动和心理影射。

    228 引用 • 1450 回帖
  • 书籍

    宋真宗赵恒曾经说过:“书中自有黄金屋,书中自有颜如玉。”

    76 引用 • 390 回帖
  • 设计模式

    设计模式(Design pattern)代表了最佳的实践,通常被有经验的面向对象的软件开发人员所采用。设计模式是软件开发人员在软件开发过程中面临的一般问题的解决方案。这些解决方案是众多软件开发人员经过相当长的一段时间的试验和错误总结出来的。

    198 引用 • 120 回帖
  • Python

    Python 是一种面向对象、直译式电脑编程语言,具有近二十年的发展历史,成熟且稳定。它包含了一组完善而且容易理解的标准库,能够轻松完成很多常见的任务。它的语法简捷和清晰,尽量使用无异义的英语单词,与其它大多数程序设计语言使用大括号不一样,它使用缩进来定义语句块。

    535 引用 • 672 回帖 • 1 关注
  • Hprose

    Hprose 是一款先进的轻量级、跨语言、跨平台、无侵入式、高性能动态远程对象调用引擎库。它不仅简单易用,而且功能强大。你无需专门学习,只需看上几眼,就能用它轻松构建分布式应用系统。

    9 引用 • 17 回帖 • 597 关注
  • RYMCU

    RYMCU 致力于打造一个即严谨又活泼、专业又不失有趣,为数百万人服务的开源嵌入式知识学习交流平台。

    4 引用 • 6 回帖 • 38 关注
  • 链滴

    链滴是一个记录生活的地方。

    记录生活,连接点滴

    131 引用 • 3639 回帖
  • Linux

    Linux 是一套免费使用和自由传播的类 Unix 操作系统,是一个基于 POSIX 和 Unix 的多用户、多任务、支持多线程和多 CPU 的操作系统。它能运行主要的 Unix 工具软件、应用程序和网络协议,并支持 32 位和 64 位硬件。Linux 继承了 Unix 以网络为核心的设计思想,是一个性能稳定的多用户网络操作系统。

    915 引用 • 931 回帖
  • 学习

    “梦想从学习开始,事业从实践起步” —— 习近平

    161 引用 • 473 回帖
  • wolai

    我来 wolai:不仅仅是未来的云端笔记!

    1 引用 • 11 回帖
  • Markdown

    Markdown 是一种轻量级标记语言,用户可使用纯文本编辑器来排版文档,最终通过 Markdown 引擎将文档转换为所需格式(比如 HTML、PDF 等)。

    163 引用 • 1450 回帖 • 1 关注
  • 导航

    各种网址链接、内容导航。

    37 引用 • 168 回帖
  • JSON

    JSON (JavaScript Object Notation)是一种轻量级的数据交换格式。易于人类阅读和编写。同时也易于机器解析和生成。

    51 引用 • 190 回帖
  • 互联网

    互联网(Internet),又称网际网络,或音译因特网、英特网。互联网始于 1969 年美国的阿帕网,是网络与网络之间所串连成的庞大网络,这些网络以一组通用的协议相连,形成逻辑上的单一巨大国际网络。

    96 引用 • 330 回帖
  • 开源

    Open Source, Open Mind, Open Sight, Open Future!

    395 引用 • 3408 回帖 • 1 关注
  • 分享

    有什么新发现就分享给大家吧!

    242 引用 • 1746 回帖 • 2 关注
  • 自由行
  • Hexo

    Hexo 是一款快速、简洁且高效的博客框架,使用 Node.js 编写。

    21 引用 • 140 回帖 • 25 关注
  • 小薇

    小薇是一个用 Java 写的 QQ 聊天机器人 Web 服务,可以用于社群互动。

    由于 Smart QQ 从 2019 年 1 月 1 日起停止服务,所以该项目也已经停止维护了!

    34 引用 • 467 回帖 • 692 关注