千家信息网

Fabric中怎么批量管理远程服务器

发表于:2025-02-03 作者:千家信息网编辑
千家信息网最后更新 2025年02月03日,本篇文章为大家展示了Fabric中怎么批量管理远程服务器,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。Fabric 通过 Group 来组合多台服务器。区别在
千家信息网最后更新 2025年02月03日Fabric中怎么批量管理远程服务器

本篇文章为大家展示了Fabric中怎么批量管理远程服务器,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。

Fabric 通过 Group 来组合多台服务器。区别在于由 fabric.group.Group 基类(父类)派生出的两个子类:
  • SerialGroup(*hosts, **kwargs):按串行方式执行操作
  • ThreadingGroup(*hosts, **kwargs):按并发方式执行操作

下面先看看这个基类:

我把一些没用的信息折叠了,比较值得注意的内容有:
  • Group 继承了 list,所以能够 extend() ,对传入的服务器分别建立 connection
  • 核心的 run() 方法没有写实现,用意是留给子类再实现
  • 最后的 __enter__() 和 __exit__() 实现了上下文管理器

有了这个基类,接下来就要看 SerialGroup 和 ThreadingGroup 的具体实现了。

SerialGroup 类很简单,只实现了一个 run() 方法。因为类在初始化时为所有 host 建立了连接而且存了起来,所以这里只需用 for 循环依次取出,再执行 Connection 的 run() 方法。

这里可以看到一种非常实用的开发技巧:创建类时,让它继承内置的数据结构(如 list、dict), 这样可以直接使用 self.append()、self.extend()、self.update() 等方法把关键的信息存到"自身",再到取出时则"for xxx in self",这样就免了创建临时的 list 或 dict,也免得要在参数中传来传去。

GroupResult 和 GroupException 是对执行结果和异常的处理,不是我们关注的重点,这里略过。

接下来看看 ThreadingGroup,它也只有一个 run() 方法:

ExceptionHandlingThread 是一个继承了 threading.Thread 的类,这是一种创建多线程的方式。每个线程执行的方法主要做两件事:执行 connection 的 run() 方法,以及将执行成功的结果存入队列中。

接下来再分别把执行成功的结果与出异常的结果都存入到 results 中。

所以,Fabric 是使用了 threading 多线程的方式来实现并发。网络请求是 IO 密集型的,使用多线程是不错的方式。

至此,对于我们在开头提的问题,就有了一个初步的答案:Fabric 封装了两种 Group 来批量管理服务器,其中串行方式就是用了简单的 for 循环,而并发方式使用了 threading 多线程方式。

但是,通过分析这两种 Group 的实现代码(以及使用的实践),我们也可以发现 Fabric 的缺陷:
  • Group 只实现了 run() 方法,但是 Connection 的 put()、get()、sudo() 等方法都没有,这意味着用这种方式管理服务器集群时,只能在上面执行 shell 命令……
  • 每次调用 run() 方法时,它要等所有主机都执行完,才会返回结果,这意味着先执行完的主机会被阻塞。更为致命的是,如果其中一台主机执行时出了异常,整个 run() 方法就抛异常,这意味着每次使用 run() 方法时,都需要作异常捕获
  • run() 方法支持执行单条 shell 命令,但是命令的状态不会传递。假设先在一个 run() 方法中运行 cd 命令切到 A 目录(非根目录),再在下一个 run() 方法创建一个文件,最终结果是该文件并不在 A 目录,而是在默认目录。解决办法是用"&&"连接起多条命令,略显麻烦


上述内容就是Fabric中怎么批量管理远程服务器,你们学到知识或技能了吗?如果还想学到更多技能或者丰富自己的知识储备,欢迎关注行业资讯频道。

方法 方式 服务器 服务 结果 管理 命令 线程 接下来 主机 内容 意味 目录 成功 信息 子类 就是 技能 文件 知识 数据库的安全要保护哪些东西 数据库安全各自的含义是什么 生产安全数据库录入 数据库的安全性及管理 数据库安全策略包含哪些 海淀数据库安全审计系统 建立农村房屋安全信息数据库 易用的数据库客户端支持安全管理 连接数据库失败ssl安全错误 数据库的锁怎样保障安全 网络安全宣传周问答陕西 软件开发公司看聚顶科技在线 散热器和服务器有什么区别 范克瑞斯服务器晚上排队吗 班级网络安全宣传班会背景图 网络安全议论文200字 vs的数据库相关操作 上海配件管理软件开发 软件开发真的看天赋吗 单核云服务器打游戏 软件开发著作权备案证书 途尚网络技术 2021年校园网络安全 方舟生存进化主播一般玩的服务器 管理系统软件开发服务价格 长兴誉美网络技术服务工作室 公安网络安全训练考试 禅道设置数据库的端口号 虹口区专业软件开发联系方式 滁州市软件开发职位 网络安全论坛 推荐 清华同方的博硕士论文数据库官网 门户网络安全吗 互联网科技类作文素材 电信网络安全门户 max服务器管理 方舟生存进化主播一般玩的服务器 无锡商城软件开发外包公司哪个好 40个服务器安全加固小技巧 预知大学生网络安全竞赛
0