feat(kaniko): Optimize kaniko build by 50% using compression and add progress #9476
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
Merge current PR after 9464: #9464
Description
We have a large code base(over 96k files) and it's painful to deploy the service because it takes a lot of time. I've spent a lot of time trying to fix this and finally, I did it, now it takes less than 50% time to deploy and it transfers 3x less data.
I also added progress output so it'll be convenient to see what's going on.
User facing changes
.
New kaniko config option
BuildContextCompressionLevel
.New default output
Start building with kaniko for artifact
.New progress
Sending build context to Kaniko pod {amount}
before optimization:

3 minutes and 40 seconds to create a tar file and 613M transfer
after optimization:

1 minute and 24 seconds to create a tar file and 167M transfer