From a2124e068a72c5f21a3ef874a8cb872ba086993d Mon Sep 17 00:00:00 2001 From: Jim Ramsay Date: Fri, 8 Apr 2022 10:47:59 -0400 Subject: [PATCH] ztp: Disable podman logging when extracting container data As described in https://github.com/containers/podman/issues/13779, podman by default logs all of a container's stdout in order to retain info to make 'podman logs' work. But this extra copy of stdout can be overrun and cause hangs when shipping large amounts of data through stdout (as in the case when piping out a tar stream). Changing the instructions and documentation to add '--log-driver=none' to the podman commandline disables this extra unneeded logging and prevents hangs. Signed-off-by: Jim Ramsay --- ztp/gitops-subscriptions/argocd/README.md | 2 +- ztp/resource-generator/Makefile | 4 ++-- ztp/resource-generator/entrypoints/entrypoints | 2 +- ztp/resource-generator/entrypoints/extract | 7 +++++-- 4 files changed, 9 insertions(+), 6 deletions(-) diff --git a/ztp/gitops-subscriptions/argocd/README.md b/ztp/gitops-subscriptions/argocd/README.md index 23cd695233..a6049c69cc 100644 --- a/ztp/gitops-subscriptions/argocd/README.md +++ b/ztp/gitops-subscriptions/argocd/README.md @@ -17,7 +17,7 @@ Create a GIT repository for hosting site configuration data. The ZTP pipeline wi 2. Export the argocd directory from the ztp-site-generator container image by executing the following commands: ``` $ mkdir -p ./out - $ podman run --rm ztp-site-generator:latest extract /home/ztp --tar | tar x -C ./out + $ podman run --rm --log-driver=none ztp-site-generator:latest extract /home/ztp --tar | tar x -C ./out ``` 3. Check the out directory that created above. It contains the following sub directories - out/extra-manifest: contains the source CRs files that SiteConfig uses to generate extra manifest configMap. diff --git a/ztp/resource-generator/Makefile b/ztp/resource-generator/Makefile index b4cc79ed9d..d00df65d9a 100644 --- a/ztp/resource-generator/Makefile +++ b/ztp/resource-generator/Makefile @@ -25,8 +25,8 @@ build: ## Build the ZTP image export: ## Copy resources from container image to out/ directory mkdir -p out - podman run --rm ${IMAGE_NAME}:${VERSION} extract /home/ztp --tar | tar x -C out + podman run --rm --log-driver=none ${IMAGE_NAME}:${VERSION} extract /home/ztp --tar | tar x -C out mkdir -p out/kustomize - podman run --rm ${IMAGE_NAME}:${VERSION} extract /kustomize --tar | tar x -C out/kustomize + podman run --rm --log-driver=none ${IMAGE_NAME}:${VERSION} extract /kustomize --tar | tar x -C out/kustomize all: build export diff --git a/ztp/resource-generator/entrypoints/entrypoints b/ztp/resource-generator/entrypoints/entrypoints index 082cb1b129..f94a0d2e5a 100755 --- a/ztp/resource-generator/entrypoints/entrypoints +++ b/ztp/resource-generator/entrypoints/entrypoints @@ -27,7 +27,7 @@ template and example distribution You can export these templates and examples by running the following commands: - $ podman run --rm ztp-site-generator:latest extract /home/ztp --tar | tar x -C ./out + $ podman run --rm --log-driver=none ztp-site-generator:latest extract /home/ztp --tar | tar x -C ./out extract ------- diff --git a/ztp/resource-generator/entrypoints/extract b/ztp/resource-generator/entrypoints/extract index 86f08b18b3..c249f0820c 100755 --- a/ztp/resource-generator/entrypoints/extract +++ b/ztp/resource-generator/entrypoints/extract @@ -9,12 +9,15 @@ if [[ $1 == "-h" || $1 == "--help" || $1 == "help" ]]; then echo " $(basename $0) srcPath --tar" echo " Export the given directory structure to stdout as a tar stream (should be redirected)" echo " Example:" - echo " podman run \$THIS_CONTAINER $(basename $0) /home/ztp --tar | tar -C ./out" + echo " podman run --rm --log-driver=none \$THIS_CONTAINER $(basename $0) /home/ztp --tar | tar -C ./out" + echo + echo " Important: With podman, add '--log-driver=none' to prevent podman from hanging with large data sent to stdout," + echo " and '--rm' to avoid creating unneeded persistent container image" echo echo " $(basename $0) srcPath dstPath" echo " Export the given directory structure to the destination path (should be mounted as a container volume)" echo " Example:" - echo " podman run \$THIS_CONTAINER -v ./out:/out:Z $(basename $0) /home/ztp /out" + echo " podman run --rm \$THIS_CONTAINER -v ./out:/out:Z $(basename $0) /home/ztp /out" exit 1 fi