测试你的 Puppet 配置清单
If all else fails, immortality can always be assured by spectacular error.
— J.K. Galbraith
你总会遭遇麻烦,就像趴在你的挡风玻璃上的一只虫子。遗憾的是像 Nagios 那样标准的检测监视工具也不能面面俱到地检测你要的一切。 许多技术指标对于排错是很有帮助的,例如平均负载和磁盘占用, 我更希望我的系统能提供关于应用和服务的更高级别的信息。
例如,如果你运行的是一个 web 应用程序,你不能肯定它正监听 80 端口并能返回 HTTP 200 OK 状态。也许它只是返回 Apache 默认的欢迎页面。
如果你的 web 应用程序是一个在线商店,例如:你可能希望检查以下几项:
大家能否看到预期的页面(例如:“欢迎光临 FooStore”)?
用户能否正常登录(假定应用程序支持 session 会话)?
搜索某种产品能否返回期待的结果?
响应时间是否令人满意?
这种监控(专注于应用程序的行为,而不是对服务器自身指标的度量) 经常被称作 行为驱动的监控(behavior-driven monitoring)。
与开发者改变代码后经常使用行为驱动的测试(behavior-driven tests) 来校验应用程序是否正常一样, 你可以在产品上线后持续地使用行为驱动的监控。
事实上,感谢有 cucumber-nagios 这样的工具存在,你可以和开发人员使用同样的测试。 Lindsay Holmwood 为流行的 Cucumber 测试框架所做的封装可以让你运行针对 Nagios 的基于 Cucumber 的测试,这似乎是对 Nagios 进行评估的标准方法。
准备工作
为了安装 cucumber-nagios ,你首先要安装依赖的包。如果你在用 Ubuntu 或 Debian, 可能需要从源代码安装 RubyGems ,因为 cucumber-nagios 需要 RubyGems 1.3.6 或更高的版本。 从 RubyGems 站点: http://rubygems.org/pages/download 下载 tarball 。 解压缩之后运行 ruby setup.rb 编译并安装此软件包。
接下来,你需要安装相关依赖包:
# apt-get install ruby1.8-dev libxml2-dev
最后,使用如下命令安装 cucumber-nagios :
# gem install cucumber-nagios
操作步骤
一旦 RubyGems 和相关依赖安装完成后,你就可以开始写 Cucumber 测试了。 要做到这一点,首先使用 cucumer-nagios-gen 来帮助我们创建一个项目目录和所需要的一切:
# cucumber-nagios-gen project mytest Generating with project generator: [ADDED] features/steps [ADDED] features/support [ADDED] .gitignore [ADDED] .bzrignore [ADDED] lib/generators/feature/%feature_name%.feature [ADDED] Gemfile [ADDED] bin/cucumber-nagios [ADDED] lib/generators/feature/%feature_name%_steps.rb [ADDED] README
你新创建的 cucumber-nagios 项目可以在 /root/mytest 找到。
下一步, 使用如下命令安装所需的 RubyGems:
bundle install
你的项目已经作为一个 git 仓库初始化了。
有一个好主意是在项目目录里运行 bundle install ,因为 cucumber-nagios 建议你这么做。这样做的话 cucumber-nagios 会在项目目录里安装所有依赖的包。 然后你就可以移动项目目录到其他任何一台机器,不必再安装依赖包就可以工作。
# cd mytest # bundle install
现在我们开始写测试。下面的例子用于测试 Google 的主页:
# cucumber-nagios-gen feature www.google.com home Generating with feature generator: [ADDED] features/www.google.com/home.feature [ADDED] features/www.google.com/steps/home_steps.rb
如果你要编辑 home.feature 文件, 会发现 cucumber-nagios 已经为你生成了一个基本的测试:
Feature: www.google.com It should be up Scenario: Visiting home page When I go to "http://www.google.com" Then the request should succeed
你可以在项目下使用如下命令运行这个测试:
# cucumber --require features features/www.google.com/home.feature Feature: www.google.com It should be up Scenario: Visiting home page # features/www.google. com/home.feature:4 When I go to "http://www.google.com" # features/steps/http_ steps.rb:11 Then the request should succeed # features/steps/http_ steps.rb:64 1 scenario (1 passed) 2 steps (2 passed) 0m0.176s
假设一切正常(若不正常,请联系 Google), 要对 Nagios 的检测使用此特性, 你要做的所有工作就是使用 cucumber-nagios 代替 cucumber :
# bin/cucumber-nagios features/www.google.com/home.feature CUCUMBER OK - Critical: 0, Warning: 0, 2 okay | passed=2; failed=0; nosteps=0; total=2; time=0
工作原理
任何脚本都可以成为 Nagios 监控的一个插件; 它只是返回执行完成后退出的状态 (0 为成功,1 为警告,2 为紧急)。cucumber-nagios 封装 Cucumber 来实现测试, 并且打印出有用信息,而后 Nagios 将通过警告或者 web 接口发送报告。
更多用法
就其本身而言,并非你在此做的所有工作都有用。但不管怎样,Cucumber 可以让你写出十分复杂的 Web 交互脚本: 你可以填写表单字段、搜索、 单击按扭、在页面上匹配文本等等。要监控你的 web 应用或服务的任何特性, 首先弄清楚用户使用 web 浏览器的行为习惯,然后根据这些用户行为, 使用 Cucumber 创建自动监控脚本。
你可以从 Cucumber 网站 http://cukes.info/ 上找到更多关于 cucumber-nagios 的信息。