diff --git a/website/content/docs/connect/observability/ui-visualization.mdx b/website/content/docs/connect/observability/ui-visualization.mdx
index 9a9056ff07..63768ff6b8 100644
--- a/website/content/docs/connect/observability/ui-visualization.mdx
+++ b/website/content/docs/connect/observability/ui-visualization.mdx
@@ -66,8 +66,7 @@ service named `prometheus-server` so each Consul agent can reach it on
A full configuration to enable Prometheus is given below.
-
-
+
```hcl
ui_config {
@@ -79,9 +78,6 @@ ui_config {
}
```
-
-
-
```json
{
"ui_config": [
@@ -98,8 +94,7 @@ ui_config {
}
```
-
-
+
Similarly, to configure the UI on Kubernetes, use this [reference](/docs/k8s/connect/observability/metrics).
@@ -120,27 +115,22 @@ to the relevant information.
An example with Grafana is shown below.
-
-
+
+
+
```hcl
ui_config {
enabled = true
dashboard_url_templates {
- service = "https://grafana.example.com/d/lDlaj-NGz/
- service-overview?orgId=1&var-service={{Service.Name}}&
- var-namespace={{Service.Namespace}}&
- var-partition={{Service.Partition}}&var-dc={{Datacenter}}"
+ service = "https://grafana.example.com/d/lDlaj-NGz/service-overview?orgId=1&var-service={{Service.Name}}&var-namespace={{Service.Namespace}}&var-partition={{Service.Partition}}&var-dc={{Datacenter}}"
}
}
```
--> **Note**: the URL is wrapped over multiple lines to make it easier to read
-without horizontal scrolling in the example above however this needs to be a
-normal single-line string value in an HCL configuration file.
+
-
-
+
```json
{
@@ -148,10 +138,7 @@ normal single-line string value in an HCL configuration file.
{
"dashboard_url_templates": [
{
- "service": "https://grafana.example.com/d/lDlaj-NGz/
- service-overview?orgId=1\u0026var-service={{Service.Name}}\u0026
- var-namespace={{Service.Namespace}}\u0026
- var-partition={{Service.Partition}}\u0026var-dc={{Datacenter}}"
+ "service": "https://grafana.example.com/d/lDlaj-NGz/service-overview?orgId=1\u0026var-service={{Service.Name}}\u0026var-namespace={{Service.Namespace}}\u0026var-partition={{Service.Partition}}\u0026var-dc={{Datacenter}}"
}
],
"enabled": true
@@ -160,17 +147,19 @@ normal single-line string value in an HCL configuration file.
}
```
--> **Note**: the URL is wrapped over multiple lines to make it easier to read
-without horizontal scrolling in the example above however this needs to be a
-normal single-line string value in a JSON configuration file.
+
-
-
-
-On Kubernetes, Consul Server configuration is set in your Helm config via the
-[`server.extraConfig`](/docs/k8s/helm#v-server-extraconfig) key as JSON:
+
```yaml
+################################### Notes: ####################################
+# On Kubernetes, Consul Server configuration is set in your Helm config via #
+# the server.extraConfig key as JSON. #
+# #
+# The `{{` characters in the URL must be escaped using `{{ "{{" }}` so that #
+# Helm doesn't try to template them. #
+###############################################################################
+
# The UI is enabled by default so this stanza is not required.
ui:
enabled: true
@@ -185,10 +174,9 @@ server:
}
```
--> **Note**: The `{{` characters in the URL must be escaped using `{{ "{{" }}` so that Helm doesn't try to template them.
+
-
-
+
![Consul UI Service Dashboard Link](/img/ui-dashboard-url-template.png)
@@ -221,6 +209,8 @@ un-authenticated workloads on the network**.
With ACLs enabled, the proxy endpoint requires a valid token with read access
to all nodes and services (across all namespaces in Enterprise):
+
+
```hcl
# Consul OSS
service_prefix "" {
@@ -241,6 +231,8 @@ namespace_prefix "" {
}
```
+
+
It's typical for most authenticated users to have this level of access in Consul
as it's required for viewing the catalog or discovering services. If you use a
[Single Sign-On integration](/docs/security/acl/auth-methods/oidc) (Consul
@@ -285,8 +277,7 @@ visible to Consul operators in the configuration file while UI users can query
the metrics they need without separately obtaining a token for that provider or
having a token exposed to them that they might be able to use elsewhere.
-
-
+
```hcl
ui_config {
@@ -304,9 +295,6 @@ ui_config {
}
```
-
-
-
```json
{
"ui_config": [
@@ -329,8 +317,7 @@ ui_config {
}
```
-
-
+
## Custom Metrics Providers
@@ -347,6 +334,8 @@ feedback on [GitHub](https://github.com/hashicorp/consul) or
The template for a complete provider JavaScript file is given below.
+
+
```JavaScript
(function () {
var provider = {
@@ -553,6 +542,8 @@ The template for a complete provider JavaScript file is given below.
}());
```
+
+
Additionally, the built in [Prometheus
provider code](https://github.com/hashicorp/consul/blob/main/ui/packages/consul-ui/vendor/metrics-providers/prometheus.js)
can be used as a reference.
@@ -565,8 +556,7 @@ named `example-provider`, which is defined in
have been specified in the call to `consul.registerMetricsProvider` as in the
code listing in the last section.
-
-
+
```hcl
ui_config {
@@ -581,9 +571,6 @@ ui_config {
}
```
-
-
-
```json
{
"ui_config": {
@@ -595,8 +582,7 @@ ui_config {
}
```
-
-
+
More than one JavaScript file may be specified in
[`metrics_provider_files`](/docs/agent/options#ui_config_metrics_provider_files)