must-gather

module
v0.0.0-...-4ba8f18 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Aug 6, 2025 License: Apache-2.0

README

OADP Must-gather

New Markdown UI for summarized results

In order to better facilitate the quick analsysis of customer issues, OADP now offers a markown summary of the collected information. The oadp-must-gather-summary.md file can be found under the clusters directory in the oadp-must-gather results.

Example screenshot #1

Screenshot from 2025-05-05 10-33-47

Example screenshot #2

Screenshot from 2025-05-05 10-34-05

Developer Setup

To test OADP Must-gather, run

go run cmd/main.go -h
go run cmd/main.go

To test OADP Must-gather with oc adm must-gather, run

podman build -t ttl.sh/oadp/must-gather-$(git rev-parse --short HEAD)-$(echo $RANDOM):1h -f Dockerfile . --platform=<cluster-architecture>
podman push <this-image>
oc adm must-gather --image=<this-image> -- /usr/bin/gather -h
oc adm must-gather --image=<this-image>

OADP Must-gather is also tested through OADP E2E tests, being run after test cases and checking if summary does not contain errors and all required objects were collected.

To test omg tool, create omg.Dockerfile file

FROM python:3.10.12-slim-bullseye

WORKDIR /test-omg
COPY ./ ./
RUN pip install o-must-gather

and run

podman build -t omg-container -f omg.Dockerfile .
podman run -ti --rm omg-container bash
# inside container
omg use must-gather/clusters/
omg get backup -n <namespace> # and other OADP resources

To update OADP Must-gather go.mod dependencies, run

go get github.com/openshift/oadp-operator@oadp-dev
go get github.com/migtools/oadp-non-admin@oadp-dev
# manually update github.com/openshift/velero version in replace section of go.mod to match OADP operator
go mod tidy
go mod verify

Update it often. It must be updated prior to releases.

Possible necessary updates over the time

go get github.com/openshift/oc@<branch-or-commit>
go mod tidy
go mod verify

OADP release

Prior to each release, OADP Must-gather must be updated.

To update OADP Must-gather go.mod dependencies, run

go get github.com/openshift/oadp-operator@<release-brach>
go get github.com/migtools/oadp-non-admin@<release-brach>
# manually update github.com/openshift/velero version in replace section of go.mod to match OADP operator
go mod tidy
go mod verify

must-gather/pkg/cli.go file must be updated

 const (
-	mustGatherVersion = "1.5.0"
+	mustGatherVersion = "1.5.1"
	mustGatherImage   = "registry.redhat.io/oadp/oadp-mustgather-rhel9:v1.5"

Note: If it is a minor release, mustGatherImage must also be updated.

Deprecated folder

Scripts under deprecated/ folder are for backwards compatibility with old OADP Must-gather shell script. Users should use new OADP Must-gather Go script, as highlighted in product documentation.

Standards

OADP Must-gather must comply with https://github.com/openshift/enhancements/blob/995b620cb04c030bf62c908e188472fe7031a704/enhancements/oc/must-gather.md?plain=1#L94-L104

  1. Must have a zero-arg, executable file at /usr/bin/gather that does your default gathering

OADP Must-gather binary can be called without args. All OADP Must-gather binary args are optional

  1. Must produce data to be copied back at /must-gather. The data must not contain any sensitive data. We don't string PII information, only secret information.

OADP Must-gather collected data is stored at /must-gather folder in the same path the binary was called.

Most of the data is collected through oc adm inspect command (including Secrets). The other data are cluster information, OADP related information (CRDs and CRs) and storage information (StorageClasses, VolumeSnapshotClasses and CSIDrivers CRDs and CRs). These objects should not contain any sensitive data.

  1. Must produce a text /must-gather/version that indicates the product (first line) and the version (second line, major.minor.micro-qualifier), so that programmatic analysis can be developed.

OADP Must-gather stores version information in /must-gather/version file

Example content of the file

OpenShift API for Data Protection (OADP) Must-gather
oadp-dev-branch
  1. Should honor the user-provided values for --since and --since-time, which are passed to plugins via environment variables named MUST_GATHER_SINCE and MUST_GATHER_SINCE_TIME, respectively.

TODO oc adm inspect command is called through Go code. But both since and since-time are private. Need to change this in https://github.com/openshift/oc/blob/ae1bd9e4a75b8ab617a569e5c8e1a0d7285a16f6/pkg/cli/admin/inspect/inspect.go#L118-L119 to allow usage in OADP Must-gather

Directories

Path Synopsis
pkg
gvk

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL