AWS メトリックスストリームインテグレーションでは、すべてのsingle service AWSAWSメトリックスとカスタムネームスペースを収集して に送信するには、 ( CloudWatch)New Relic のみが必要です。
CloudWatchのメトリクスをNew Relicにストリーミングするには。
- 最小限のパーミッションとマッピングの説明 を確認してください。
- Kinesis Data Firehoseを作成し、New Relicを指定します。
- 次に、先ほど作成したFirehoseにメトリクスを送信するために、CloudWatch Metric Streamを作成する。
- ガイド付き または マニュアル のセットアップ手順に従う。
- データ受信の検証。
該当する場合は、 AWSポーリング統合からの移行に関するドキュメントをお読みください。
ヒント
Terraformを使用して、クラウド統合を有効にするプロセスを自動化できます。 Terraformの公式ドキュメントサイトでその方法をお読みください。
最小限のパーミッションとマッピングの指示
サービスメタデータやカスタムタグを追加してCloudWatchのメトリクスを充実させるには、New Relicに設定されているAWSロールに、以下の最小限の権限を付与する必要があります。
config:BatchGetResourceConfigconfig:ListDiscoveredResourceselasticache:DescribeCacheClusterstag:GetResources
New Relic UIは現在、これらの個々のアイテムに対してReadOnlyAccess
ポリシーを推奨しているため、New Relicには、AWS CloudWatchMetricStreamsでは利用できないサービスデータを収集するための適切な権限があります。
New RelicとAWSのアカウントとリージョンのマッピング
- 複数のAWSアカウントを管理している場合は、それぞれのアカウントをNew Relicに接続する必要があります。
- これらのアカウントで複数の地域を管理している場合は、各地域にNew Relicを指す異なるKinesis Data Firehoseを設定する必要があります。
- 通常、1つのNew Relicアカウントに1つまたは複数のAWSアカウントをマッピングします。
CloudFormationを使ったガイド付きセットアップ
まず、各AWSアカウントをNewRelicアカウントにリンクする必要があります。これを行うには、次のいずれかのオプションを使用します。
one.newrelic.com > All capabilities > Infrastructure > AWS
に移動し、
Add an AWS account
をクリックしてから
Use metric streams
をクリックし、手順に従います。
次に、UIの最後のステップで提供するCloudFormationテンプレートを使用してメトリックストリームを設定します。このテンプレートは、単一のリージョンで統合を設定するためのベースとして提供されています。要件に合わせてカスタマイズおよび拡張できます。
CloudFormation テンプレートのパラメーター
この表は、CloudFormation テンプレートに必要なさまざまなパラメーターの概要を示しています。テンプレートは AWS アカウントに新しいリソースを作成するため、ここでは既存の AWS リソースの名前を提供しません。
名前 | 説明 | 制約 |
---|---|---|
New Relic インジェスト ライセンス キー | メトリクスのエクスポート先のアカウントに関連付けられた 。 | 40 文字の 16 進文字列 |
New Relic データセンター | メトリクスがエクスポートされるNew Relicデータセンターの ID。 (EU データセンター アカウントのライセンスキーの先頭には | 許容値: |
CloudWatch メトリクス ストリーム名 | 新しい CloudWatch メトリクス ストリームの名前 (同じ AWS リージョン内の AWS アカウントごとに一意である必要があります) | 文字 (大文字と小文字)、数字、文字「_」、および「-」のみを含む必要があり、最大長は合計 255 文字です |
Kinesis Data Firehose 名 | 新しい Kinesis Firehose Delivery Stream の名前 (同じ AWS リージョン内の AWS アカウントごとに一意である必要があります) | 文字 (大文字と小文字)、数字、および文字「.」、「_」、および「-」のみを含む必要があり、最大長は合計 64 文字です |
Firehose S3 バックアップ バケット名 | 失敗したイベントの新しい S3 バケット送信先の名前 (パーティション内のすべての AWS リージョンのすべての AWS アカウントでグローバルに一意である必要があります) | S3 バケットの命名規則に従う必要があります |
AWS Config のリソース メタデータでメトリクスを強化する | リソースの変更を追跡するために AWS Config を有効にして設定します。これにより、New Relic エクスペリエンスを完全に監視できます。 | 許容値: |
S3 バックアップ バケット名の構成 | 配信チャネル設定用の新しい S3 バケット送信先の名前 (パーティション内のすべての AWS リージョンのすべての AWS アカウントでグローバルに一意である必要があります) | S3 バケットの命名規則に従う必要があります |
ヒント
提供された CloudFormation テンプレートには、CloudWatch メトリクス ストリームに包含または除外名前空間フィルターが含まれていません。ビジネス要件に基づいて基本テンプレートを調整することを検討してください。
AWSコンソール、API、またはコールを使用した手動設定
Create a Kinesis Data Firehose Delivery Stream 、以下の宛先パラメータを設定します。
ソースダイレクトPUTまたはその他のソース
データ変換。使用不可
記録フォーマットの変換。無効
目的地New Relic
以下の設定が定義されていることを確認してください。
New Relicの設定(Destination Settings)
HTTPエンドポイントURL-米国のデータセンター:
https://aws-api.newrelic.com/cloudwatch-metrics/v1
HTTPエンドポイントURL-EUデータセンター:
https://aws-api.eu01.nr-data.net/cloudwatch-metrics/v1
APIキー: を入力してください
コンテンツエンコーディング:
GZIP
再試行期間:
60
S3バックアップモード。失敗したデータのみ
S3バケット:送信に失敗したメトリクスを保存するバケットを選択するか、新しいバケットを作成します。
New Relicのバッファ条件
- バッファサイズ:
1 MB
- バッファ間隔:
60 (seconds)
- バッファサイズ:
パーミッション IAMロール
- IAMロールの作成または更新
メトリクス・ストリームの作成.
AWS コンソールのCloudWatch serviceに移動し、 MetricsメニューのStreamsオプションを選択します。
Create metric streamをクリックします。
ユースケースに応じて適切な構成を決定します。
- どのサービスがNew Relicにメトリクスをプッシュすべきかを選択するには、包含フィルターと除外フィルターを使用します。
- Kinesis Data Firehoseを選択します。
- ストリームに意味のある名前を定義します(たとえば、
newrelic-metric-stream)
。
デフォルトの出力形式を
Open Telemetry 0.7
に変更します。(JSONはサポートされていません。)メトリクスストリームの作成を確認します。
または、AWS ドキュメントで、CloudFormation テンプレート、API、または CLI を使用して CloudWatch メトリクス ストリームを作成する手順を見つけることができます。
New Relic UI のMetric streamsモードで新しい AWS アカウントを追加します。 one.newrelic.com > All capabilities > Infrastructure > AWSに移動し、 Add an AWS accountをクリックし、次にUse metric streamsをクリックして、手順に従います。
データが正しく受信されているかどうかの確認
メトリック ストリームからデータを受信していることを確認するには、次の手順に従います。
one.newrelic.com > All capabilities > Infrastructure > AWSに移動し、 Streamのアカウントを検索します。
次の点をチェックします。
- アカウント ステータス ダッシュボード。New Relic がメトリクス データ (エラー、取り込まれた名前空間/メトリクスの数など) を受信していることを確認するのに役立ちます。
- データを探索します。メトリックとイベントを使用して、特定のメトリック セットを見つけたり、特定のメトリックで使用可能なすべてのディメンションにアクセスしたりします。
新しいリソースが検出され、エンティティとして合成されるまで、数分かかる場合があります。詳細については、クラウド統合システムの制限を参照してください。
ヒント
AWS Billing などのグローバルサービスのAWS CloudWatch メトリックスは、us-east-1 リージョンでのみ利用できます。 そのリージョンにアクティブな CloudWatch メトリック ストリームが設定されていることを確認してください。
クエリ、メトリックの保存、マッピング
AWS CloudWatchからのメトリクスは、タイプsummary
のディメンションメトリクスとして保存されます。NRQLを使用してクエリを実行できます。
現在のクラウド統合からのメトリクスを、AWS Metric Streams から来る新しいマッピングにマッピングしました。現在のメトリクスの命名を引き続き使用できます。クエリは引き続き機能し、AWS Metric Streams と現在のクラウド統合からデータを選択します。
現在のクラウド統合のメトリクスと新しいメトリクスの名称 への対応については、ドキュメントをご確認ください。
メトリック ストリームからのすべてのメトリックには、次の属性があります。
aws.MetricStreamArn
collector.name = 'cloudwatch-metric-streams'
。
エンティティ リスト内の AWS 名前空間のエンティティ
多くの AWS 名前空間に対して New Relic エンティティ を生成します。名前空間の New Relic エンティティを生成すると、次のことが期待できます。
- エンティティ エクスプローラーでこれらのエンティティを参照します。
- それらのエンティティ用に自動的に作成されたエンティティダッシュボードにアクセスします。
- AWSタグで装飾された名前空間からメトリックとエンティティを取得します。AWSタグを収集するには、UIのセットアッププロセスの一部である
tag:GetResources
権限をNewRelicに付与している必要があります。AWSタグは、メトリックにtag.AWSTagName
として表示されます。たとえば、リソースにTeam
AWSタグを設定した場合、tag.Team
と表示されます。 - エンティティ エクスプローラーに含まれるすべての機能を活用します。
重要
New Relic Lookout は、 AWS Metric Streams 統合と互換性がありません。
アラート条件の設定
メトリック・ストリームからのメトリクスに対してNRQLアラート条件を作成することができます。フィルタがデータをCloudWatchメトリック・ストリームからのメトリクスのみに制限することを確認してください。そのためには、以下のようにクエリを構成します。
SELECT sum(aws.s3.5xxErrors) FROM Metric WHERE collector.name = 'cloudwatch-metric-streams' FACET aws.accountId, aws.s3.BucketName
次に、 データを正しく処理できるように、詳細な信号設定を構成します。 AWS CloudWatch は一定の遅延を持ってサービスからメトリクスを受信するため、これらの設定が必要です。 (たとえば、Amazon は、EC2 メトリクスの 90% が生成されてから 7 分以内に CloudWatch で利用可能になることを保証しています。) さらに、AWS から New Relic へのメトリクスのストリーミングでは、主に Firehose でのデータのバッファリングが原因で、最大 1 分の追加遅延が発生します。
信号設定を構成するには、 Condition SettingsでAdvanced Signal Settingsをクリックし、次の値を入力します。
Aggregation window
。 1分に設定することをお勧めします。 フラッピング アラート または アラート がトリガーされないという問題がある場合は、2 分に増やすことを検討してください。
Offset evaluation by
。サービスによっては、CloudWatch は一定の遅延を伴ってメトリクスを送信する場合があります。 値は Windows で設定されます。 1 分間の集計ウィンドウでオフセットを 8 に設定すると、ほとんどのメトリックが正しく評価されます。 AWS と Firehose によってもたらされる遅延が少ない場合は、より低いオフセットを使用できる可能性があります。
Fill data gaps with
この空白のままにしておくか、AWS からのデータにギャップがあり、誤検知または誤検知が発生する場合は、最後の既知の値を使用します。
詳細については、NRQLアラートの作成方法に関するドキュメント をご覧ください。
タグコレクション [#tags-collection]
New Relic は、AWS CloudWatch メトリクス ストリームからのメトリクスから拡張ディメンションを提供します。リソース タグとカスタム タグは、ほとんどのサービスから自動的に取得され、追加のディメンションでメトリックを装飾するために使用されます。メトリクスとイベントを使用して、各 AWS メトリクスで使用できるタグを確認します。
次のクエリは、タグを収集し、メトリクスのディメンションとしてクエリを実行する例を示しています。
SELECT average(`aws.rds.CPUUtilization`) FROM Metric FACET `tags.mycustomtag` SINCE 30 MINUTES AGO TIMESERIES
すべての指標にディメンションとしてカスタム タグがあるわけではありません。エンティティ エクスプローラー にリストされているエンティティにリンクされているメトリクスのみに、カスタム タグが関連付けられています。AWS CloudWatch メトリクス ストリームには、ストリーム メッセージの一部としてタグが含まれません。したがって、New Relic 側で追加の処理が必要になります。
メタデータの収集
カスタムタグと同様に、New Relic は関連する AWS サービスからメタデータ情報をプルして、AWS サービス API から収集された強化されたメタデータで AWS CloudWatch メトリクスを装飾します。このメタデータは、AWS CloudWatch によって提供されるメトリクスの追加のディメンションとして、New Relic でアクセスできます。
重要
このオプションの機能は、CloudWatch Metric Streams 統合を補完するものです。このオプション機能を有効にしないと、サービスの検出と監視が不完全になります。
このソリューションは、 AWS Config に依存しており、お客様のAWSアカウントに追加コストが発生する可能性があります。 AWS Config は、どのサービスやリソースを記録するかを決定するために、 粒度の高いコントロールを提供します。New Relic は、お客様の AWS アカウントで利用可能なリソースからのみメタデータを取り込みます。
ALB/NLB
APIゲートウェイ(API v1を除く)
DynamoDB
EBS
EC2
ECS
ELB
ラムダ
RDS
S3
インフラストラクチャエージェントのメトリクスとEC2メタデータの装飾 [#infra-data-decoration]
カスタムメトリックとパーセンタイル [#custom-metrics-percentiles]
CloudWatchメトリクスストリーム統合は、カスタムメトリクスやパーセンタイルなど、ストリームに設定された新しいメトリクスを自動的に取り込みます。
カスタムメトリック [#custom-metrics]
パーセンタイル [#percentiles]
AWS CloudWatchを使用すると、パーセンタイルなどの追加の統計を定義できます。
次の手順に従って、CloudWatchストリームで利用可能なすべてのメトリクスにパーセンタイルを追加します。
AWSで、CloudWatchストリーム設定を(API、CLI、またはAWSコンソールを介して)
StatisticConfiguration
設定で必要なパーセンタイルで更新します。たとえば、p90、p95、およびp99パーセンタイルをELB latency metric (aws.elb.Latency)
に追加できます。数分後、新しい統計がストリームで利用可能になり、NewRelicによって取り込まれるはずです。パーセンタイルは、次の命名規則を使用して照会できます。
From Metric select max(aws.elb.Latency.p99) where collector.name = 'cloudwatch-metric-streams' timeseries
AWSは、パーセンタイルを超えるストリーム内の他の統計をサポートしていますが、それらはOpen Telemetryエクスポート形式(JSONのみ)では利用できず、現在NewRelicではサポートされていません。
価格設定、制限、および事前設定の詳細については、 AWSのドキュメントをご覧ください。
データの管理
New Relic UI は、アカウントに取り込まれているデータを追跡するための一連のツールを提供します。 すべての詳細を表示するには、設定メニューのManage your dataに移動します。 AWSメトリクス ストリーム統合から取り込まれたメトリクスは、 Metricバケット内にあるとみなされます。
データをより詳細に表示する必要がある場合は、 Metric
で bytecountestimate()
関数 を使用して、取り込まれるデータを推定します。たとえば、次のクエリは、過去 30 日間に AWS Metric Streams 統合を介して処理されたすべてのメトリクスから取り込まれたデータを表します (バイト単位)。
FROM Metric SELECT bytecountestimate()/10e8 as 'GB Estimate' WHERE collector.name='cloudwatch-metric-streams' SINCE 30 day ago
AWSサービス/ネームスペースによって取り込まれたデータを表示するには:
FROM Metric SELECT bytecountestimate()/10e8 as 'GB Estimate' WHERE collector.name='cloudwatch-metric-streams' FACET aws.Namespace
AWSサービス/ネームスペースによって処理された生のメトリックスアップデートの数を確認するには:
FROM Metric SELECT dataPointCount() WHERE collector.name='cloudwatch-metric-streams' FACET aws.Namespace
インジェストされるデータをコントロールするために、次のような対応をお勧めします。
New Relicで監視したいAWSアカウントとリージョンでのみメトリックストリームが有効になっていることを確認します。
Use the inclusion and exclusion filters
CloudWatch Metric Streamsで、 New Relicによって監視されているサービスまたはネームスペースを選択します。
ドロップデータルールを使用して、カスタムフィルターに基づくメトリックを破棄することを検討してください。(たとえば、名前空間とタグ、タグ値、またはその他の有効なNRQL基準ごとにメトリックを削除します。)
重要
AWS Metric Streams を介して送信されたメトリクスは、データが取り込まれる New Relic アカウントの Metric API 制限にカウントされます。