Skip to main content
U.S. flag

An official website of the United States government

Potential buildpack cache issue with apt-buildpack

December 09, 2024

What does the buildpack cache do?

The buildpack cache (aka “app cache,” or “build artifacts cache”) is a per-application cache that is stored in the blob (binary large object) store and recovered when an existing application is restaged (regardless of application code or buildpack changes).

Different buildpacks use this cache for different things. System buildpacks are cached on the VM hosting the application container and then mounted as read-only volumes into each staging container. If your application references a custom buildpack or buildpack version via a URLs (to a git repo or a zip file), those buildpacks are downloaded every time application staging occurs.

Potential cache issue with apt-buildpack

The potential issue with the apt-buildpack cache involves the / directory disk allocation. The apt-buildpack uses /tmp for its cache like other buildpacks. In all buildpacks, the / directory is allocated approximately 9% of the disk allocation, meaning that the size of the /tmp subdirectory cannot exceed that disk allocation. For most buildpacks, this disk allocation is sufficient as all the possible packages that they could be installing is known with the only variable being the application code. However, the apt-buildpack can install an unknown number of packages of variable size, such as the AWS CLI. Depending on how many packages are installed and their individual size, the allotted 9% of disk space may not be sufficient, causing application staging to fail with an error like:

stdout: No space left on device. /usr/bin/tar: /tmp/output-cache: Wrote only 2048 of 10240 bytes

How to address the issue

If the number of packages that you are installing during staging is within the allotted 9% of the disk limit (2 GB default) you can attempt to resolve the issue by clearing the buildpack cache and attempting to push your application again. Please refer to the commands below to clear your buildpack cache.

app_guid=$(cf app --guid <staging-app-name>)
cf curl -X POST /v3/apps/${app_guid}/actions/clear_buildpack_cache

You can additionally configure the apt buildpack cache to purge any cached content by setting cleancache to true which calls apt-get clean and apt-get autoclean and is useful to remove any cached content per the apt buildpack documentation.

If you encounter any difficulties deploying this solution or have any questions, please contact support@cloud.gov and we would be happy to assist you.

cloud.gov

An official website of the U.S. General Services Administration

Looking for U.S. government information and services?
Visit USA.gov