Including logs from pods in the collected output
logs collectors can be used to include logs from running pods.
This collector can be included multiple times with different label selectors and/or namespaces.
In addition to the shared collector properties, the
logs collector accepts the following parameters:
The selector to use to find matching pods. If this selector returns more than one pod, all matching pods will be collected.
Multiple selectors are possible, but the results are a logical
AND, not a logical
OR, meaning that the resulting set of pod may not contain the expected results (possibly no results). It is best to use separate collectors to generate individual logs for different service pods.
The pod labels in
metadata: name: service1 labels: app.kubernetes.io/name: service1
The collector YAML in
collectors: - logs: selector: - app.kubernetes.io/name=service1
The namespace to search for the pod selector in. If this is not provided, it will default to the current namespace of the context.
Name will be used to create a folder in the support bundle where logs will be saved. Name can contain slashes to create a path in the support bundle.
ContainerNames is an array of container names. If specified, logs for each container in the list will be collected. This can be omitted for pods with only one container.
Provided to limit the size of the logs.
By default, this is set to
maxLines can be provided, but not both.
The duration of the maximum oldest log to include. Valid time units are "ns", "us" (or "µs"), "ms", "s", "m", "h". For duration string format see time.ParseDuration.
The number of lines to include, starting from the newest.
The maximum file size of a collected pod log. Defaults to an integer value of
5000000 bytes, which is 5MB. The value
can only be set as an integer value for the
apiVersion: troubleshoot.sh/v1beta2 kind: SupportBundle metadata: name: sample spec: collectors: - logs: selector: - app=api namespace: default name: api/container/logs containerNames: - api - node limits: maxAge: 720h - logs: selector: - app=backend namespace: default name: backend/container/logs containerNames: - db limits: maxLines: 1000 maxBytes: 5000000
When this collector is executed, it will include the following files in a support bundle:
This will be created for each pod that matches the selector.
If any errors are encounted, the following file will be created:
[ "failed to get log stream: container node is not valid for pod api-6fd69d8f78-tmtf7" ]