2

我们最近将 OpsGenie 处理程序 ( opsgenie.rb) 更新为当前社区版本,可在此处找到。

我们的处理程序定义为:

"opsgenie-pager" : {
  "type": "pipe",
  "command": "/etc/sensu/handlers/opsgenie.rb -j opsgenie-pager"
}

我们的 json 配置opsgenie-pager是:

{
  "opsgenie-pager": {
  "customerKey": "<Our API Key>",
  "recipients": "<Our Schedule>,<Our Escalation>",
  "source": "Admiral Ackbar",
  "overwrite_quiet_hours": false,
  "tags": [ "admAckbar", "live", "pager" ]
  }
}

当检查返回为“CRITICAL”并opsgenie调用处理程序时,sensu-server.log 报告:

{"timestamp":"2015-02-03T06:16:17.804061-0700","level":"info","message":"handler output","handler":{"type":"pipe","command":"/etc/sensu/handlers/opsgenie.rb -j opsgenie-pager","name":"opsgenie-pager"},"output":"/etc/sensu/handlers/opsgenie.rb:15:in `<class:Opsgenie>': undefined method `option' for Opsgenie:Class (NoMethodError)\n"}
{"timestamp":"2015-02-03T06:16:17.804210-0700","level":"info","message":"handler output","handler":{"type":"pipe","command":"/etc/sensu/handlers/opsgenie.rb -j opsgenie-pager","name":"opsgenie-pager"},"output":"\tfrom /etc/sensu/handlers/opsgenie.rb:13:in `<main>'\n"}

在我们的“开发实例”(vagrant box)中,我们能够成功地使用 OpsGenie 处理程序来创建警报。

有什么想法会导致undefined method 'option' for Opsgenie:Class (NoMethodError)错误吗?

4

1 回答 1

2

看起来这是一个过时的宝石的结果。

我偶然检查了我们的“开发实例”和“生产”之间已安装的软件包(rpms 和 gems)。

我们开发实例中的sensu-pluigngem(在 a 期间安装vagrant up)是当前版本(1.1.0),而在生产中安装的版本是旧版本(0.6.3)。

更新这个宝石

gem update sensu-plugin

解决了这个问题!

于 2015-02-03T17:45:25.257 回答