fabric 自动部署falsk 应用

2024-01-16 22:48

本文主要是介绍fabric 自动部署falsk 应用,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1.介绍

Fabric 是一个高级 Python (2.7,3.4 +)库,旨在通过 SSH 远程执行 shell 命令,从而产生有用的 Python 对象。 它构建在 Invoke (子流程命令执行和命令行特性)和 Paramiko (SSH 协议实现)之上,扩展它们的 api 以相互补充并提供额外的功能。

Fabric 最基本的用途是通过 SSH 在远程系统上执行 shell 命令,然后(可选)查询结果。 默认情况下,远程程序的输出直接打印到终端,并被捕获。 

2.安装

pip install fabric==1.14.0 (python2)
pip install fabric3 (python3)

3.简单示例:fabfile.py

#!/usr/bin/env python
# coding=utf-8
from fabric.api import *
from fabric.context_managers import *__author__ = 'jing'"""
一个自动部署样例,主要过程是
1.进入项目目录
2.拉取最新代码
3.杀掉对应端口的进程
4.启动服务
5.查看状态
"""# 项目配置,可以不参照我的
# 项目目录
PROJECT_PATH = '/data/project/my_project/'
# 项目名称,用于ps -ef时查询
PROJECT_NAME = "my_project"
# 端口
PROJECT_PORT = 5133
# git 分支,由于我配置了ssh 链接,所以可以直接拉取代码
GIT_BRANCH = 'master'# 服务器配置,名称可以随便取
# 用户名
USER = 'root'
# 外网ip
HOSTS = ['127.0.0.1']
# 密码
PASSWORD = 'pwd'# 重点配置
# fabric的上下文环境配置
env.user = USER
env.hosts = HOSTS
env.password = PASSWORD
# 可以把退出换为警告,以提供更灵活的错误处理。如果设置为False,则一条命令运行失败会就会退出,不再执行后面的命令。
env.warn_only = True
# 命令执行超时时间
env.command_timeout = 1800
# 连接超时时间
env.timeout = 3000
# 在连接到新服务器时,Fabric 尝试连接的次数。 由于向后兼容的原因,它默认只有一次连接尝试。
env.connection_attempts = 300def check_user():# 切换身份run("sudo -s ", pty=True)def pull():# 拉取最新代码run('git pull origin %s ' % GIT_BRANCH, pty=False)def kill_run_procedure():run("kill $(lsof -i:%s|awk '{if(NR==2)print $2}')" % PROJECT_PORT)def restart():# 这里有一个坑,执行source ../venv3/bin/activate命令 进入虚拟环境时会失败# 解决办法是写一个shell脚本,执行shell.脚本# restart.sh# `source /usr/local/pythonvenv/venv3/bin/activate# nohup python runserve.py &`sudo("sh restart.sh")def show_result():run('ps -ef|grep  %s' % PROJECT_NAME)def runserver():# 进入目录with cd(PROJECT_PATH):# 拉取代码pull()kill_run_procedure()  # 杀掉正在运行的程序# 重新启动restart()# 查看结果show_result()print('结束')

4.执行命令
在命令行里执行命令  fab -f [文件名] [方法名]

fab -f fabfile.py  runserver

 

这篇关于fabric 自动部署falsk 应用的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/614174

相关文章

Nginx分布式部署流程分析

《Nginx分布式部署流程分析》文章介绍Nginx在分布式部署中的反向代理和负载均衡作用,用于分发请求、减轻服务器压力及解决session共享问题,涵盖配置方法、策略及Java项目应用,并提及分布式事... 目录分布式部署NginxJava中的代理代理分为正向代理和反向代理正向代理反向代理Nginx应用场景

利用Python操作Word文档页码的实际应用

《利用Python操作Word文档页码的实际应用》在撰写长篇文档时,经常需要将文档分成多个节,每个节都需要单独的页码,下面:本文主要介绍利用Python操作Word文档页码的相关资料,文中通过代码... 目录需求:文档详情:要求:该程序的功能是:总结需求:一次性处理24个文档的页码。文档详情:1、每个

JAVA实现Token自动续期机制的示例代码

《JAVA实现Token自动续期机制的示例代码》本文主要介绍了JAVA实现Token自动续期机制的示例代码,通过动态调整会话生命周期平衡安全性与用户体验,解决固定有效期Token带来的风险与不便,感兴... 目录1. 固定有效期Token的内在局限性2. 自动续期机制:兼顾安全与体验的解决方案3. 总结PS

Java中的分布式系统开发基于 Zookeeper 与 Dubbo 的应用案例解析

《Java中的分布式系统开发基于Zookeeper与Dubbo的应用案例解析》本文将通过实际案例,带你走进基于Zookeeper与Dubbo的分布式系统开发,本文通过实例代码给大家介绍的非常详... 目录Java 中的分布式系统开发基于 Zookeeper 与 Dubbo 的应用案例一、分布式系统中的挑战二

Java 缓存框架 Caffeine 应用场景解析

《Java缓存框架Caffeine应用场景解析》文章介绍Caffeine作为高性能Java本地缓存框架,基于W-TinyLFU算法,支持异步加载、灵活过期策略、内存安全机制及统计监控,重点解析其... 目录一、Caffeine 简介1. 框架概述1.1 Caffeine的核心优势二、Caffeine 基础2

使用Node.js和PostgreSQL构建数据库应用

《使用Node.js和PostgreSQL构建数据库应用》PostgreSQL是一个功能强大的开源关系型数据库,而Node.js是构建高效网络应用的理想平台,结合这两个技术,我们可以创建出色的数据驱动... 目录初始化项目与安装依赖建立数据库连接执行CRUD操作查询数据插入数据更新数据删除数据完整示例与最佳

linux部署NFS和autofs自动挂载实现过程

《linux部署NFS和autofs自动挂载实现过程》文章介绍了NFS(网络文件系统)和Autofs的原理与配置,NFS通过RPC实现跨系统文件共享,需配置/etc/exports和nfs.conf,... 目录(一)NFS1. 什么是NFS2.NFS守护进程3.RPC服务4. 原理5. 部署5.1安装NF

通过Docker容器部署Python环境的全流程

《通过Docker容器部署Python环境的全流程》在现代化开发流程中,Docker因其轻量化、环境隔离和跨平台一致性的特性,已成为部署Python应用的标准工具,本文将详细演示如何通过Docker容... 目录引言一、docker与python的协同优势二、核心步骤详解三、进阶配置技巧四、生产环境最佳实践

Nginx部署HTTP/3的实现步骤

《Nginx部署HTTP/3的实现步骤》本文介绍了在Nginx中部署HTTP/3的详细步骤,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学... 目录前提条件第一步:安装必要的依赖库第二步:获取并构建 BoringSSL第三步:获取 Nginx

MyBatis Plus实现时间字段自动填充的完整方案

《MyBatisPlus实现时间字段自动填充的完整方案》在日常开发中,我们经常需要记录数据的创建时间和更新时间,传统的做法是在每次插入或更新操作时手动设置这些时间字段,这种方式不仅繁琐,还容易遗漏,... 目录前言解决目标技术栈实现步骤1. 实体类注解配置2. 创建元数据处理器3. 服务层代码优化填充机制详