mirror of
https://github.com/edgelesssys/constellation.git
synced 2024-10-01 01:36:09 -04:00
60 lines
3.0 KiB
Markdown
60 lines
3.0 KiB
Markdown
|
# Logcollection
|
||
|
|
||
|
One can deploy [Filebeat](https://www.elastic.co/guide/en/beats/filebeat/current/index.html) and [Logstash](https://www.elastic.co/guide/en/logstash/current/index.html) to enable collection of logs to [OpenSearch](https://search-e2e-logs-y46renozy42lcojbvrt3qq7csm.eu-central-1.es.amazonaws.com/_dashboards/app/home#/), which allows for agreggation and easy inspection of said logs.
|
||
|
The logcollection functionality can be deployed to both [debug](./debug-cluster.md) and non-debug clusters.
|
||
|
|
||
|
## Deployment in Debug Clusters
|
||
|
|
||
|
In debug clusters, logcollection functionality should be deployed automatically through the debug daemon `debugd`, which runs *before* the bootstrapper
|
||
|
and can therefore, contrary to non-debug clusters, also collect logs of the bootstrapper.
|
||
|
|
||
|
## Deployment in Non-Debug Clusters
|
||
|
|
||
|
In non-debug clusters, logcollection functionality needs to be explicitly deployed as a Kubernetes Deployment through Helm. To do that, a few steps need to be followed:
|
||
|
|
||
|
1. Template the deployment configuration through the `loco` CLI.
|
||
|
|
||
|
```bash
|
||
|
bazel run //hack/logcollector template -- \
|
||
|
--dir $(realpath .) \
|
||
|
--username <OPENSEARCH_USERNAME> \
|
||
|
--password <OPENSEARCH_PW> \
|
||
|
--info deployment-type={k8s, debugd}
|
||
|
...
|
||
|
```
|
||
|
|
||
|
This will place the templated configuration in the current directory. OpenSearch user credentials can be created by any admin in OpenSearch.
|
||
|
Logging in with your company CSP accounts should grant you sufficient permissions to [create a user](https://opensearch.org/docs/latest/security/access-control/users-roles/#create-users)
|
||
|
and [grant him the required `all_access` role](https://opensearch.org/docs/latest/security/access-control/users-roles/#map-users-to-roles).
|
||
|
One can add additional key-value pairs to the configuration by appending `--info key=value` to the command.
|
||
|
These key-value pairs will be attached to the log entries and can be used to filter them in OpenSearch.
|
||
|
For example, it might be helpful to add a `test=<xyz>` tag to be able to filter out logs from a specific test run.
|
||
|
2. Deploy Logstash
|
||
|
|
||
|
```bash
|
||
|
cd logstash
|
||
|
make add
|
||
|
make install
|
||
|
cd ..
|
||
|
```
|
||
|
|
||
|
This will add the required Logstash Helm charts and deploy them to your cluster.
|
||
|
3. Deploy Filebeat
|
||
|
|
||
|
```bash
|
||
|
cd filebeat
|
||
|
make add
|
||
|
make install
|
||
|
cd ..
|
||
|
```
|
||
|
|
||
|
This will add the required Filebeat Helm charts and deploy them to your cluster.
|
||
|
|
||
|
To remove Logstash or Filebeat, `cd` into the corresponding directory and run `make remove`.
|
||
|
|
||
|
## Inspecting Logs in OpenSearch
|
||
|
|
||
|
To search through logs in OpenSearch, head to the [discover page](https://search-e2e-logs-y46renozy42lcojbvrt3qq7csm.eu-central-1.es.amazonaws.com/_dashboards/app/discover) in the
|
||
|
OpenSearch dashboard and configure the timeframe selector in the top right accordingly.
|
||
|
Click `Refresh`. You can now see all logs recorded in the specified timeframe. To get a less cluttered view, select the fields you want to inspect in the left sidebar.
|