変数

通知メッセージ内で変数を使用すれば、条件付き変数を使用して条件付きメッセージを表示したり、通知をさまざまなチームにルーティングしたり、属性とタグ変数およびテンプレート変数を使用してそのコンテンツをリッチ化したりできます。

条件付き変数

条件付き変数は、if-else ロジックを使用して、モニターの状態とトリガーのされ方の詳細に応じて異なるメッセージを表示します。この変数は、通知メッセージの件名または本文内で使用できます。

以下の条件付き変数を使用できます。

条件付き変数テキストは次の場合に表示されます
{{#is_alert}}モニターがアラートする
{{^is_alert}}モニターがアラートしない
{{#is_match}}コンテキストは指定されたサブストリングに一致します。数値が使用された場合、文字列に変換されます。
{{^is_match}}コンテキストが指定された部分文字列と一致しない
{{#is_exact_match}}コンテキストは指定された文字列と正確に一致します。
数値が使用された場合、その型に関係なく数値として扱われます。つまり、2 つの数値が同じ値である限り、この関数はそれらを等しいとみなします。
{{^is_exact_match}}コンテキストが指定された文字列と完全に一致しない
{{#is_no_data}}不足しているデータに対してモニターがトリガーされる
{{^is_no_data}}不足しているデータに対してモニターがトリガーされない
{{#is_warning}}モニターが警告する
{{^is_warning}}モニターが警告しない
{{#is_recovery}}ALERTWARNINGUNKNOWN、または NO DATA からモニターが回復する
{{^is_recovery}}ALERTWARNINGUNKNOWN、または NO DATA からモニターが回復しない
{{#is_warning_recovery}}モニターが WARNING から OK に回復する
{{^is_warning_recovery}}モニターが WARNING から OK に回復しない
{{#is_alert_recovery}}モニターが ALERT から OK に回復する
{{^is_alert_recovery}}モニターが ALERT から OK に回復しない
{{#is_alert_to_warning}}モニターが ALERT から WARNING に移行する
{{^is_alert_to_warning}}モニターが ALERT から WARNING に移行しない
{{#is_no_data_recovery}}モニターが NO DATA から回復する
{{^is_no_data_recovery}}モニターが NO DATA から回復しない
{{#is_priority 'value'}}モニターの優先度は value です。値の範囲は P1 から P5 です
{{#is_unknown}}モニターは不明な状態です
{{^is_unknown}}モニターは不明な状態ではありません
{{#is_renotify}}モニターが再通知しています
{{^is_renotify}}モニターは再通知していません。

条件付き変数には、テキストと @通知の間に開始と終了のペアが必要です。

モニターがアラートしたときに通知メッセージを送信するには、次の形式を使用します。

{{#is_alert}}
  <アラートメッセージテキスト> <@通知>
{{/is_alert}}

モニターが警告したときに通知メッセージを送信するには、次の形式を使用します。

{{#is_warning}}
  <警告メッセージテキスト> <@通知>
{{/is_warning}}

モニターが回復したときに通知メッセージを送信するには、次の形式を使用します。

{{#is_recovery}}
  <回復メッセージテキスト> <@通知>
{{/is_recovery}}

次の形式でタグ変数内の部分文字列を検索します。

{{#is_match "<タグ変数>.name" "<比較文字列>"}}
  これは、<比較文字列> が <タグ変数> に含まれている場合に表示されます。
{{/is_match}}

トリガーするホストにタグ role:db_cassandra または role:db_postgres がある場合に DB チームに通知する場合は、以下を使用します。

{{#is_match "role.name" "db"}}
  これは、アラートをトリガーするホストのロール名に `db` が含まれている場合に表示されます。@db-team@company.com
{{/is_match}}

is_match 条件は、複数の文字列の一致にも対応しています。

{{#is_match "role.name" "db" "database"}}
  アラートをトリガーしているホストのロール名に `db` または `database` が
  含まれている場合に表示されます。@db-team@company.com
{{/is_match}}

タグに db が含まれない場合に異なる通知を送信するには、以下のように条件の否認を使用します。

{{^is_match "role.name" "db"}}
  ロールタグに `db` が含まれない場合に表示されます。
  @slack-example
{{/is_match}}

または、最初の例にある {{else}} パラメータを使用します。

{{#is_match "role.name" "db"}}
  アラートをトリガーしているホストのロール名に `db` が
  含まれている場合に表示されます。@db-team@company.com
{{else}}
  ロールタグに `db` が含まれない場合に表示されます。
  @slack-example
{{/is_match}}

: <タグ変数> が空ではないかどうかを確認するには、<比較文字列> に空の文字列を使用します。

次の形式でタグ変数内の正確な文字列を検索します。

{{#is_exact_match "<タグ変数>.name" "<比較文字列>"}}
  これは、<比較文字列> が正確に <タグ変数> である場合に表示されます。
{{/is_exact_match}}

トリガーするホストの名前が production である場合に開発チームに通知するには、以下を使用します。

{{#is_exact_match "host.name" "production"}}
  これは、アラートをトリガーするホストの名前が正確に production である場合に表示されます。@dev-team@company.com
{{/is_exact_match}}

is_exact_match 条件は、複数の文字列の一致にも対応しています。

{{#is_exact_match "host.name" "production" "staging"}}
  これは、アラートをトリガーするホストの名前が
  正確に production または staging である場合に表示されます。
{{/is_exact_match}}

条件変数 is_exact_match{{value}} テンプレート変数もサポートします。

{{#is_exact_match "value" "<VALUE>"}}
  This displays if the value that breached the threshold of the monitor is exactly <VALUE>.
{{/is_exact_match}}

モニターで設定したしきい値を超過した値が 5 (または 5.0 ) の場合に、開発チームへ通知するには、以下を使用してください。

{{#is_exact_match "value" "5"}}
  This displays if the value that breached the threshold of the monitor is 5. @dev-team@company.com
{{/is_exact_match}}

production 環境専用の別の宛先にエスカレーションメッセージを送信するには、次のようにします。

{{#is_renotify}}
{{#is_match "env" "production"}}
  This is an escalation message sent to @dev-team@company.com
{{/is_match}}
{{/is_renotify}}

元のメッセージの詳細を含まない別のエスカレーションメッセージを送信するには、{{^is_renotify}} ブロックと {{#is_renotify}} ブロックを組み合わせて使用します。

{{^is_renotify}}
このモニターは警告を発し、最初のメッセージ @dev-team@company.com を送信しています

このモニターを解決するには、次の手順に従ってください。
1. そこに行く
2. これを行う
{{/is_renotify}}

この部分は一般的であり、最初のトリガーとエスカレーションメッセージの両方に送信されます。

{{#is_renotify}}
  これはエスカレーションメッセージ @dev-team@company.com です。
{{/is_renotify}}

モニターの再通知で、ユーザーは次のエスカレーションメッセージを受け取ります。

この部分は一般的であり、最初のトリガーとエスカレーションメッセージの両方に送信されます。

これはエスカレーションメッセージ @dev-team@company.com です。

alert または warning の状態に遷移する条件ブロックを @-notifications ハンドルで構成した場合、そのハンドルに回復通知を送るために、対応する recovery 条件を構成することが推奨されます。

: 構成された条件変数の外側に置かれたテキストまたは通知ハンドルは、モニターの状態遷移ごとに起動されます。構成された条件変数の内側に置かれたテキストまたは通知ハンドルは、モニター状態の遷移がその条件に一致する場合にのみ呼び出されます。

属性変数とタグ変数

属性変数とタグ変数を使用して、カスタマイズされた、有益で、特定のアラートメッセージを表示して、アラートの性質を理解できるようにします。

: データがない状態 (例えば、クエリに一致するイベントがない状態) でモニターが回復するように構成されている場合、回復メッセージにはデータは含まれません。回復メッセージの情報を保持するには、{{tag.name}} でアクセスできる追加のタグでグループ化します。

マルチアラート変数

マルチアラートグループボックスで選択したディメンションに基づいて、マルチアラートモニターでマルチアラート変数を構成します。通知を強化して、各アラートのディメンションごとのグループに関連付けられた値を動的に含めます。

メトリクスが key:value 構文に続くタグでタグ付けされており、モニタークエリがこのタグでグループ化されている場合は、変数を使用します。

{{ key.name }}

これにより、各アラート通知の key に関連付けられた value が表示されます。グループが同じ key に関連付けられた複数の values でタグ付けされている場合、アラートメッセージは、辞書順ですべての値をコンマ区切りの文字列として表示します。

: モニターが各 env に対してアラートをトリガーする場合、変数 {{env.name}} が通知メッセージで使用可能です。

マルチアラート変数の構文

ピリオドを含むタグキー

タグのキーにピリオドが含まれている場合は、タグ変数を使用するときに、キー全体を角括弧で囲みます。 たとえば、タグが dot.key.test:five で、モニターが dot.key.test によってグループ化されている場合は、次を使用します。

{{[dot.key.test].name}}

イベントにタグがあり、イベントモニターを使用している場合は、以下を使用します。

{{ event.tags.[dot.key.test] }}

ログモニター、トレース分析モニター、RUM モニター、イベントモニターは、モニターがファセットごとにグループ化されている場合、ファセットを変数として使用できます。ログモニターが @facet_key でグループ化されている場合は、変数を使用します。

{{ @facet_key.name }}

: @machine_id によってマルチアラートログモニターグループにグループ固有の情報を含めるには

This alert was triggered on {{ @machine_id.name }}

ファセットにピリオドが含まれている場合、ファセットを角括弧で囲みます。例、

{{ [@network.client.ip].name }}

通知をグループごとにカスタマイズする

クエリが特定のディメンションでグループ化されている場合、そのグループに関連する動的メタデータを活用して通知を拡充できます。

ホストごとのクエリグループ

モニターが各 host に対してアラートをトリガーする場合、タグ変数 {{host.name}}{{host.ip}} 、およびこのホストで使用可能なホストタグを使用できます。タグの選択に基づいてタグ変数のリストを表示するには、Say what’s happening セクションで Use message template variables をクリックします。

特定のホストのメタデータ変数:

  • Agent Version: {{host.metadata_agent_version}}
  • Machine: {{host.metadata_machine}}
  • Platform: {{host.metadata_platform}}
  • Processor: {{host.metadata_processor}}
クエリを kube_namespace および kube_cluster_name でグループ化する

モニターが kube_namespacekube_cluster_name ごとにアラートをトリガーする場合、ネームスペースの任意の属性にアクセスできます。

ネームスペースのメタデータ変数:

  • クラスター名: {{kube_namespace.cluster_name}}
  • ネームスペース名: {{kube_namespace.display_name}}
  • ネームスペースのステータス: {{kube_namespace.status}}
  • ネームスペースのラベル: {{kube_namespace.labels}}

以下の表には、利用可能なすべての属性が含まれています。

変数構文第 1 レベルの属性
{{kube_namespace.key}}k8s_namespace_keytagsannotationscluster_idcluster_namecreation_timestampdeletion_timestampdisplay_nameexternal_idfinalizersfirst_seen_atgroup_sizelabelsnamenamespacestatusuid
クエリを pod_name、kube_namespace、kube_cluster_name でグループ化する

モニターが pod_namekube_namespacekube_cluster_name ごとにアラートを発生させる場合、ポッドの任意の属性にアクセスできます。

ポッドのメタデータ変数:

  • クラスター名: {{pod_name.cluster_name}}
  • ポッド名: {{pod_name.name}}
  • ポッドのフェーズ: {{pod_name.phase}}

以下の表には、利用可能なすべての属性が含まれています。

変数構文第 1 レベルの属性
{{pod_name.key}}k8s_pod_keytagsannotationscluster_idcluster_nameconditionscontainer_statusescreation_timestampdeletion_timestampdisplay_nameexternal_idfinalizersfirst_seen_athost_idhost_keyhostnameinit_container_statusesiplabelsnamenamespacenode_namenominated_node_namephasepod_scheduled_timestamppriority_class_nameqosclassresource_requirementsuid

一致する属性/タグ変数

これらは Log モニターTrace Analytics モニター (APM)、Error Tracking モニターRUM モニターCI モニターDatabase Monitoring モニターで利用できます。

モニタークエリに一致するログ、トレーススパン、RUM イベント、CI パイプラインまたは CI テストイベントから任意の属性またはタグを含めるには、次の変数を使用します。

モニターの種類変数構文
ログ{{log.attributes.key}} または {{log.tags.key}}
トレース分析{{span.attributes.key}} または {{span.tags.key}}
Error Tracking{{issue.attributes.key}}
RUM{{rum.attributes.key}} または {{rum.tags.key}}
Audit trail(監査証跡){{audit.attributes.key}} または {{audit.message}}
CI Pipeline{{cipipeline.attributes.key}}
CI Test{{citest.attributes.key}}
Database Monitoring{{databasemonitoring.attributes.key}}

key:value ペアの場合、変数 {{log.tags.key}} はアラートメッセージに value を表示します。

: ログモニターが @http.status_code でグループ化されている場合、通知メッセージにエラーメッセージまたはインフラストラクチャータグを含めるには、次の変数を使用します。

{{ log.attributes.[error.message] }}
{{ log.tags.env }}
...
一致する属性変数の構文

メッセージは、属性が存在する場合、クエリに一致する選択されたログの error.message 属性を表示します。

: 選択したイベントに属性またはタグキーが含まれていない場合、変数は通知メッセージで空になります。通知の欠落を回避するには、{{#is_match}} ハンドルを使用して通知をルーティングするためにこれらの変数を使用しません。

モニターがクエリで Formula & Functions を使用する場合、値は最初のクエリから抽出されるイベントで解決されます。

予約済み属性

ログ、イベント管理、スパン、RUM、CI パイプライン、CI テストイベントには、次の構文の変数で使用できる一般的な予約済み属性があります。

モニターの種類変数構文第 1 レベルの属性
ログ{{log.key}}messageservicestatussourcespan_idtimestamptrace_idlinkhost
トレース分析{{span.key}}envoperation_nameresource_nameservicestatusspan_idtimestamptrace_idtypelink
RUM{{rum.key}}servicestatustimestamplink
イベント{{event.key}}attributeshost.nameidlinktitletexttags
CI Pipeline{{cipipeline.key}}serviceenvresource_nameci_leveltrace_idspan_idpipeline_fingerprintoperation_nameci_partial_arraystatustimestamplink
CI Test{{citest.key}}serviceenvresource_nametrace_idspan_idoperation_namestatustimestamplink

一致するイベントの定義に属性が含まれていない場合、変数は空になります。

エクスプローラーリンク

{{log.link}}{{span.link}}{{rum.link}}{{issue.link}} を使用して、クエリに一致するイベントを対象としたログエクスプローラー、トレースエクスプローラー、RUM エクスプローラー、またはエラー追跡へのリンクで通知を充実させます。

チェックモニター変数

チェックモニター変数(カスタムチェックおよびインテグレーションチェック)には、変数 {{check_message}} が利用可能で、カスタムチェックまたはインテグレーションチェックで指定されたメッセージを表示します。

複合条件モニター変数

複合条件モニターは、アラートがトリガーされたときにサブモニターに関連付けられた値とステータスにアクセスできます。

たとえば、複合条件モニターにサブモニター a がある場合、a の値を次で含めることができます。

{{ a.value }}

サブモニター a のステータスを取得するには、以下を使用します。

{{ a.status }}

ステータスに指定できる値は、OKAlertWarn、および No Data です。

複合条件モニターは、基底のモニターと同様の方法でタグ変数もサポートします。基底のモニターが同じタグまたはファセットでグループ化されていることを条件に、複合条件モニターは他のモニターと同様の形式に従います。

例えば、複合条件モニターにサブモニター a があり、それがログモニターであるとします。この場合は、次の方法で a のタグまたはファセットの値を含めることができます。

{{ a.log.message }} または {{ a.log.my_facet }}

文字エスケープ

変数の内容はデフォルトでエスケープされます。JSON やコードなどの内容がエスケープされないようにするには、たとえば {{{event.text}}} のように、二重中括弧の代わりに三重中括弧を使用します。

テンプレート変数

テンプレート変数を使用して、モニター通知をカスタマイズします。組み込み変数は次のとおりです。

変数説明
{{value}}メトリクスベースのクエリモニターのアラートに違反した値。
{{threshold}}モニターのアラート条件に設定されたアラートしきい値の値。
{{warn_threshold}}モニターのアラート条件に設定された警告しきい値の値。
{{alert_recovery_threshold}}モニターを ALERT 状態から回復させた値。
{{warn_recovery_threshold}}モニターを WARN 状態から回復させた値。
{{ok_threshold}}サービスチェックモニターを回復した値。
{{comparator}}モニターのアラート条件に設定された関係値。
{{first_triggered_at}}
以下のセクションを参照
モニターが最初にトリガーされた UTC 日時。
{{first_triggered_at_epoch}}
以下のセクションを参照
モニターが最初にトリガーされた UTC 日時(エポックミリ秒)。
{{last_triggered_at}}
以下のセクションを参照
モニターが最後にトリガーされた UTC 日時。
{{last_triggered_at_epoch}}
以下のセクションを参照
モニターが最後にトリガーされた UTC 日時(エポックミリ秒)。
{{triggered_duration_sec}}モニターがトリガー状態になっている秒数。

トリガーされた変数

{{first_triggered_at}}{{first_triggered_at_epoch}}{{last_triggered_at}}{{last_triggered_at_epoch}} というモニターテンプレート変数は、モニターの状態が変わるときの値を反映し、新しいモニターイベントが発生したときの値を反映するわけではありません。モニターの状態が変化していない場合、再通知イベントは同じテンプレート変数を表示します。{{triggered_duration_sec}} を使用して、モニターイベント時の継続時間を表示します。

{{first_triggered_at}} は、モニターグループが OK から OK 以外の状態になったとき、または新しいグループが OK 以外の状態で現れたときに設定されます。{{last_triggered_at}} は、モニターグループがその 1 つ前の状態とは無関係に OK 以外の状態になったときに設定されます (WARNALERTALERTWARN など)。また、{{last_triggered_at}} は、新しいグループが OK 以外の状態で現れたときにも設定されます。違いは、{{last_triggered_at}} がその 1 つ前の状態とは無関係であることです。

状態の遷移をタイムスタンプとともに 4 つ表示。A: 1419 OK から WARN へ、B: 1427 WARN から ALERT へ、C: 1445 ALERT から NO DATA へ、D: 1449 NO DATA から OK へ

: モニターが OKWARN と遷移するとき、{{first_triggered_at}}{{last_triggered_at}} の値のタイムスタンプはどちらも A になります。モニターが回復するまでの値を下表に示します。

遷移first_triggered_atlast_triggered_attriggered_duration_sec
OKWARNAA0
WARNALERTABB - A
ALERTNO DATAACC - A
NO DATAOKACD - A

評価

数値を返すテンプレート変数は、算術演算と関数をサポートしています。これにより、数値の算術演算や値のフォーマット変更を実行できます。詳細については、テンプレート変数の評価を参照してください。

ローカルタイム

local_time 関数を使用して、選択したタイムゾーンで通知に別の日付を追加します。この関数は、日付を現地時間に変換します: {{local_time 'time_variable' 'timezone'}}。 たとえば、通知にモニターの最終トリガー時刻を東京時間で追加するには、通知メッセージに以下を含めます。

{{local_time 'last_triggered_at' 'Asia/Tokyo'}}

結果は、ISO 8601 形式 yyyy-MM-dd HH:mm:ss±HH:mm で表示されます。例: 2021-05-31 23:43:27+09:00。 利用可能なタイムゾーンの値については、tz データベースのタイムゾーンリストで、TZ データベース名の列をご参照ください。

アドバンスド

ダイナミックハンドル

タグ変数を使用して、通知ハンドルを動的に構築し、モニターが検出した問題の種類に基づいて、通知を適切なチームまたはサービスにルーティングします。

: モニターがメトリクスをクエリし、service タグでグループ化すると、失敗したサービスに応じて異なる Slack チャンネルに通知をルーティングさせることができます。

@slack-{{service.name}} There is an ongoing issue with {{service.name}}.

service:ad-server グループでモニターが失敗し始めると、#ad-server Slack チャンネルに以下の内容で通知が送信されます。

@slack-ad-server There is an ongoing issue with ad-server.

常に存在するとは限らない属性を用いて動的ハンドルを構築する場合、通知の配信に問題が生じる可能性があります。属性が欠けている場合、その変数は通知メッセージ内で空としてレンダリングされ、無効なハンドルとなり得ます。

これらの変数を用いた動的ハンドルで通知が失われないよう、フォールバックハンドルを必ず追加してください。

{{#is_match "kube_namespace.owner" ""}}
  @slack-example
{{/is_match}}

ダイナミックリンク

タグ変数を使用して、チームを適切なリソースにリンクする動的 URL 構築を有効にします。たとえば、ダッシュボード、ホストマップ、モニターなどの Datadog 内のページへのリンクを提供できます。

{{host.name}} タグ変数を使用して、システムダッシュボードへのリンクを提供します。

https://app.datadoghq.com/dash/integration/system_overview?tpl_var_scope=host:{{host.name}}

{{host.name}} タグ変数<インテグレーション名> を使用して、インテグレーションダッシュボードへのリンクを提供します。

https://app.datadoghq.com/dash/integration/<インテグレーション名>?tpl_var_scope=host:{{host.name}}

{{last_triggered_at_epoch}} テンプレート変数<DASHBOARD_ID><DASHBOARD_NAME> を使って、警告の瞬間から相対時間範囲を持つダッシュボードにリンクします。

https://app.datadoghq.com/dashboard/<DASHBOARD_ID>/<DASHBOARD_NAME>?from_ts={{eval "last_triggered_at_epoch-10*60*1000"}}&to_ts={{eval "last_triggered_at_epoch+10*60*1000"}}&live=false

ホストマップへのリンクを提供するには、{{service.name}} などのタグ変数を使用します。

https://app.datadoghq.com/infrastructure/map?filter=service:{{service.name}}

ホストマップリンクは、追加のパラメーターを使用してカスタマイズできます。最も一般的なものは次のとおりです。

パラメーター次で定義決定するもの
fillbyfillby=avg:<メトリクス名>ホストの六角形の塗りつぶし色。
groupbygroupby=<タグキー>ホストの六角形のグループ。
sizebysizeby=avg:<メトリクス名>ホストの六角形のサイズ。

{{host.name}} タグ変数を使用して、特定のホストに関連するすべてのモニターへのリンクを提供します。

https://app.datadoghq.com/monitors/manage?q=scope:host:{{host.name}}

モニターリンクは、追加のパラメーターを使用してカスタマイズできます。最も一般的なものは次のとおりです。

パラメーター表示するもの
statusstatus:Alertアラート状態のモニター(追加のステータス: WARNNO DATAOK
mutedmuted: trueミュートされたモニター(ミュートされていないモニターには false を使用)
typetype:logログモニター(他のモニタータイプを参照)

{{last_triggered_at_epoch}} テンプレート変数を使用して、アラートの瞬間に発生しているすべてのログへのリンクを提供します。

https://app.datadoghq.com/logs?from_ts={{eval "last_triggered_at_epoch-10*60*1000"}}&to_ts={{eval "last_triggered_at_epoch+10*60*1000"}}&live=false

ログリンクは、追加のパラメーターを使用してカスタマイズできます。最も一般的なものは次のとおりです。

パラメーター次で定義決定するもの
serviceservice=<SERVICE_NAME>特定のサービスのログをフィルタリングします。
hosthost=<HOST_NAME>特定のホストのログをフィルタリングします
statusstatus=<STATUS>ログステータス: Error、Warn、Info など。

コメント

モニター編集画面にのみ表示されるモニターメッセージにコメントを含めるには、次の構文を使用します。

{{!-- これはコメントです --}}
{{!-- これはコメントです }}

未加工の形式

アラートメッセージで {{ <TEXT> }} などの二重中括弧を送信する必要がある場合は、{{{{raw}}}} 形式を使用します。たとえば、次のとおりです。

{{{{raw}}}}
{{ <テキスト_1> }} {{ <テキスト_2> }}
{{{{/raw}}}}

出力:

{{ <テキスト_1> }} {{ <テキスト_2> }}

条件付き変数で使用されている ^|# ヘルパーは、{{{{raw}}}} 形式と共に使用できず、削除する必要があります。たとえば、{{is_match}} 条件付き変数を使用してテキストをそのまま出力するには、次のテンプレートを使用します。

{{{{is_match "host.name" "<ホスト名>"}}}}
{{ .matched }} ホスト名
{{{{/is_match}}}}

host.name<HOST_NAME> と一致する場合、テンプレートは次を出力します。

{{ .matched }} ホスト名

URL エンコード

アラートメッセージに URL でエンコードする必要がある情報が含まれている場合 (例えば、リダイレクトの場合)、{{ urlencode "<variable>"}} 構文を使います。

: モニターメッセージに特定のサービスにフィルタリングされたサービスカタログへの URL が含まれている場合、service タグ変数を使い、URL に {{ urlencode "<variable>"}} 構文を追加します。

https://app.datadoghq.com/services/{{urlencode "service.name"}}

参考資料