The helm chart installs Telemetry-Core, Telemetry-Shard and Telemetry-Frontend services.
Name | Url | |
---|---|---|
Parity | [email protected] | https://github.com/paritytech/helm-charts |
Substrate-Telemetry Github repo lives in https://github.com/paritytech/substrate-telemetry.
helm repo add parity https://paritytech.github.io/helm-charts/
helm repo update
helm install substrate-telemetry parity/substrate-telemetry
By default, the type of Kubernetes service used for Telemetry-Core, Telemetry-Shard and Telemetry-Frontend is ClusterIP
, so they're not accessible from outside of the k8s cluster. Consider exposing all of the services using service of type LoadBalancer
or using an ingress controller:
- Frontend: This is the frontend web application for the backend services.
- Shard: Polkadot/Substrate nodes will submit their statistics to the
/submit
endpoint of theShard
service. It's recommended to only expose/submit
endpoint. - Core: This is where all of the data would be stored. The
/feed
should only be exposed to the public network as other endpoints might expose sensitive information about the nodes.
Notes:
- All the services must be exposed over
HTTPS
. - The
Core
service could also be exposed using theFrontend
Nginx service. The Nginx configuration should be tweaked for this purpose. - Consider setting
.Values.envVars.frontend.SUBSTRATE_TELEMETRY_URL
variable otherwise the web clients wouldn't be able to find theCore
service address.
Key | Type | Default | Description |
---|---|---|---|
affinity | object | {} |
Assign custom affinity rules |
autoscaling | object | {"core":{"enabled":false},"frontend":{"enabled":false,"maxReplicas":6,"minReplicas":1,"targetCPUUtilizationPercentage":80},"shard":{"enabled":false,"maxReplicas":6,"minReplicas":2,"targetCPUUtilizationPercentage":80}} |
Autoscaling configuration |
autoscaling.core | object | {"enabled":false} |
Autoscaling configuration for the Core service |
autoscaling.core.enabled | bool | false |
Enables autoscaling |
autoscaling.frontend | object | {"enabled":false,"maxReplicas":6,"minReplicas":1,"targetCPUUtilizationPercentage":80} |
Autoscaling configuration for the Frontend service |
autoscaling.frontend.enabled | bool | false |
Enables autoscaling |
autoscaling.frontend.maxReplicas | int | 6 |
Maximum number of replicas |
autoscaling.frontend.minReplicas | int | 1 |
Minimum number of replicas |
autoscaling.frontend.targetCPUUtilizationPercentage | int | 80 |
Target CPU utilization percentage |
autoscaling.shard | object | {"enabled":false,"maxReplicas":6,"minReplicas":2,"targetCPUUtilizationPercentage":80} |
Autoscaling configuration for the Shard service NOTE: The core service is not scalable at the moment. |
autoscaling.shard.enabled | bool | false |
Enables autoscaling |
autoscaling.shard.maxReplicas | int | 6 |
Maximum number of replicas |
autoscaling.shard.minReplicas | int | 2 |
Minimum number of replicas |
autoscaling.shard.targetCPUUtilizationPercentage | int | 80 |
Target CPU utilization percentage |
envVars | object | {"core":{},"frontend":{"SUBSTRATE_TELEMETRY_URL":"wss://core-service-domain.com"},"shard":{}} |
Environment variables to set on the main containers |
envVars.core | object | {} |
Environment variables to set on the core service |
envVars.frontend | object | {"SUBSTRATE_TELEMETRY_URL":"wss://core-service-domain.com"} |
Environment variables to set on the frontend service |
envVars.frontend.SUBSTRATE_TELEMETRY_URL | string | "wss://core-service-domain.com" |
The frontend docker container makes this available to the UI, so that it knows where to look for feed information: |
envVars.shard | object | {} |
Environment variables to set on the shard service |
extraArgs | object | {"core":{},"shard":{}} |
Extra arguments to pass to the services |
extraArgs.core | object | {} |
Extra arguments to pass to the core service |
extraArgs.shard | object | {} |
Extra arguments to pass to the shard service |
fullnameOverride | string | "" |
Provide a name to substitute for the full names of resources |
image | object | {"backend":{"pullPolicy":"IfNotPresent","repository":"docker.io/parity/substrate-telemetry-backend","tag":"latest"},"frontend":{"pullPolicy":"IfNotPresent","repository":"docker.io/parity/substrate-telemetry-frontend","tag":"latest"}} |
Image to use for the service |
image.backend | object | {"pullPolicy":"IfNotPresent","repository":"docker.io/parity/substrate-telemetry-backend","tag":"latest"} |
Image for the backend service |
image.backend.pullPolicy | string | "IfNotPresent" |
Image pull policy |
image.backend.repository | string | "docker.io/parity/substrate-telemetry-backend" |
Image repository |
image.backend.tag | string | "latest" |
Image tag |
image.frontend | object | {"pullPolicy":"IfNotPresent","repository":"docker.io/parity/substrate-telemetry-frontend","tag":"latest"} |
Image for the frontend service |
image.frontend.pullPolicy | string | "IfNotPresent" |
Image pull policy |
image.frontend.repository | string | "docker.io/parity/substrate-telemetry-frontend" |
Image repository |
image.frontend.tag | string | "latest" |
Image tag |
imagePullSecrets | list | [] |
Reference to one or more secrets to be used when pulling images. ref: https://kubernetes.io/docs/tasks/configure-pod-container/pull-image-private-registry/ |
ingress | object | {"core":{"annotations":{},"className":"","enabled":false,"rules":[{"host":"feed.example.local","http":{"paths":[{"backend":{"service":{"name":"telemetry-core","port":{"number":80}}},"path":"/feed","pathType":"Exact"},{"backend":{"service":{"name":"telemetry-core","port":{"number":80}}},"path":"/feed/","pathType":"Exact"}]}}],"tls":[{"hosts":["feed.example.local"],"secretName":"feed.example.local"}]},"frontend":{"annotations":null,"className":"","enabled":false,"rules":[{"host":"example.local","http":{"paths":[{"backend":{"service":{"name":"telemetry-frontend","port":{"number":80}}},"path":"/","pathType":"Prefix"}]}}],"tls":[{"hosts":["example.local"],"secretName":"example.local"}]},"shard":{"annotations":{},"className":"","enabled":false,"rules":[{"host":"shard.example.local","http":{"paths":[{"backend":{"service":{"name":"telemetry-shard","port":{"number":80}}},"path":"/submit","pathType":"Exact"},{"backend":{"service":{"name":"telemetry-shard","port":{"number":80}}},"path":"/submit/","pathType":"Exact"}]}}],"tls":[{"hosts":["shard.example.local"],"secretName":"shard.example.local"}]}} |
Creates an ingress resource |
ingress.core | object | {"annotations":{},"className":"","enabled":false,"rules":[{"host":"feed.example.local","http":{"paths":[{"backend":{"service":{"name":"telemetry-core","port":{"number":80}}},"path":"/feed","pathType":"Exact"},{"backend":{"service":{"name":"telemetry-core","port":{"number":80}}},"path":"/feed/","pathType":"Exact"}]}}],"tls":[{"hosts":["feed.example.local"],"secretName":"feed.example.local"}]} |
Ingress configuration for the Core service |
ingress.core.annotations | object | {} |
Annotations to add to the Ingress |
ingress.core.className | string | "" |
Ingress class name |
ingress.core.enabled | bool | false |
Enable Ingress for the Core service |
ingress.core.rules | list | [{"host":"feed.example.local","http":{"paths":[{"backend":{"service":{"name":"telemetry-core","port":{"number":80}}},"path":"/feed","pathType":"Exact"},{"backend":{"service":{"name":"telemetry-core","port":{"number":80}}},"path":"/feed/","pathType":"Exact"}]}}] |
A list of hosts for the Ingress |
ingress.core.tls | list | [{"hosts":["feed.example.local"],"secretName":"feed.example.local"}] |
Ingress TLS configuration |
ingress.core.tls[0] | object | {"hosts":["feed.example.local"],"secretName":"feed.example.local"} |
Secret name for the TLS certificate |
ingress.core.tls[0].hosts | list | ["feed.example.local"] |
A list of hosts for the Ingress with TLS enabled |
ingress.frontend | object | {"annotations":null,"className":"","enabled":false,"rules":[{"host":"example.local","http":{"paths":[{"backend":{"service":{"name":"telemetry-frontend","port":{"number":80}}},"path":"/","pathType":"Prefix"}]}}],"tls":[{"hosts":["example.local"],"secretName":"example.local"}]} |
Ingress configuration for the Frontend service |
ingress.frontend.annotations | string | nil |
Annotations to add to the Ingress |
ingress.frontend.className | string | "" |
Ingress class name |
ingress.frontend.enabled | bool | false |
Enable Ingress for the Frontend service |
ingress.frontend.rules | list | [{"host":"example.local","http":{"paths":[{"backend":{"service":{"name":"telemetry-frontend","port":{"number":80}}},"path":"/","pathType":"Prefix"}]}}] |
A list of hosts for the Ingress |
ingress.frontend.tls | list | [{"hosts":["example.local"],"secretName":"example.local"}] |
Ingress TLS configuration |
ingress.frontend.tls[0] | object | {"hosts":["example.local"],"secretName":"example.local"} |
Secret name for the TLS certificate |
ingress.frontend.tls[0].hosts | list | ["example.local"] |
A list of hosts for the Ingress with TLS enabled |
ingress.shard | object | {"annotations":{},"className":"","enabled":false,"rules":[{"host":"shard.example.local","http":{"paths":[{"backend":{"service":{"name":"telemetry-shard","port":{"number":80}}},"path":"/submit","pathType":"Exact"},{"backend":{"service":{"name":"telemetry-shard","port":{"number":80}}},"path":"/submit/","pathType":"Exact"}]}}],"tls":[{"hosts":["shard.example.local"],"secretName":"shard.example.local"}]} |
Ingress configuration for the Shard service |
ingress.shard.annotations | object | {} |
Annotations to add to the Ingress |
ingress.shard.className | string | "" |
Ingress class name |
ingress.shard.enabled | bool | false |
Enable Ingress for the Shard service |
ingress.shard.rules | list | [{"host":"shard.example.local","http":{"paths":[{"backend":{"service":{"name":"telemetry-shard","port":{"number":80}}},"path":"/submit","pathType":"Exact"},{"backend":{"service":{"name":"telemetry-shard","port":{"number":80}}},"path":"/submit/","pathType":"Exact"}]}}] |
A list of hosts for the Ingress |
ingress.shard.tls | list | [{"hosts":["shard.example.local"],"secretName":"shard.example.local"}] |
Ingress TLS configuration |
ingress.shard.tls[0] | object | {"hosts":["shard.example.local"],"secretName":"shard.example.local"} |
Secret name for the TLS certificate |
ingress.shard.tls[0].hosts | list | ["shard.example.local"] |
A list of hosts for the Ingress with TLS enabled |
nameOverride | string | "" |
Provide a name in place of node for app: labels |
nodeSelector | object | {} |
Define which Nodes the Pods are scheduled on |
podAnnotations | object | {} |
Annotations to add to the Pod |
podSecurityContext | object | {} |
SecurityContext holds pod-level security attributes and common container settings. ref: https://kubernetes.io/docs/tasks/configure-pod-container/security-context/ |
replicaCount | object | {"core":1,"frontend":1,"shard":1} |
Number of replicas to deploy |
replicaCount.core | int | 1 |
Number of Core service replicas |
replicaCount.frontend | int | 1 |
Number of Frontend service replicas |
replicaCount.shard | int | 1 |
Number of Shard service replicas NOTE: The core service is not scalable at the moment. |
resources | object | {"core":{},"frontend":{},"shard":{}} |
Resource limits & requests |
resources.core | object | {} |
Resource limits & requests for the Core service |
resources.frontend | object | {} |
Resource limits & requests for the Frontend service |
resources.shard | object | {} |
Resource limits & requests for the Shard service |
securityContext | object | {} |
SecurityContext settings |
service | object | {"core":{"annotations":{},"port":80,"targetPort":8000,"type":"ClusterIP"},"frontend":{"annotations":{},"port":80,"targetPort":8000,"type":"ClusterIP"},"shard":{"annotations":{},"port":80,"targetPort":8000,"type":"ClusterIP"}} |
Configration of the Service |
service.core | object | {"annotations":{},"port":80,"targetPort":8000,"type":"ClusterIP"} |
Configration of the Service for the Core service |
service.core.annotations | object | {} |
Additional annotations to assign to the Service object |
service.core.port | int | 80 |
Service port to expose |
service.core.targetPort | int | 8000 |
A port of the service where the traffic is forwarded |
service.core.type | string | "ClusterIP" |
Service type |
service.frontend | object | {"annotations":{},"port":80,"targetPort":8000,"type":"ClusterIP"} |
Configration of the Service for the Frontend service |
service.frontend.annotations | object | {} |
Additional annotations to assign to the Service object |
service.frontend.port | int | 80 |
Service port to expose |
service.frontend.targetPort | int | 8000 |
A port of the service where the traffic is forwarded |
service.frontend.type | string | "ClusterIP" |
Service type |
service.shard | object | {"annotations":{},"port":80,"targetPort":8000,"type":"ClusterIP"} |
Configration of the Service for the Shard service |
service.shard.annotations | object | {} |
Additional annotations to assign to the Service object |
service.shard.port | int | 80 |
Service port to expose |
service.shard.targetPort | int | 8000 |
A port of the service where the traffic is forwarded |
service.shard.type | string | "ClusterIP" |
Service type |
serviceAccount | object | {"annotations":{},"create":true,"name":""} |
Service account for the node to use. ref: https://kubernetes.io/docs/tasks/configure-pod-container/configure-service-account/ |
serviceAccount.annotations | object | {} |
Annotations to add to the Service Account |
serviceAccount.create | bool | true |
Enable creation of a Service Account for the main container |
serviceAccount.name | string | "" |
The name of the service account to use. If not set and create is true, a name is generated using the fullname template |
serviceMonitor | object | {"core":{"additionalLabels":{},"annotations":{},"enabled":false,"interval":"","scrapeTimeout":"10s"}} |
Service Monitor of Prometheus-Operator ref: https://github.com/prometheus-operator/prometheus-operator/blob/main/Documentation/user-guides/getting-started.md#include-servicemonitors |
serviceMonitor.core | object | {"additionalLabels":{},"annotations":{},"enabled":false,"interval":"","scrapeTimeout":"10s"} |
Expose ServiceMonitor on the core service Only core service has Prometheus metrics exposed at the moment. |
serviceMonitor.core.additionalLabels | object | {} |
Additional labels to assign to the ServiceMonitor |
serviceMonitor.core.annotations | object | {} |
Annotations to assign to the ServiceMonitor |
serviceMonitor.core.enabled | bool | false |
Enables Service Monitor |
serviceMonitor.core.interval | string | "" |
Scrape interval |
serviceMonitor.core.scrapeTimeout | string | "10s" |
Scrape timeout |
tolerations | list | [] |
Tolerations for use with node taints |
Autogenerated from chart metadata using helm-docs v1.11.0