From 849b785593d50b124fb4e27197e6167c66c0c476 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=E2=80=9Cnico-shishkin=E2=80=9D?= <“nicoshishkinatlogz@outlook.com”> Date: Tue, 28 Nov 2023 12:25:17 +0100 Subject: [PATCH] DOC-730 --- docs/_include/general-shipping/k8s.md | 243 +++++++++++++++++ docs/shipping/Containers/kubernetes.md | 244 +----------------- docs/user-guide/k8s-360/unified-helm-chart.md | 187 +------------- 3 files changed, 245 insertions(+), 429 deletions(-) create mode 100644 docs/_include/general-shipping/k8s.md diff --git a/docs/_include/general-shipping/k8s.md b/docs/_include/general-shipping/k8s.md new file mode 100644 index 00000000..5ab509d2 --- /dev/null +++ b/docs/_include/general-shipping/k8s.md @@ -0,0 +1,243 @@ + + + + +The logzio-monitoring Helm Chart ships your Kubernetes telemetry (logs, metrics, traces and security reports) to your Logz.io account. + +## Prerequisites + +1. [Helm](https://helm.sh/) + +Add Logzio-helm repository + +```sh +helm repo add logzio-helm https://logzio.github.io/logzio-helm && helm repo update +``` +{@include: ../../_include/general-shipping/k8s-all-data.md} + +## Send your logs + +```sh +helm install -n monitoring \ +--set logs.enabled=true \ +--set logzio-fluentd.secrets.logzioShippingToken="<>" \ +--set logzio-fluentd.secrets.logzioListener="<>" \ +--set logzio-fluentd.env_id="<>" \ +logzio-monitoring logzio-helm/logzio-monitoring +``` + + +| Parameter | Description | +| --- | --- | +| `<>` | Your [logs shipping token](https://app.logz.io/#/dashboard/settings/general). | +| `<>` | Your account's [listener host](https://app.logz.io/#/dashboard/settings/manage-tokens/data-shipping?product=logs). | +| `<>` | The cluster's name, to easily identify the telemetry data for each environment. | + + +For log shipping troubleshooting, see our [user guide](https://docs.logz.io/user-guide/kubernetes-troubleshooting/). + +## Send your deploy events logs + +This integration sends data about deployment events in the cluster, and how they affect the cluster's resources. +Currently supported resource kinds are `Deployment`, `Daemonset`, `Statefulset`, `ConfigMap`, `Secret`, `Service Account`, `Cluster Role` and `Cluster Role Binding`. + +```sh +helm install --namespace=monitoring \ +--set logzio-k8s-events.secrets.logzioShippingToken='<>' \ +--set logzio-k8s-events.secrets.logzioListener='<>' \ +--set logzio-k8s-events.secrets.env_id='<>' \ +--set logzio-k8s-events.secrets.customListener='<>' \ +logzio-monitoring logzio-helm/logzio-monitoring + +``` + + +| Parameter | Description | +| --- | --- | +| `<>` | Your [logs shipping token](https://app.logz.io/#/dashboard/settings/general). | +| `<>` | Your account's [listener host](https://app.logz.io/#/dashboard/settings/manage-tokens/data-shipping?product=logs). | +| `<>` | The cluster's name, to easily identify the telemetry data for each environment. | +| `<>` | (*optional*) HTTP/s listener endpoint that receives JSON input, overrides the Logz.io listener. | + +### Deployment Events Versioning + +In order to add an indication for the versioning in our K8S 360 and Service Overview UI, the following annotation should be added to the metadata of each resource you'd like to track its versioning. +Commit URL structure: `https://github.com///commit/` + +Example: `https://github.com/logzio/logzio-k8s-events/commit/069c75c95caeca58dd0776405bb8dfb4eed3acb2` + +```yaml +metadata: + annotations: + logzio/commit_url: "" +``` + + +For log shipping troubleshooting, see our [user guide](https://docs.logz.io/user-guide/kubernetes-troubleshooting/). + +## Send your Metrics + +```sh +helm install -n monitoring \ +--set metricsOrTraces.enabled=true \ +--set logzio-k8s-telemetry.metrics.enabled=true \ +--set logzio-k8s-telemetry.secrets.MetricsToken="<>" \ +--set logzio-k8s-telemetry.secrets.ListenerHost="https://<>:8053" \ +--set logzio-k8s-telemetry.secrets.p8s_logzio_name="<>" \ +--set logzio-k8s-telemetry.secrets.env_id="<>" \ +logzio-monitoring logzio-helm/logzio-monitoring +``` + +| Parameter | Description | +| --- | --- | +| `<>` | Your [metrics shipping token](https://app.logz.io/#/dashboard/settings/manage-tokens/data-shipping). | +| `<>` | The cluster's name, to easily identify the telemetry data for each environment. | +| `<>` | Your account's [listener host](https://app.logz.io/#/dashboard/settings/manage-tokens/data-shipping?product=logs). | + + +For metrics shipping troubleshooting, see our [user guide](https://docs.logz.io/user-guide/infrastructure-monitoring/troubleshooting/k8-helm-opentelemetry-troubleshooting.html). + + + +## Send your traces + +```sh +helm install -n monitoring \ +--set metricsOrTraces.enabled=true \ +--set logzio-k8s-telemetry.traces.enabled=true \ +--set logzio-k8s-telemetry.secrets.TracesToken="<>" \ +--set logzio-k8s-telemetry.secrets.LogzioRegion="<>" \ +--set logzio-k8s-telemetry.secrets.env_id="<>" \ +logzio-monitoring logzio-helm/logzio-monitoring +``` + +| Parameter | Description | +| --- | --- | +| `<>` | Your [traces shipping token](https://app.logz.io/#/dashboard/settings/manage-tokens/data-shipping?product=tracing). | +| `<>` | The cluster's name, to easily identify the telemetry data for each environment. | +| `<>` | Name of your Logz.io traces region e.g `us`, `eu`... | + + +For traces shipping troubleshooting, see our [user guide]([https://docs.logz.io/user-guide/kubernetes-troubleshooting/](https://docs.logz.io/user-guide/distributed-tracing/tracing-troubleshooting.html)). + + +## Send traces with SPM + +```sh +helm install -n monitoring \ +--set metricsOrTraces.enabled=true \ +--set logzio-k8s-telemetry.traces.enabled=true \ +--set logzio-k8s-telemetry.secrets.TracesToken="<>" \ +--set logzio-k8s-telemetry.secrets.LogzioRegion="<>" \ +--set logzio-k8s-telemetry.secrets.env_id="<>" \ +--set logzio-k8s-telemetry.spm.enabled=true \ +--set logzio-k8s-telemetry.secrets.SpmToken=<> \ +logzio-monitoring logzio-helm/logzio-monitoring +``` + +| Parameter | Description | +| --- | --- | +| `<>` | Your [traces shipping token](https://app.logz.io/#/dashboard/settings/manage-tokens/data-shipping). | +| `<>` | The cluster's name, to easily identify the telemetry data for each environment. | +| `<>` | Your account's [listener host](https://app.logz.io/#/dashboard/settings/manage-tokens/data-shipping?product=logs). | +| `<>` | Name of your Logz.io traces region e.g `us`, `eu`... | +| `<>` | Your [span metrics shipping token](https://app.logz.io/#/dashboard/settings/manage-tokens/data-shipping). | + + +## Scan your cluster for security vulnerabilities + +```sh +helm install -n monitoring \ +--set securityReport.enabled=true \ +--set logzio-trivy.env_id="<>" \ +--set logzio-trivy.secrets.logzioShippingToken="<>" \ +--set logzio-trivy.secrets.logzioListener="<>" \ +``` + +| Parameter | Description | +| --- | --- | +| `<>` | Your [logs shipping token](https://app.logz.io/#/dashboard/settings/general). | +| `<>` | Your account's [listener host](https://app.logz.io/#/dashboard/settings/manage-tokens/data-shipping?product=logs). | +| `<>` | The cluster's name, to easily identify the telemetry data for each environment. | + + +## Modifying the configuration for logs + +You can see a full list of the possible configuration values in the [logzio-fluentd Chart folder](https://github.com/logzio/logzio-helm/tree/master/charts/fluentd#configuration). + +If you would like to modify any of the values found in the `logzio-fluentd` folder, use the `--set` flag with the `logzio-fluentd` prefix. + +For instance, if there is a parameter called `someField` in the `logzio-telemetry`'s `values.yaml` file, you can set it by adding the following to the `helm install` command: + +```sh +--set logzio-fluentd.someField="my new value" +``` +You can add `log_type` annotation with a custom value, which will be parsed into a `log_type` field with the same value. + + +### Modifying the configuration for metrics and traces + +You can see a full list of the possible configuration values in the [logzio-telemetry Chart folder](https://github.com/logzio/logzio-helm/tree/master/charts/logzio-telemetry). + +If you would like to modify any of the values found in the `logzio-telemetry` folder, use the `--set` flag with the `logzio-k8s-telemetry` prefix. + +For instance, if there is a parameter called `someField` in the `logzio-telemetry`'s `values.yaml` file, you can set it by adding the following to the `helm install` command: + + +```sh +--set logzio-k8s-telemetry.someField="my new value" +``` + +## Sending telemetry data from eks on fargate + +To ship logs from pods running on Fargate, set the `fargateLogRouter.enabled` value to `true`. Doing so will deploy a dedicated `aws-observability` namespace and a `configmap` for the Fargate log router. For more information on EKS Fargate logging, please refer to the [official AWS documentation]((https://docs.aws.amazon.com/eks/latest/userguide/fargate-logging.html). + +```shell +helm install -n monitoring \ +--set logs.enabled=true \ +--set logzio-fluentd.fargateLogRouter.enabled=true \ +--set logzio-fluentd.secrets.logzioShippingToken="<>" \ +--set logzio-fluentd.secrets.logzioListener="<>" \ +--set metricsOrTraces.enabled=true \ +--set logzio-k8s-telemetry.metrics.enabled=true \ +--set logzio-k8s-telemetry.secrets.MetricsToken="<>" \ +--set logzio-k8s-telemetry.secrets.ListenerHost="https://<>:8053" \ +--set logzio-k8s-telemetry.secrets.p8s_logzio_name="<>" \ +--set logzio-k8s-telemetry.traces.enabled=true \ +--set logzio-k8s-telemetry.secrets.TracesToken="<>" \ +--set logzio-k8s-telemetry.secrets.LogzioRegion="<>" \ +logzio-monitoring logzio-helm/logzio-monitoring +``` + +| Parameter | Description | +| --- | --- | +| `<>` | Your [logs shipping token](https://app.logz.io/#/dashboard/settings/manage-tokens/data-shipping?product=logs). | +| `<>` | Your account's [listener host](https://app.logz.io/#/dashboard/settings/manage-tokens/data-shipping?product=logs). | +| `<>` | Your [metrics shipping token](https://app.logz.io/#/dashboard/settings/manage-tokens/data-shipping?product=metrics). | +| `<>` | The name for the environment's metrics, to easily identify the metrics for each environment. | +| `<>` | The name for your environment's identifier, to easily identify the telemetry data for each environment. | +| `<>` | Your custom name for the environment's metrics, to easily identify the metrics for each environment. | +| `<>` | Replace `<>` with the [token](https://app.logz.io/#/dashboard/settings/manage-tokens/data-shipping?product=tracing) of the account you want to ship to. | +| `<>` | Name of your Logz.io traces region e.g `us` or `eu`. You can find your region code in the [Regions and URLs](https://docs.logz.io/user-guide/accounts/account-region.html#regions-and-urls) table. | + +## Handling image pull rate limit + +In certain situations, such as with spot clusters where pods/nodes are frequently replaced, you may encounter the pull rate limit for images fetched from Docker Hub. This could result in the following error: `You have reached your pull rate limit. You may increase the limit by authenticating and upgrading: https://www.docker.com/increase-rate-limits`. + +To address this issue, you can use the `--set` commands provided below in order to access an alternative image repository: + +```shell +--set logzio-k8s-telemetry.image.repository=ghcr.io/open-telemetry/opentelemetry-collector-releases/opentelemetry-collector-contrib +--set logzio-k8s-telemetry.prometheus-pushgateway.image.repository=public.ecr.aws/logzio/prom-pushgateway +--set logzio-fluentd.image=public.ecr.aws/logzio/logzio-fluentd +--set logzio-fluentd.daemonset.init.containerImage=public.ecr.aws/docker/library/busybox +--set logzio-trivy.image=public.ecr.aws/logzio/trivy-to-logzio +``` + +## Upgrade logzio-monitoring to v3.0.0 + +Before upgrading your logzio-monitoring Chart to v3.0.0 with `helm upgrade`, note that you may encounter an error for some of the logzio-telemetry sub-charts. + +There are two possible approaches to the upgrade you can choose from: +- Reinstall the chart. +- Before running the `helm upgrade` command, delete the old subcharts resources: `logzio-monitoring-prometheus-pushgateway` deployment and the `logzio-monitoring-prometheus-node-exporter` daemonset. diff --git a/docs/shipping/Containers/kubernetes.md b/docs/shipping/Containers/kubernetes.md index 025e223d..378a6948 100644 --- a/docs/shipping/Containers/kubernetes.md +++ b/docs/shipping/Containers/kubernetes.md @@ -14,246 +14,4 @@ metrics_alerts: ['5Ng398K19vXP9197bRV1If'] drop_filter: [] --- - - - - -The logzio-monitoring Helm Chart ships your Kubernetes telemetry (logs, metrics, traces and security reports) to your Logz.io account. - -## Prerequisites - -1. [Helm](https://helm.sh/) - -Add Logzio-helm repository - -```sh -helm repo add logzio-helm https://logzio.github.io/logzio-helm && helm repo update -``` -{@include: ../../_include/general-shipping/k8s-all-data.md} - -## Send your logs - -```sh -helm install -n monitoring \ ---set logs.enabled=true \ ---set logzio-fluentd.secrets.logzioShippingToken="<>" \ ---set logzio-fluentd.secrets.logzioListener="<>" \ ---set logzio-fluentd.env_id="<>" \ -logzio-monitoring logzio-helm/logzio-monitoring -``` - - -| Parameter | Description | -| --- | --- | -| `<>` | Your [logs shipping token](https://app.logz.io/#/dashboard/settings/general). | -| `<>` | Your account's [listener host](https://app.logz.io/#/dashboard/settings/manage-tokens/data-shipping?product=logs). | -| `<>` | The cluster's name, to easily identify the telemetry data for each environment. | - - -For log shipping troubleshooting, see our [user guide](https://docs.logz.io/user-guide/kubernetes-troubleshooting/). - -## Send your deploy events logs - -This integration sends data about deployment events in the cluster, and how they affect the cluster's resources. -Currently supported resource kinds are `Deployment`, `Daemonset`, `Statefulset`, `ConfigMap`, `Secret`, `Service Account`, `Cluster Role` and `Cluster Role Binding`. - -```sh -helm install --namespace=monitoring \ ---set logzio-k8s-events.secrets.logzioShippingToken='<>' \ ---set logzio-k8s-events.secrets.logzioListener='<>' \ ---set logzio-k8s-events.secrets.env_id='<>' \ ---set logzio-k8s-events.secrets.customListener='<>' \ -logzio-monitoring logzio-helm/logzio-monitoring - -``` - - -| Parameter | Description | -| --- | --- | -| `<>` | Your [logs shipping token](https://app.logz.io/#/dashboard/settings/general). | -| `<>` | Your account's [listener host](https://app.logz.io/#/dashboard/settings/manage-tokens/data-shipping?product=logs). | -| `<>` | The cluster's name, to easily identify the telemetry data for each environment. | -| `<>` | (*optional*) HTTP/s listener endpoint that receives JSON input, overrides the Logz.io listener. | - -### Deployment Events Versioning - -In order to add an indication for the versioning in our K8S 360 and Service Overview UI, the following annotation should be added to the metadata of each resource you'd like to track its versioning. -Commit URL structure: `https://github.com///commit/` - -Example: `https://github.com/logzio/logzio-k8s-events/commit/069c75c95caeca58dd0776405bb8dfb4eed3acb2` - -```yaml -metadata: - annotations: - logzio/commit_url: "" -``` - - -For log shipping troubleshooting, see our [user guide](https://docs.logz.io/user-guide/kubernetes-troubleshooting/). - -## Send your Metrics - -```sh -helm install -n monitoring \ ---set metricsOrTraces.enabled=true \ ---set logzio-k8s-telemetry.metrics.enabled=true \ ---set logzio-k8s-telemetry.secrets.MetricsToken="<>" \ ---set logzio-k8s-telemetry.secrets.ListenerHost="https://<>:8053" \ ---set logzio-k8s-telemetry.secrets.p8s_logzio_name="<>" \ ---set logzio-k8s-telemetry.secrets.env_id="<>" \ -logzio-monitoring logzio-helm/logzio-monitoring -``` - -| Parameter | Description | -| --- | --- | -| `<>` | Your [metrics shipping token](https://app.logz.io/#/dashboard/settings/manage-tokens/data-shipping). | -| `<>` | The cluster's name, to easily identify the telemetry data for each environment. | -| `<>` | Your account's [listener host](https://app.logz.io/#/dashboard/settings/manage-tokens/data-shipping?product=logs). | - - -For metrics shipping troubleshooting, see our [user guide](https://docs.logz.io/user-guide/infrastructure-monitoring/troubleshooting/k8-helm-opentelemetry-troubleshooting.html). - - - -## Send your traces - -```sh -helm install -n monitoring \ ---set metricsOrTraces.enabled=true \ ---set logzio-k8s-telemetry.traces.enabled=true \ ---set logzio-k8s-telemetry.secrets.TracesToken="<>" \ ---set logzio-k8s-telemetry.secrets.LogzioRegion="<>" \ ---set logzio-k8s-telemetry.secrets.env_id="<>" \ -logzio-monitoring logzio-helm/logzio-monitoring -``` - -| Parameter | Description | -| --- | --- | -| `<>` | Your [traces shipping token](https://app.logz.io/#/dashboard/settings/manage-tokens/data-shipping?product=tracing). | -| `<>` | The cluster's name, to easily identify the telemetry data for each environment. | -| `<>` | Name of your Logz.io traces region e.g `us`, `eu`... | - - -For traces shipping troubleshooting, see our [user guide]([https://docs.logz.io/user-guide/kubernetes-troubleshooting/](https://docs.logz.io/user-guide/distributed-tracing/tracing-troubleshooting.html)). - - -## Send traces with SPM - -```sh -helm install -n monitoring \ ---set metricsOrTraces.enabled=true \ ---set logzio-k8s-telemetry.traces.enabled=true \ ---set logzio-k8s-telemetry.secrets.TracesToken="<>" \ ---set logzio-k8s-telemetry.secrets.LogzioRegion="<>" \ ---set logzio-k8s-telemetry.secrets.env_id="<>" \ ---set logzio-k8s-telemetry.spm.enabled=true \ ---set logzio-k8s-telemetry.secrets.SpmToken=<> \ -logzio-monitoring logzio-helm/logzio-monitoring -``` - -| Parameter | Description | -| --- | --- | -| `<>` | Your [traces shipping token](https://app.logz.io/#/dashboard/settings/manage-tokens/data-shipping). | -| `<>` | The cluster's name, to easily identify the telemetry data for each environment. | -| `<>` | Your account's [listener host](https://app.logz.io/#/dashboard/settings/manage-tokens/data-shipping?product=logs). | -| `<>` | Name of your Logz.io traces region e.g `us`, `eu`... | -| `<>` | Your [span metrics shipping token](https://app.logz.io/#/dashboard/settings/manage-tokens/data-shipping). | - - -## Scan your cluster for security vulnerabilities - -```sh -helm install -n monitoring \ ---set securityReport.enabled=true \ ---set logzio-trivy.env_id="<>" \ ---set logzio-trivy.secrets.logzioShippingToken="<>" \ ---set logzio-trivy.secrets.logzioListener="<>" \ -``` - -| Parameter | Description | -| --- | --- | -| `<>` | Your [logs shipping token](https://app.logz.io/#/dashboard/settings/general). | -| `<>` | Your account's [listener host](https://app.logz.io/#/dashboard/settings/manage-tokens/data-shipping?product=logs). | -| `<>` | The cluster's name, to easily identify the telemetry data for each environment. | - - -## Modifying the configuration for logs - -You can see a full list of the possible configuration values in the [logzio-fluentd Chart folder](https://github.com/logzio/logzio-helm/tree/master/charts/fluentd#configuration). - -If you would like to modify any of the values found in the `logzio-fluentd` folder, use the `--set` flag with the `logzio-fluentd` prefix. - -For instance, if there is a parameter called `someField` in the `logzio-telemetry`'s `values.yaml` file, you can set it by adding the following to the `helm install` command: - -```sh ---set logzio-fluentd.someField="my new value" -``` -You can add `log_type` annotation with a custom value, which will be parsed into a `log_type` field with the same value. - - -### Modifying the configuration for metrics and traces - -You can see a full list of the possible configuration values in the [logzio-telemetry Chart folder](https://github.com/logzio/logzio-helm/tree/master/charts/logzio-telemetry). - -If you would like to modify any of the values found in the `logzio-telemetry` folder, use the `--set` flag with the `logzio-k8s-telemetry` prefix. - -For instance, if there is a parameter called `someField` in the `logzio-telemetry`'s `values.yaml` file, you can set it by adding the following to the `helm install` command: - - -```sh ---set logzio-k8s-telemetry.someField="my new value" -``` - -## Sending telemetry data from eks on fargate - -To ship logs from pods running on Fargate, set the `fargateLogRouter.enabled` value to `true`. Doing so will deploy a dedicated `aws-observability` namespace and a `configmap` for the Fargate log router. For more information on EKS Fargate logging, please refer to the [official AWS documentation]((https://docs.aws.amazon.com/eks/latest/userguide/fargate-logging.html). - -```shell -helm install -n monitoring \ ---set logs.enabled=true \ ---set logzio-fluentd.fargateLogRouter.enabled=true \ ---set logzio-fluentd.secrets.logzioShippingToken="<>" \ ---set logzio-fluentd.secrets.logzioListener="<>" \ ---set metricsOrTraces.enabled=true \ ---set logzio-k8s-telemetry.metrics.enabled=true \ ---set logzio-k8s-telemetry.secrets.MetricsToken="<>" \ ---set logzio-k8s-telemetry.secrets.ListenerHost="https://<>:8053" \ ---set logzio-k8s-telemetry.secrets.p8s_logzio_name="<>" \ ---set logzio-k8s-telemetry.traces.enabled=true \ ---set logzio-k8s-telemetry.secrets.TracesToken="<>" \ ---set logzio-k8s-telemetry.secrets.LogzioRegion="<>" \ -logzio-monitoring logzio-helm/logzio-monitoring -``` - -| Parameter | Description | -| --- | --- | -| `<>` | Your [logs shipping token](https://app.logz.io/#/dashboard/settings/manage-tokens/data-shipping?product=logs). | -| `<>` | Your account's [listener host](https://app.logz.io/#/dashboard/settings/manage-tokens/data-shipping?product=logs). | -| `<>` | Your [metrics shipping token](https://app.logz.io/#/dashboard/settings/manage-tokens/data-shipping?product=metrics). | -| `<>` | The name for the environment's metrics, to easily identify the metrics for each environment. | -| `<>` | The name for your environment's identifier, to easily identify the telemetry data for each environment. | -| `<>` | Your custom name for the environment's metrics, to easily identify the metrics for each environment. | -| `<>` | Replace `<>` with the [token](https://app.logz.io/#/dashboard/settings/manage-tokens/data-shipping?product=tracing) of the account you want to ship to. | -| `<>` | Name of your Logz.io traces region e.g `us` or `eu`. You can find your region code in the [Regions and URLs](https://docs.logz.io/user-guide/accounts/account-region.html#regions-and-urls) table. | - -## Handling image pull rate limit - -In certain situations, such as with spot clusters where pods/nodes are frequently replaced, you may encounter the pull rate limit for images fetched from Docker Hub. This could result in the following error: `You have reached your pull rate limit. You may increase the limit by authenticating and upgrading: https://www.docker.com/increase-rate-limits`. - -To address this issue, you can use the `--set` commands provided below in order to access an alternative image repository: - -```shell ---set logzio-k8s-telemetry.image.repository=ghcr.io/open-telemetry/opentelemetry-collector-releases/opentelemetry-collector-contrib ---set logzio-k8s-telemetry.prometheus-pushgateway.image.repository=public.ecr.aws/logzio/prom-pushgateway ---set logzio-fluentd.image=public.ecr.aws/logzio/logzio-fluentd ---set logzio-fluentd.daemonset.init.containerImage=public.ecr.aws/docker/library/busybox ---set logzio-trivy.image=public.ecr.aws/logzio/trivy-to-logzio -``` - -## Upgrade logzio-monitoring to v3.0.0 - -Before upgrading your logzio-monitoring Chart to v3.0.0 with `helm upgrade`, note that you may encounter an error for some of the logzio-telemetry sub-charts. - -There are two possible approaches to the upgrade you can choose from: -- Reinstall the chart. -- Before running the `helm upgrade` command, delete the old subcharts resources: `logzio-monitoring-prometheus-pushgateway` deployment and the `logzio-monitoring-prometheus-node-exporter` daemonset. +{@include: ../../_include/general-shipping/k8s.md} \ No newline at end of file diff --git a/docs/user-guide/k8s-360/unified-helm-chart.md b/docs/user-guide/k8s-360/unified-helm-chart.md index 8cd7d525..b94a9ac2 100644 --- a/docs/user-guide/k8s-360/unified-helm-chart.md +++ b/docs/user-guide/k8s-360/unified-helm-chart.md @@ -4,189 +4,4 @@ title: Unified Helm Chart --- - - - -The `logzio-monitoring` Helm Chart ships your Kubernetes telemetry (logs, metrics, traces and security reports) to your Logz.io account. - -:::note -Please be aware that this project is presently in its beta stage, and as such, it may undergo alterations. -::: - -:::tip -To get the most out of Kubernetes 360, try out dedicated [dashboard](./kubernetes-360-pre). Log in to your Logz.io account and navigate to the current instructions page [inside the Logz.io app](https://app.logz.io/#/dashboard/send-your-data/collection?tag=all&collection=prometheus-sources). Install the pre-built dashboard to enhance the observability of your metrics. To view the metrics on the main dashboard, log in to your Logz.io Metrics account, and open the [Logz.io Metrics tab](https://app.logz.io/#/dashboard/metrics). -::: - - - -### Default Helm Chart configuration -##### 1. Check if you have any taints on your nodes - -```shell -kubectl get nodes -o json | jq '"\(.items[].metadata.name) \(.items[].spec.taints)"' -``` - -If you want to ship logs from any of the nodes that have a taint, make sure that the taint key values are listed in your in your daemonset/deployment configuration as follows: - -```yaml -tolerations: -- key: - operator: - value: - effect: -``` - -:::node -You need to use `Helm` client with version `v3.9.0` or above. -::: - -##### 2. Add the Helm Chart - -```shell -helm repo add logzio-helm https://logzio.github.io/logzio-helm -helm repo update -``` - -##### 3. Deploy the Chart - -```shell -helm install -n monitoring \ ---set logs.enabled=true \ ---set logzio-fluentd.secrets.logzioShippingToken="<>" \ ---set logzio-fluentd.secrets.logzioListener="<>" \ ---set logzio-fluentd.env_id="<>" \ ---set metricsOrTraces.enabled=true \ ---set logzio-k8s-telemetry.metrics.enabled=true \ ---set logzio-k8s-telemetry.secrets.MetricsToken="<>" \ ---set logzio-k8s-telemetry.secrets.ListenerHost="https://<>:8053" \ ---set logzio-k8s-telemetry.secrets.p8s_logzio_name="<>" \ ---set logzio-k8s-telemetry.traces.enabled=true \ ---set logzio-k8s-telemetry.secrets.TracesToken="<>" \ ---set logzio-k8s-telemetry.secrets.LogzioRegion="<>" \ -logzio-monitoring logzio-helm/logzio-monitoring -``` - -| Parameter | Description | -| --- | --- | -| `<>` | Replace `<>` with the token of the account you want to ship to. | -| `<>` | Replace `<>` with the host [for your region](../../admin/hosting-regions/account-region/#available-regions). For example, `listener.logz.io` if your account is hosted on AWS US East, or `listener-nl.logz.io` if hosted on Azure West Europe. The required port depends whether HTTP or HTTPS is used: HTTP = 8070, HTTPS = 8071. | -| `<>` | Your [metrics shipping token](https://app.logz.io/#/dashboard/settings/manage-tokens/data-shipping). | -| `<>` | The name for the environment's metrics, to easily identify the metrics for each environment. | -| `<>` | The name for your environment's identifier, to easily identify the telemetry data for each environment. | -| `<>` | Your custom name for the environment's metrics, to easily identify the metrics for each environment. | -| `<>` | Replace `<>` with the [token](https://app.logz.io/#/dashboard/settings/manage-tokens/data-shipping?product=tracing) of the account you want to ship to. | -| `<>` | Name of your Logz.io traces region e.g `us` or `eu`. You can find your region code in the [Regions and URLs](https://docs.logz.io/user-guide/accounts/account-region.html#regions-and-urls) table. | - -##### 4. Check Logz.io for your data - -Give your data some time to get from your system to ours, and then open [Open Search Dashboards](https://app.logz.io/#/dashboard/osd). - -Log in to your Logz.io account and navigate to the current instructions page [inside the Logz.io app](https://app.logz.io/#/dashboard/send-your-data/prometheus-sources/). Install the pre-built dashboard to enhance the observability of your metrics. - -To view the metrics on the main dashboard, log in to your Logz.io Metrics account, and open the [Logz.io Metrics tab](https://app.logz.io/#/dashboard/metrics/). - - -### Advanced Helm Chart configuration - -#### Collecting span metrics and Trivy reports - -To enable the `logzio-monitoring` Helm Chart collect span metrics and Trivy reports, add the following command to the default deployment: - -```shell -helm install -n monitoring \ ---set logzio-k8s-telemetry.secrets.SpmToken=<> \ ---set securityReport.enabled=true \ ---set logzio-trivy.env_id="<>" \ ---set logzio-trivy.secrets.logzioShippingToken="<>" \ ---set logzio-trivy.secrets.logzioListener="<>" \ -logzio-monitoring logzio-helm/logzio-monitoring -``` - -| Parameter | Description | -| --- | --- | -| `<>` | Your [span metrics shipping token](https://app.logz.io/#/dashboard/settings/manage-tokens/data-shipping). | -| `<>` | The name for your environment's identifier, to easily identify the telemetry data for each environment. | -| `<>` | Replace `<>` with the token of the account you want to ship to. | -| `<>` | | - - -#### Further configuration - -You can modify the default `logzio-monitoring` Helm Chart by using the `--set` flag in your `helm install` command: - -| Parameter | Description | Default | -| --- | --- | --- | -| `logs.enabled` | Enable to send k8s logs | `false` | -| `metricsOrTraces` | Enable to send k8s metrics or traces | `false` | - -##### Modifying the configuration for logs - -You can see a full list of the possible configuration values in the [logzio-fluentd Chart folder](https://github.com/logzio/logzio-helm/tree/master/charts/fluentd#configuration). - -If you would like to modify any of the values found in the `logzio-fluentd` folder, use the `--set` flag with the `logzio-fluentd` prefix. - -For instance, if there is a parameter called `someField` in the `logzio-telemetry`'s `values.yaml` file, you can set it by adding the following to the `helm install` command: - -```sh ---set logzio-fluentd.someField="my new value" -``` -You can add `log_type` annotation with a custom value, which will be parsed into a `log_type` field with the same value. - - -##### Modifying the configuration for metrics and traces - -You can see a full list of the possible configuration values in the [logzio-telemetry Chart folder](https://github.com/logzio/logzio-helm/tree/master/charts/logzio-telemetry). - -If you would like to modify any of the values found in the `logzio-telemetry` folder, use the `--set` flag with the `logzio-k8s-telemetry` prefix. - -For instance, if there is a parameter called `someField` in the `logzio-telemetry`'s `values.yaml` file, you can set it by adding the following to the `helm install` command: - - -```sh ---set logzio-k8s-telemetry.someField="my new value" -``` - -#### Sending telemetry data from eks on fargate - -To ship logs from pods running on Fargate, set the `fargateLogRouter.enabled` value to `true`. Doing so will deploy a dedicated `aws-observability` namespace and a `configmap` for the Fargate log router. For more information on EKS Fargate logging, please refer to the [official AWS documentation](https://docs.aws.amazon.com/eks/latest/userguide/fargate-logging.html). - -```shell -helm install -n monitoring \ ---set logs.enabled=true \ ---set logzio-fluentd.fargateLogRouter.enabled=true \ ---set logzio-fluentd.secrets.logzioShippingToken="<>" \ ---set logzio-fluentd.secrets.logzioListener="<>" \ ---set metricsOrTraces.enabled=true \ ---set logzio-k8s-telemetry.metrics.enabled=true \ ---set logzio-k8s-telemetry.secrets.MetricsToken="<>" \ ---set logzio-k8s-telemetry.secrets.ListenerHost="https://<>:8053" \ ---set logzio-k8s-telemetry.secrets.p8s_logzio_name="<>" \ ---set logzio-k8s-telemetry.traces.enabled=true \ ---set logzio-k8s-telemetry.secrets.TracesToken="<>" \ ---set logzio-k8s-telemetry.secrets.LogzioRegion="<>" \ -logzio-monitoring logzio-helm/logzio-monitoring -``` - -| Parameter | Description | -| --- | --- | -| `<>` | | -| `<>` | | -| `<>` | Your [metrics shipping token](https://app.logz.io/#/dashboard/settings/manage-tokens/data-shipping). | -| `<>` | The name for the environment's metrics, to easily identify the metrics for each environment. | -| `<>` | The name for your environment's identifier, to easily identify the telemetry data for each environment. | -| `<>` | Your custom name for the environment's metrics, to easily identify the metrics for each environment. | -| `<>` | Replace `<>` with the [token](https://app.logz.io/#/dashboard/settings/manage-tokens/data-shipping?product=tracing) of the account you want to ship to. | -| `<>` | Name of your Logz.io traces region e.g `us` or `eu`. You can find your region code in the [Regions and URLs](https://docs.logz.io/user-guide/accounts/account-region.html#regions-and-urls) table. | - -#### Handling image pull rate limit - -In certain situations, such as with spot clusters where pods/nodes are frequently replaced, you may encounter the pull rate limit for images fetched from Docker Hub. This could result in the following error: Y`ou have reached your pull rate limit. You may increase the limit by authenticating and upgrading: https://www.docker.com/increase-rate-limits`. - -To address this issue, you can use the `--set` commands provided below in order to access an alternative image repository: - -```shell ---set logzio-k8s-telemetry.image.repository=ghcr.io/open-telemetry/opentelemetry-collector-releases/opentelemetry-collector-contrib ---set logzio-k8s-telemetry.prometheus-pushgateway.image.repository=public.ecr.aws/logzio/prom-pushgateway ---set logzio-fluentd.image=public.ecr.aws/logzio/logzio-fluentd ---set logzio-trivy.image=public.ecr.aws/logzio/trivy-to-logzio -``` +{@include: ../../_include/general-shipping/k8s.md} \ No newline at end of file