首页
/ Fabric项目中的Python Fabfile配置与命令示例

Fabric项目中的Python Fabfile配置与命令示例

2025-05-15 16:12:39作者:董灵辛Dennis

Fabric是一个流行的Python库,用于简化SSH操作和系统管理任务的自动化。本文将介绍几个实用的Fabric配置和命令示例,帮助开发者更好地利用这个工具进行服务器管理。

基础环境配置

在使用Fabric前,需要先建立与服务器的连接。以下是一个基础连接配置示例:

from invoke import run
from fabric import Connection
from credentials import Servers  # 自定义的服务器凭证模块

# 获取本地IP地址
ip_address = run(
    command="ip -br a show | grep UP | awk '{print $3}'",
    hide=True
).stdout.split('/')[0]

# 建立Nginx服务器连接
server_nginx = Connection(
    Servers.nginx,
    user='root'
)

服务器日志分析

通过Fabric可以方便地分析服务器日志:

# 查询特定IP地址的Nginx访问记录
server_nginx.run(
    command=f'cat /var/log/nginx/access.log | grep {ip_address}'
)

# 获取所有唯一的访问IP地址
list_address = server_nginx.run(
    command="cat /var/log/nginx/access.log | awk '{print $1}' | sort -u",
    hide=True
).stdout.split("\n")
print(list_address)

Docker容器管理

Fabric特别适合用于Docker环境的管理和维护:

清理无用Docker资源

apps_server = Connection(
    Servers.xxx,
    user='root'
)

# 清理无用的Docker镜像和卷
apps_server.run('docker system prune --all --volumes --force')

# 清空特定日志文件
apps_server.run('truncate -s 0 /var/lib/docker/aufs/diff/*/usr/local/tomcat/logs/*.log')
apps_server.run('truncate -s 0 /var/lib/docker/containers/*/*-json.log')

# 检查磁盘空间
apps_server.run('df -h | grep /dev/sda1')

容器更新操作

# 定义需要操作的容器名称
names = ' '.join(['names_xxx', 'names_yyy'])

# 停止容器、清理资源并重新启动
apps_server.run(f'docker-compose stop {names}')
apps_server.run('docker system prune --all --volumes --force')
apps_server.run(f'docker-compose up -d --no-deps {names}')

下载容器日志

name = 'xxx'

# 获取容器ID
container_id = apps_server.run(
    f'docker ps --quiet --filter="name=root_{name}_1"'
).stdout.split("\n")[0]

# 定位日志文件路径
dir = apps_server.run(
    f'cd /var/lib/docker/containers/{container_id}*/ && pwd'
).stdout.split("\n")[0]

log = apps_server.run(
    f'ls /var/lib/docker/containers/{container_id}*/ | grep log'
).stdout.split("\n")[0]

# 下载日志到本地
apps_server.get(f'{dir}/{log}')

最佳实践建议

  1. 安全性:建议使用SSH密钥认证而非密码,并在Connection配置中设置合理的超时时间。

  2. 错误处理:为run()命令添加适当的错误处理逻辑,考虑使用warn=True参数使命令失败时不抛出异常。

  3. 性能优化:对于频繁执行的命令,可以考虑使用Connection的sudo()方法替代run()以获得更高权限。

  4. 日志记录:重要的操作应该记录执行结果,便于后续审计和问题排查。

通过这些示例,开发者可以快速上手Fabric,实现服务器管理的自动化。Fabric的强大之处在于它将复杂的SSH操作封装成了简单的Python方法调用,大大提高了运维效率。

登录后查看全文
热门项目推荐
相关项目推荐

项目优选

收起
kernelkernel
deepin linux kernel
C
22
6
docsdocs
OpenHarmony documentation | OpenHarmony开发者文档
Dockerfile
203
2.18 K
ohos_react_nativeohos_react_native
React Native鸿蒙化仓库
C++
208
285
pytorchpytorch
Ascend Extension for PyTorch
Python
62
94
RuoYi-Vue3RuoYi-Vue3
🎉 (RuoYi)官方仓库 基于SpringBoot,Spring Security,JWT,Vue3 & Vite、Element Plus 的前后端分离权限管理系统
Vue
977
575
nop-entropynop-entropy
Nop Platform 2.0是基于可逆计算理论实现的采用面向语言编程范式的新一代低代码开发平台,包含基于全新原理从零开始研发的GraphQL引擎、ORM引擎、工作流引擎、报表引擎、规则引擎、批处理引引擎等完整设计。nop-entropy是它的后端部分,采用java语言实现,可选择集成Spring框架或者Quarkus框架。中小企业可以免费商用
Java
9
1
ops-mathops-math
本项目是CANN提供的数学类基础计算算子库,实现网络在NPU上加速计算。
C++
550
84
openHiTLSopenHiTLS
旨在打造算法先进、性能卓越、高效敏捷、安全可靠的密码套件,通过轻量级、可剪裁的软件技术架构满足各行业不同场景的多样化要求,让密码技术应用更简单,同时探索后量子等先进算法创新实践,构建密码前沿技术底座!
C
1.02 K
399
communitycommunity
本项目是CANN开源社区的核心管理仓库,包含社区的治理章程、治理组织、通用操作指引及流程规范等基础信息
393
27
MateChatMateChat
前端智能化场景解决方案UI库,轻松构建你的AI应用,我们将持续完善更新,欢迎你的使用与建议。 官网地址:https://matechat.gitcode.com
1.2 K
133