Skip to content

Commit

Permalink
cleanup build directory fix
Browse files Browse the repository at this point in the history
- use unique marker per run
- avoid race condition when new pvs arrive in middle of run.
- fix reference in doc to hard coded versions as they are stale
- updated tests to use single "test" tag for now
  • Loading branch information
jduimovich committed Feb 12, 2022
1 parent 5abb137 commit 0808de7
Show file tree
Hide file tree
Showing 5 changed files with 24 additions and 13 deletions.
6 changes: 3 additions & 3 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -4,11 +4,11 @@ This repository contains components that are installed or managed by the managed

This includes default Pipelines and Tasks. You need to have bootstrapped a working appstudio configuration from (see `https://github.com/redhat-appstudio/infra-deployments`) for the dev of pipelines or new tasks.

Pipelines are delivered into App Studio via `quay.io/redhat-appstudio/build-templates-bundle:v0.1.3` (the tag will be updated every change)
Pipelines are delivered into App Studio via `quay.io/redhat-appstudio/build-templates-bundle:vX.Y.Z` (the tag will be updated every change)

Tasks are delivered into App Studio via `quay.io/redhat-appstudio/appstudio-tasks`. Where each task is bundled and pushed into tag in format `${TASK_NAME}-${VERSION}` where version is the same as pipelines bundle version.

Currently a set of utilties are bundled with App Studio in `quay.io/redhat-appstudio/appstudio-utils:v0.1.3` as a convenience but tasks may be run from different per-task containers in future.
Currently a set of utilties are bundled with App Studio in `quay.io/redhat-appstudio/appstudio-utils:vX.Y.Z` as a convenience but tasks may be run from different per-task containers in future.

## Devmode

Expand All @@ -30,7 +30,7 @@ Please test in _gitops mode_ when doing a new release into staging as it will be
The tasks can be found in the `tasks` directories. Tasks are bundled and used by bundled pipelines. Tasks are not stored in the Cluster.
For quick local innerloop style task development, you may install new Tasks in your local namespace manually and create your pipelines as well as the base task image to test new function. Tasks can be installed into local namespace using `oc apply -k tasks/appstudio-utils/util-tasks`.

There is a container which is used to support multiple set of tasks called `quay.io/redhat-appstudio/appstudio-utils:v0.1.3` , which is a single container which is used by multiple tasks. Tasks may also be in their own container as well however many simple tasks are utilities and will be packaged for app studio in a single container. Tasks can rely on other tasks in the system which are co-packed in a container allowing combined tasks (build-only vs build-deploy) which use the same core implementations.
There is a container which is used to support multiple set of tasks called `quay.io/redhat-appstudio/appstudio-utils:vX.Y.Z` , which is a single container which is used by multiple tasks. Tasks may also be in their own container as well however many simple tasks are utilities and will be packaged for app studio in a single container. Tasks can rely on other tasks in the system which are co-packed in a container allowing combined tasks (build-only vs build-deploy) which use the same core implementations.

## Release

Expand Down
2 changes: 1 addition & 1 deletion tasks/appstudio-utils/README.md
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
# Source for quay.io/redhat-appstudioappstudio-utils:v0.1.3
# Source for quay.io/redhat-appstudioappstudio-utils:vX.Y.Z

This component provides an image which contains a suite of app-studio specific utilies.

Expand Down
2 changes: 1 addition & 1 deletion tasks/appstudio-utils/test-all-tasks.sh
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@
SCRIPTDIR="$( cd "$( dirname "${BASH_SOURCE[0]}" )" >/dev/null 2>&1 && pwd )"

oc apply -k $SCRIPTDIR/test-all-tasks
tkn pipeline start test-all-tasks -w name=workspace,claimName=app-studio-default-workspace -p test-image=quay.io/redhat-appstudio/appstudio-utils:v0.1.3 --showlog --use-param-defaults
tkn pipeline start test-all-tasks -w name=workspace,claimName=app-studio-default-workspace -p test-image=quay.io/redhat-appstudio/appstudio-utils:test --showlog --use-param-defaults

# cleanup manually, this is so you can inspect the results
# if you delete immediately, the results are gone
Expand Down
2 changes: 1 addition & 1 deletion tasks/appstudio-utils/test-all-tasks/kustomization.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -11,4 +11,4 @@ patches:
patch: |-
- op: replace
path: /spec/steps/0/image
value: quay.io/redhat-appstudio/appstudio-utils:v0.1.3
value: quay.io/redhat-appstudio/appstudio-utils:test
25 changes: 18 additions & 7 deletions tasks/appstudio-utils/util-scripts/cleanup-build-directories.sh
Original file line number Diff line number Diff line change
Expand Up @@ -5,14 +5,24 @@
# rm unused marker in live pipeline-runs
# rm all directories with unused marker
# all other directories are live and have no marker (done)

MARKER=.appstudio-mark-unused

# if a directory is being gc'd by two copies of this task
# the marker will be unique so they can both run.
# live directories will be a noop
# dead directories can be deleted by either copy
# note, not recommended to run in parallel but will work.

# use a unique marker per tasks based on time to NS
MARKER=.appstudio-mark-unused-$(date +"%Y%m%d%H%M%S%6N")
# Keep track of the existing pvs, any pvs added during this run
# will be ignored until a later run so that new pvs which were not
# originally marked dont get deleted due to not being marked.
CANDIDATES=./pv-*

cd workspace/source
echo "Cleanup:"
BEFORE=$(du -h . | tail -n 1)
BEFORE=$(du -s)
# mark all unused
for build in ./pv-* ; do
for build in $CANDIDATES ; do
if [ -d "$build" ]; then
echo "Directory: $build"
echo "unused" > "$build/$MARKER"
Expand All @@ -30,8 +40,9 @@ kubectl get pipelineruns --no-headers -o custom-columns=":metadata.name" | \
kubectl get pipelineruns --no-headers -o custom-columns=":metadata.name" | \
xargs -n 1 -I {} rm -f pv-{}/$MARKER 2> /dev/null


# if still marked unused, may be removed
for build in ./pv-* ; do
for build in $CANDIDATES ; do
if [ -f "$build/$MARKER" ]; then
echo "Removing: $(du -h $build | tail -n 1)"
rm -rf $build
Expand All @@ -41,7 +52,7 @@ for build in ./pv-* ; do
fi
fi
done
AFTER=$(du -h . | tail -n 1)
AFTER=$(du -s)

CMD=$(basename $0)
if [ -d "$1" ]; then
Expand Down

0 comments on commit 0808de7

Please sign in to comment.