-
Notifications
You must be signed in to change notification settings - Fork 33
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
In situations where concurrent stacker runs are happening on a system, and they are building containers with the same name, and they are being done inside a mount namespace, and the path name given as the roots dir is the same, but the actual mounted volume is different, then both stackers will be able to acquire the file lock at $rootdir/.lock, and will go ahead and start containers named $name, which will then race to set up the lxc control socket, which is named after the container name and the rootfs path, which are both the same here. The fix is to add some randomness to the lxc container name, which ensures that the socket won't clash. This should not affect other uses of the image name, which will still use the un-randomized name. Signed-off-by: Michael McCracken <mikmccra@cisco.com>
- Loading branch information
1 parent
ad9a694
commit 74db868
Showing
3 changed files
with
41 additions
and
2 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,37 @@ | ||
load helpers | ||
|
||
function setup() { | ||
stacker_setup | ||
} | ||
|
||
function teardown() { | ||
cleanup | ||
} | ||
|
||
@test "concurrent w aliased rootdir" { | ||
cat > stacker.yaml <<"EOF" | ||
robertos: | ||
from: | ||
type: oci | ||
url: ${{BUSYBOX_OCI}} | ||
run: | | ||
sleep ${{SNOOZ}} # make sure they have time to conflict | ||
EOF | ||
|
||
mkdir -p 1/roots 1/stacker 2/roots 2/stacker aliased-rootsdir | ||
chmod -R 777 1 2 | ||
|
||
# simulate shared CI infra where name of sandbox dir is same despite backing store being different | ||
|
||
mount --bind 1/roots aliased-rootsdir | ||
${ROOT_DIR}/stacker --debug --roots-dir=aliased-rootsdir --stacker-dir=1/stacker --oci-dir=1/oci --log-file=1.log build --substitute BUSYBOX_OCI=${BUSYBOX_OCI} --substitute SNOOZ=15 & | ||
|
||
sleep 5 | ||
|
||
unshare -m bash <<EOF | ||
mount --bind 2/roots aliased-rootsdir | ||
${ROOT_DIR}/stacker --debug --roots-dir=aliased-rootsdir --stacker-dir=2/stacker --oci-dir=2/oci --log-file=2.log \ | ||
build --substitute BUSYBOX_OCI=${BUSYBOX_OCI} --substitute SNOOZ=0 | ||
EOF | ||
|
||
} |