mirror of
https://github.com/ilyakooo0/nixpkgs.git
synced 2024-12-27 22:03:54 +03:00
Merge pull request #14588 from puffnfresh/bug/remove-docker-tarballs
dockerTools: remove "tarballs" attribute
This commit is contained in:
commit
6d8845ed8f
@ -1,5 +1,5 @@
|
|||||||
{ stdenv, lib, callPackage, runCommand, writeReferencesToFile, writeText, vmTools, writeScript
|
{ stdenv, lib, callPackage, runCommand, writeReferencesToFile, writeText, vmTools, writeScript
|
||||||
, docker, shadow, utillinux, coreutils, jshon, e2fsprogs, goPackages }:
|
, docker, shadow, utillinux, coreutils, jshon, e2fsprogs, goPackages, pigz }:
|
||||||
|
|
||||||
# WARNING: this API is unstable and may be subject to backwards-incompatible changes in the future.
|
# WARNING: this API is unstable and may be subject to backwards-incompatible changes in the future.
|
||||||
|
|
||||||
@ -45,27 +45,6 @@ rec {
|
|||||||
done
|
done
|
||||||
'';
|
'';
|
||||||
|
|
||||||
mkTarball = { name ? "docker-tar", drv, onlyDeps ? false }:
|
|
||||||
runCommand "${name}.tar.gz" rec {
|
|
||||||
inherit drv onlyDeps;
|
|
||||||
|
|
||||||
drvClosure = writeReferencesToFile drv;
|
|
||||||
|
|
||||||
} ''
|
|
||||||
while read dep; do
|
|
||||||
echo Copying $dep
|
|
||||||
dir="$(dirname "$dep")"
|
|
||||||
mkdir -p "rootfs/$dir"
|
|
||||||
cp -drf --preserve=mode $dep "rootfs/$dir/"
|
|
||||||
done < "$drvClosure"
|
|
||||||
|
|
||||||
if [ -z "$onlyDeps" ]; then
|
|
||||||
cp -drf --preserve=mode $drv/* rootfs/
|
|
||||||
fi
|
|
||||||
|
|
||||||
tar -C rootfs/ -cpzf $out .
|
|
||||||
'';
|
|
||||||
|
|
||||||
shellScript = text:
|
shellScript = text:
|
||||||
writeScript "script.sh" ''
|
writeScript "script.sh" ''
|
||||||
#!${stdenv.shell}
|
#!${stdenv.shell}
|
||||||
@ -99,16 +78,6 @@ EOF
|
|||||||
fi
|
fi
|
||||||
'';
|
'';
|
||||||
|
|
||||||
# Append to tar instead of unpacking
|
|
||||||
mergeTarballs = tarballs:
|
|
||||||
runCommand "merge-tars" { inherit tarballs; } ''
|
|
||||||
mkdir tmp
|
|
||||||
for tb in $tarballs; do
|
|
||||||
tar -C tmp -xkpf $tb
|
|
||||||
done
|
|
||||||
tar -C tmp -cpzf $out .
|
|
||||||
'';
|
|
||||||
|
|
||||||
runWithOverlay = { name , fromImage ? null, fromImageName ? null, fromImageTag ? null
|
runWithOverlay = { name , fromImage ? null, fromImageName ? null, fromImageTag ? null
|
||||||
, diskSize ? 1024, preMount ? "", postMount ? "", postUmount ? "" }:
|
, diskSize ? 1024, preMount ? "", postMount ? "", postUmount ? "" }:
|
||||||
vmTools.runInLinuxVM (
|
vmTools.runInLinuxVM (
|
||||||
@ -182,7 +151,7 @@ EOF
|
|||||||
|
|
||||||
postMount = ''
|
postMount = ''
|
||||||
echo Packing raw image
|
echo Packing raw image
|
||||||
tar -C mnt -czf $out .
|
tar -C mnt -cf $out .
|
||||||
'';
|
'';
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -262,8 +231,8 @@ EOF
|
|||||||
# 6. repack the image
|
# 6. repack the image
|
||||||
buildImage = args@{ name, tag ? "latest"
|
buildImage = args@{ name, tag ? "latest"
|
||||||
, fromImage ? null, fromImageName ? null, fromImageTag ? null
|
, fromImage ? null, fromImageName ? null, fromImageTag ? null
|
||||||
, contents ? null, tarballs ? [], config ? null
|
, contents ? null, config ? null, runAsRoot ? null
|
||||||
, runAsRoot ? null, diskSize ? 1024, extraCommands ? "" }:
|
, diskSize ? 1024, extraCommands ? "" }:
|
||||||
|
|
||||||
let
|
let
|
||||||
|
|
||||||
@ -279,18 +248,14 @@ EOF
|
|||||||
layer = (if runAsRoot == null
|
layer = (if runAsRoot == null
|
||||||
then mkPureLayer { inherit baseJson contents extraCommands; }
|
then mkPureLayer { inherit baseJson contents extraCommands; }
|
||||||
else mkRootLayer { inherit baseJson fromImage fromImageName fromImageTag contents runAsRoot diskSize extraCommands; });
|
else mkRootLayer { inherit baseJson fromImage fromImageName fromImageTag contents runAsRoot diskSize extraCommands; });
|
||||||
depsTarball = mkTarball { name = "${baseName}-deps";
|
|
||||||
drv = layer;
|
|
||||||
onlyDeps = true; };
|
|
||||||
|
|
||||||
result = runCommand "${baseName}.tar.gz" {
|
result = runCommand "${baseName}.tar.gz" {
|
||||||
buildInputs = [ jshon ];
|
buildInputs = [ jshon pigz ];
|
||||||
|
|
||||||
imageName = name;
|
imageName = name;
|
||||||
imageTag = tag;
|
imageTag = tag;
|
||||||
inherit fromImage baseJson;
|
inherit fromImage baseJson;
|
||||||
|
|
||||||
mergedTarball = if tarballs == [] then depsTarball else mergeTarballs ([ depsTarball ] ++ tarballs);
|
layerClosure = writeReferencesToFile layer;
|
||||||
|
|
||||||
passthru = {
|
passthru = {
|
||||||
buildArgs = args;
|
buildArgs = args;
|
||||||
@ -321,20 +286,15 @@ EOF
|
|||||||
cp ${layer}/* temp/
|
cp ${layer}/* temp/
|
||||||
chmod ug+w temp/*
|
chmod ug+w temp/*
|
||||||
|
|
||||||
echo Adding dependencies
|
touch layerFiles
|
||||||
|
for dep in $(cat $layerClosure); do
|
||||||
|
find $dep >> layerFiles
|
||||||
|
done
|
||||||
|
|
||||||
|
echo Adding layer
|
||||||
tar -tf temp/layer.tar >> baseFiles
|
tar -tf temp/layer.tar >> baseFiles
|
||||||
tar -tf "$mergedTarball" | grep -v ${layer} > layerFiles
|
comm <(sort -n baseFiles|uniq) <(sort -n layerFiles|uniq|grep -v ${layer}) -1 -3 > newFiles
|
||||||
if [ "$(wc -l layerFiles|cut -d ' ' -f 1)" -gt 3 ]; then
|
tar -rpf temp/layer.tar --no-recursion --files-from newFiles 2>/dev/null || true
|
||||||
sed -i -e 's|^[\./]\+||' baseFiles layerFiles
|
|
||||||
comm <(sort -n baseFiles|uniq) <(sort -n layerFiles|uniq) -1 -3 > newFiles
|
|
||||||
mkdir deps
|
|
||||||
pushd deps
|
|
||||||
tar -xpf "$mergedTarball" --no-recursion --files-from ../newFiles 2>/dev/null || true
|
|
||||||
tar -rf ../temp/layer.tar --no-recursion --files-from ../newFiles 2>/dev/null || true
|
|
||||||
popd
|
|
||||||
else
|
|
||||||
echo No new deps, no diffing needed
|
|
||||||
fi
|
|
||||||
|
|
||||||
echo Adding meta
|
echo Adding meta
|
||||||
|
|
||||||
@ -357,7 +317,7 @@ EOF
|
|||||||
chmod -R a-w image
|
chmod -R a-w image
|
||||||
|
|
||||||
echo Cooking the image
|
echo Cooking the image
|
||||||
tar -C image -czf $out .
|
tar -C image -c . | pigz > $out
|
||||||
'';
|
'';
|
||||||
|
|
||||||
in
|
in
|
||||||
|
Loading…
Reference in New Issue
Block a user