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

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

2025-05-15 21:29:20作者:董灵辛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方法调用,大大提高了运维效率。

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

热门内容推荐

最新内容推荐

项目优选

收起
ohos_react_nativeohos_react_native
React Native鸿蒙化仓库
C++
178
262
RuoYi-Vue3RuoYi-Vue3
🎉 (RuoYi)官方仓库 基于SpringBoot,Spring Security,JWT,Vue3 & Vite、Element Plus 的前后端分离权限管理系统
Vue
867
513
openGauss-serveropenGauss-server
openGauss kernel ~ openGauss is an open source relational database management system
C++
129
183
openHiTLSopenHiTLS
旨在打造算法先进、性能卓越、高效敏捷、安全可靠的密码套件,通过轻量级、可剪裁的软件技术架构满足各行业不同场景的多样化要求,让密码技术应用更简单,同时探索后量子等先进算法创新实践,构建密码前沿技术底座!
C
265
305
HarmonyOS-ExamplesHarmonyOS-Examples
本仓将收集和展示仓颉鸿蒙应用示例代码,欢迎大家投稿,在仓颉鸿蒙社区展现你的妙趣设计!
Cangjie
398
371
CangjieCommunityCangjieCommunity
为仓颉编程语言开发者打造活跃、开放、高质量的社区环境
Markdown
1.07 K
0
ShopXO开源商城ShopXO开源商城
🔥🔥🔥ShopXO企业级免费开源商城系统,可视化DIY拖拽装修、包含PC、H5、多端小程序(微信+支付宝+百度+头条&抖音+QQ+快手)、APP、多仓库、多商户、多门店、IM客服、进销存,遵循MIT开源协议发布、基于ThinkPHP8框架研发
JavaScript
93
15
note-gennote-gen
一款跨平台的 Markdown AI 笔记软件,致力于使用 AI 建立记录和写作的桥梁。
TSX
83
4
cherry-studiocherry-studio
🍒 Cherry Studio 是一款支持多个 LLM 提供商的桌面客户端
TypeScript
598
57
GitNextGitNext
基于可以运行在OpenHarmony的git,提供git客户端操作能力
ArkTS
10
3