使用Testinfra和Ansible验证服务器状态

运维 系统运维
Testinfra 是一个功能强大的库,可用于编写测试来验证基础设施的状态。另外它与 Ansible 和 Nagios 相结合,提供了一个用于架构即代码 (IaC) 的简单解决方案。

[[267332]]

Testinfra 是一个功能强大的库,可用于编写测试来验证基础设施的状态。另外它与 Ansible 和 Nagios 相结合,提供了一个用于架构即代码 (IaC) 的简单解决方案。

根据设计,Ansible 传递机器的期望状态,以确保 Ansible 剧本或角色的内容部署到目标机器上。但是,如果你需要确保所有基础架构更改都在 Ansible 中,该怎么办?或者想随时验证服务器的状态?

Testinfra 是一个基础架构测试框架,它可以轻松编写单元测试来验证服务器的状态。它是一个 Python 库,使用强大的 pytest 测试引擎。

开始使用 Testinfra

可以使用 Python 包管理器(pip)和 Python 虚拟环境轻松安装 Testinfra。

  1. $ python3 -m venv venv
  2. $ source venv/bin/activate
  3. (venv) $ pip install testinfra

Testinfra 也可以通过 Fedora 和 CentOS 的 EPEL 仓库中使用。例如,在 CentOS 7 上,你可以使用以下命令安装它:

  1. $ yum install -y epel-release
  2. $ yum install -y python-testinfra

一个简单的测试脚本

在 Testinfra 中编写测试很容易。使用你选择的代码编辑器,将以下内容添加到名为 test_simple.py 的文件中:

  1. import testinfra
  2.  
  3. def test_os_release(host):
  4. assert host.file("/etc/os-release").contains("Fedora")
  5.  
  6. def test_sshd_inactive(host):
  7. assert host.service("sshd").is_running is False

默认情况下,Testinfra 为测试用例提供了一个 host 对象,该对象能访问不同的辅助模块。例如,***个测试使用 file 模块来验证主机上文件的内容,第二个测试用例使用 service 模块来检查 systemd 服务的状态。

要在本机运行这些测试,请执行以下命令:

  1. (venv)$ pytest test_simple.py
  2. ================================ test session starts ================================
  3. platform linux -- Python 3.7.3, pytest-4.4.1, py-1.8.0, pluggy-0.9.0
  4. rootdir: /home/cverna/Documents/Python/testinfra
  5. plugins: testinfra-3.0.0
  6. collected 2 items
  7. test_simple.py ..
  8.  
  9. ================================ 2 passed in 0.05 seconds ================================

有关 Testinfra API 的完整列表,你可以参考文档

Testinfra 和 Ansible

Testinfra 支持的后端之一是 Ansible,这意味着 Testinfra 可以直接使用 Ansible 的清单文件和清单中定义的一组机器来对它们进行测试。

我们使用以下清单文件作为示例:

  1. [web]
  2. app-frontend01
  3. app-frontend02
  4.  
  5. [database]
  6. db-backend01

我们希望确保我们的 Apache Web 服务器在 app-frontend01app-frontend02 上运行。让我们在名为 test_web.py 的文件中编写测试:

  1. def check_httpd_service(host):
  2. """Check that the httpd service is running on the host"""
  3. assert host.service("httpd").is_running

要使用 Testinfra 和 Ansible 运行此测试,请使用以下命令:

  1. (venv) $ pip install ansible
  2. (venv) $ py.test --hosts=web --ansible-inventory=inventory --connection=ansible test_web.py

在调用测试时,我们使用 Ansible 清单文件的 [web] 组作为目标计算机,并指定我们要使用 Ansible 作为连接后端。

使用 Ansible 模块

Testinfra 还为 Ansible 提供了一个很好的可用于测试的 API。该 Ansible 模块能够在测试中运行 Ansible 动作,并且能够轻松检查动作的状态。

  1. def check_ansible_play(host):
  2. """
  3. Verify that a package is installed using Ansible
  4. package module
  5. """
  6. assert not host.ansible("package", "name=httpd state=present")["changed"]

默认情况下,Ansible 的检查模式已启用,这意味着 Ansible 将报告在远程主机上执行动作时会发生的变化。

Testinfra 和 Nagios

现在我们可以轻松地运行测试来验证机器的状态,我们可以使用这些测试来触发监控系统上的警报。这是捕获意外的更改的好方法。

Testinfra 提供了与 Nagios 的集成,它是一种流行的监控解决方案。默认情况下,Nagios 使用 NRPE 插件对远程主机进行检查,但使用 Testinfra 可以直接从 Nagios 主控节点上运行测试。

要使 Testinfra 输出与 Nagios 兼容,我们必须在触发测试时使用 --nagios 标志。我们还使用 -qq 这个 pytest 标志来启用 pytest 的静默模式,这样就不会显示所有测试细节。

  1. (venv) $ py.test --hosts=web --ansible-inventory=inventory --connection=ansible --nagios -qq line test.py
  2. TESTINFRA OK - 1 passed, 0 failed, 0 skipped in 2.55 seconds

Testinfra 是一个功能强大的库,可用于编写测试以验证基础架构的状态。 另外与 Ansible 和 Nagios 相结合,提供了一个用于架构即代码 (IaC) 的简单解决方案。 它也是使用 Molecule 开发 Ansible 角色过程中添加测试的关键组件。 

责任编辑:庞桂玉 来源: Linux中国
相关推荐

2010-07-20 10:43:34

Telnet服务器

2010-05-19 15:00:37

IIS服务器

2012-02-13 23:46:22

keepalived高可用

2009-12-29 11:03:28

VPN服务器故障

2011-07-08 09:01:37

服务器网络验证工具

2020-06-07 11:54:34

Linux服务器命令

2019-06-13 17:15:30

监控Linux服务器

2018-01-19 10:30:48

HTTP服务器代码

2010-07-27 13:53:23

NFS服务器

2010-08-26 22:07:38

DHCP服务器

2010-07-19 17:30:47

2011-03-24 10:59:10

Nagios监控mysql

2010-07-27 10:28:44

2010-05-17 16:50:38

IIS服务器

2022-03-14 15:10:20

云服务器物理服务器性能

2010-05-21 11:50:54

IIS服务器

2019-02-26 16:20:52

FTP服务器

2018-06-15 16:05:06

服务器无密码验证登录安全

2009-09-17 18:05:51

Nis服务器

2014-03-10 09:57:55

实时监测邮件监控
点赞
收藏

51CTO技术栈公众号