Splunk On-CallのPRTGインテグレーション 🔗
PRTG Network Monitorは、サーバーインフラストラクチャのための、サーバーのアップタイムと利用率、ネットワーク監視、帯域幅利用ソフトウェアパッケージです。SNMP、パケットスニッフィング、Netflowを使用して、ネットワーク内の帯域幅の使用状況を監視し、分類することができます。次のガイドでは、このインテグレーションのインストールと設定について説明します。
In Splunk On-Call 🔗
Splunk On-Call Webポータルから、Integrations を選択します。
インテグレーションオプションのリストから、PRTG (webhook) インテグレーションオプションを選択します。
結果のページで、Service API Endpoint をクリップボードにコピーします。このエンドポイントの」$routing_key」の部分は、必ず使用する実際のルーティングキーに置き換えてください。
In PRTG Network Monitor 🔗
サーバーで、C:\Program Files (x86)\PRTG Network Monitor\Notifications\EXE
に移動し、prtgtovictorops.ps1 という名前のファイルを作成します。そのファイルに以下のコードを貼り付け、更新したファイルを保存します。
Param( [string]\ :math:`API\_URL, \[string\]`\ MessageType,
[string]\ :math:`SiteName, \[string\]`\ Device,
[string]\ :math:`DeviceId, \[string\]`\ Name,
[string]\ :math:`Status, \[string\]`\ Down,
[string]\ :math:`DateTime, \[string\]`\ LinkDevice, [string]$Message )
Add-Type -AssemblyName System.Web.Extensions function ConvertTo-Json
([Object] $value) {
[System.Web.Script.Serialization.JavaScriptSerializer] $jsSerializer =
New-Object ‘System.Web.Script.Serialization.JavaScriptSerializer'
:math:`jsSerializer.Serialize(`\ value) }
function setMessageType ([string]
:math:`inputString) { If (`\ inputString -like “Up\*”) { return
‘recovery' } elseif
(:math:`inputString -like "Down\*") { return 'critical' } elseif (`\ inputString
-like “Warning\*”) { return ‘warning' } else { return ‘info' } }
:math:`postVOAlert = ConvertTo-Json(@{ message\_type = SetMessageType(`\ Status);
entity_id = $DeviceId; entity_display_name = $Device; monitoring_tool =
“PRTG”; site_name =
:math:`SiteName; link\_device = "<`\ (:math:`LinkDevice)|`\ ($Device)
:math:`(`\ Name)>“; status =”\ :math:`(`\ Status) :math:`(`\ Down) on
:math:`(`\ DateTime)“; state_message = $Message; })
[Net.ServicePointManager]::SecurityProtocol =
[Net.SecurityProtocolType]::Tls12 $postVOAlert \| Out-File -FilePath
vo.log
[System.Net.WebClient] $webclient = New-Object ‘System.Net.WebClient'
$webclient.Headers.Add(“Content-Type”,“application/json”)
:math:`webclient.UploadData(`\ API_URL,
[System.Text.Encoding]::UTF8.GetBytes($postVOAlert)) \| Out-File
-FilePath vo.log -Append
サーバーのデスクトップから、PRTG Enterprise Console を開きます。
data:image/s3,"s3://crabby-images/75dc1/75dc1eea326968366806ac1a791304e79e5649d4" alt="PRTG Enterprise Consoleのデスクトップアイコン。"
PRTG Enterprise Consoleで、Setup タブを選択します。
data:image/s3,"s3://crabby-images/d03b8/d03b832ffed3bd5edfe62436bc3bc87c5cb521f4" alt="PRTG Enterprise Consoleの「セットアップ」タブ。"
「アカウント設定」で Notifications を選択します。
data:image/s3,"s3://crabby-images/ff20a/ff20ab63621ff8f275c7beb7420ebfcf065f12f2" alt="「アカウント設定」の下にある「通知」タブ。"
Add new notification を選択します。
data:image/s3,"s3://crabby-images/77eae/77eae1edb794f562569dd4c428061c0097813a96" alt="「新しい通知を追加」と書かれた青いボタン。"
「通知名」フィールドに「Splunk On-Call Notification」と入力し、「メソッド」に Always notify ASAP, never summarize を選択します。
data:image/s3,"s3://crabby-images/7280c/7280cc72881e87707123b049f6fb028b4c5684ad" alt="通知名と概要オプション。"
下にスクロールし、EXECUTE PROGRAM を選択します。
data:image/s3,"s3://crabby-images/a5a2a/a5a2ab92799804d1f01b0960e74b1579f38af247" alt="「プログラムの実行」と書かれた空のチェックボックス。"
「プログラムファイル」ドロップダウンメニューから Prtgtovictorops.ps1 を選択し、」Parameter」フィールドに以下を貼り付けて、URL_to_notify
を」In Splunk On-Call」セクションから」通知するURL」に置き換えてください。
-API_URL 'URL_to_notify' -SiteName '%sitename' -Device '%device'
-DeviceId '%deviceid' -Name '%name' -Status '%status' -Down '%down'
-DateTime '%datetime' -LinkDevice '%linkdevice' -Message '%message'
data:image/s3,"s3://crabby-images/f5bd6/f5bd6b5a120522657ce866ceae8fd4d5107ad062" alt="「プログラムの実行」のフィールドは、前のコードからの認証情報で埋められています。"
PRTGを最初にインストールしたWindows管理者の認証情報を入力し、Save を選択します。
data:image/s3,"s3://crabby-images/9e9b7/9e9b7d662a033c48a36e94c8c46c7743071ebf98" alt="矢印は「保存」と書かれた青いボタンを指しています。"
「VictorOps通知」の隣にある Test リンクを選択します。
data:image/s3,"s3://crabby-images/4f56b/4f56b628b7110d90d77455f799c062d7cc0b946a" alt="矢印は、VictorOps通知の横にある「テスト」と書かれた青いボタンを指しています。"
「通知テスト結果」で OK を選択します。
data:image/s3,"s3://crabby-images/2ae8b/2ae8b68322ee7d05a857439f41c3c23867201602" alt="「OK」と書かれたグレーのボタン。"
Splunk On-Callタイムラインにアラートが表示されます。
Devices タブを選択します。
data:image/s3,"s3://crabby-images/109d4/109d4bceab26e27557298b019a4df94944034ef1" alt="PRTG Enterprise Consoleの「デバイス」タブ。"
親PRTGサーバー接続を選択します。
data:image/s3,"s3://crabby-images/c70c9/c70c9e970cc979620da0b4a5d2eee1d028ffde94" alt="「prtg admin」とラベル付けされたルートPRTGサーバー接続。"
Notifications タブを選択します。
data:image/s3,"s3://crabby-images/21c4a/21c4aa5446ab8c4cf779a40a0f45a54a17d501b1" alt="PRTGサーバー接続メニューの「通知」タブ。"
Add State Trigger を選択します。
data:image/s3,"s3://crabby-images/f827a/f827a1ff8cc5bf9a2f391e71028f8b0730d8d8a0" alt="通知メニュー。矢印が「状態を追加する」と書かれた青いボタンを指しています。"
この例では、トリガーは」警告」センサー状態を使用します。これらの設定を変更したり、例えばセンサーが」Down」の時のために他のトリガーを作成したりすることができます。」perform」の後にある3つのドロップダウンメニューから、VictorOps Notification を選択し、Save を選択することを確認してください。
data:image/s3,"s3://crabby-images/995d4/995d460e432f4b71d5a91d4e84bee503e978f37d" alt="アラートトリガーの設定。このメニューでさまざまなフィールドを切り替えることができます。矢印は「保存」と書かれた青いボタンを指しています。"
これでこのインテグレーションの設定は完了です。
アラートをシミュレートする 🔗
センサーの1つに移動して選択し、」simulate error status」を選択することで、インテグレーションを確認できます。これによりSplunk On-Callが作成されます。
トラブルシューティング 🔗
インテグレーションスクリプトを最適に動作させるために、最新バージョンのPowershell がPRTG環境で実行されていることを確認してください。現在のPowershellのバージョンは、次のコマンドラインを実行することで確認できます:
$PSVersionTable.PSVersion
ご不明な点がございましたら、Splunk On-Callサポート までお問い合わせください。