Skip to content

Commit e8eaeba

Browse files
committed
Attempt to fix docker-lib.sh script
See gh-15158
1 parent 8fcad7b commit e8eaeba

File tree

2 files changed

+45
-22
lines changed

2 files changed

+45
-22
lines changed

ci/images/docker-lib.sh

Lines changed: 44 additions & 21 deletions
Original file line numberDiff line numberDiff line change
@@ -1,5 +1,9 @@
11
# Based on: https://github.com/concourse/docker-image-resource/blob/master/assets/common.sh
22

3+
LOG_FILE=${LOG_FILE:-/tmp/docker.log}
4+
SKIP_PRIVILEGED=${SKIP_PRIVILEGED:-false}
5+
STARTUP_TIMEOUT=${STARTUP_TIMEOUT:-120}
6+
37
sanitize_cgroups() {
48
mkdir -p /sys/fs/cgroup
59
mountpoint -q /sys/fs/cgroup || \
@@ -13,7 +17,7 @@ sanitize_cgroups() {
1317
continue
1418
fi
1519

16-
grouping="$(cat /proc/self/cgroup | cut -d: -f2 | grep "\\<$sys\\>")"
20+
grouping="$(cat /proc/self/cgroup | cut -d: -f2 | grep "\\<$sys\\>")" || true
1721
if [ -z "$grouping" ]; then
1822
# subsystem not mounted anywhere; mount it on its own
1923
grouping="$sys"
@@ -38,44 +42,63 @@ sanitize_cgroups() {
3842
ln -s "$mountpoint" "/sys/fs/cgroup/$sys"
3943
fi
4044
done
45+
46+
if ! test -e /sys/fs/cgroup/systemd ; then
47+
mkdir /sys/fs/cgroup/systemd
48+
mount -t cgroup -o none,name=systemd none /sys/fs/cgroup/systemd
49+
fi
4150
}
4251

4352
start_docker() {
4453
mkdir -p /var/log
4554
mkdir -p /var/run
4655

47-
sanitize_cgroups
56+
if [ "$SKIP_PRIVILEGED" = "false" ]; then
57+
sanitize_cgroups
4858

49-
# check for /proc/sys being mounted readonly, as systemd does
50-
if grep '/proc/sys\s\+\w\+\s\+ro,' /proc/mounts >/dev/null; then
51-
mount -o remount,rw /proc/sys
59+
# check for /proc/sys being mounted readonly, as systemd does
60+
if grep '/proc/sys\s\+\w\+\s\+ro,' /proc/mounts >/dev/null; then
61+
mount -o remount,rw /proc/sys
62+
fi
5263
fi
5364

54-
local server_args=""
65+
local mtu=$(cat /sys/class/net/$(ip route get 8.8.8.8|awk '{ print $5 }')/mtu)
66+
local server_args="--mtu ${mtu}"
67+
local registry=""
5568

56-
for registry in $1; do
69+
server_args="${server_args}"
70+
71+
for registry in $3; do
5772
server_args="${server_args} --insecure-registry ${registry}"
5873
done
5974

60-
if [ -n "$2" ]; then
61-
server_args="${server_args} --registry-mirror=$2"
75+
if [ -n "$4" ]; then
76+
server_args="${server_args} --registry-mirror $4"
6277
fi
6378

64-
if [ -n "$3" ]; then
65-
server_args="${server_args} -g=$3"
66-
fi
79+
try_start() {
80+
dockerd --data-root /scratch/docker ${server_args} >$LOG_FILE 2>&1 &
81+
echo $! > /tmp/docker.pid
6782

68-
dockerd --data-root /scratch/docker ${server_args} >/tmp/docker.log 2>&1 &
69-
echo $! > /tmp/docker.pid
83+
sleep 1
7084

71-
trap stop_docker EXIT
85+
echo waiting for docker to come up...
86+
until docker info >/dev/null 2>&1; do
87+
sleep 1
88+
if ! kill -0 "$(cat /tmp/docker.pid)" 2>/dev/null; then
89+
return 1
90+
fi
91+
done
92+
}
7293

73-
sleep 1
94+
export server_args LOG_FILE
95+
declare -fx try_start
96+
trap stop_docker EXIT
7497

75-
until docker info >/dev/null 2>&1; do
76-
echo waiting for docker to come up...
77-
sleep 1
78-
done
98+
if ! timeout ${STARTUP_TIMEOUT} bash -ce 'while true; do try_start && break; done'; then
99+
echo Docker failed to start within ${STARTUP_TIMEOUT} seconds.
100+
return 1
101+
fi
79102
}
80103

81104
stop_docker() {
@@ -85,5 +108,5 @@ stop_docker() {
85108
fi
86109

87110
kill -TERM $pid
88-
wait $pid
89111
}
112+

ci/images/setup.sh

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -6,7 +6,7 @@ set -ex
66
###########################################################
77

88
apt-get update
9-
apt-get install --no-install-recommends -y ca-certificates net-tools libxml2-utils git curl libudev1 libxml2-utils iptables jq
9+
apt-get install --no-install-recommends -y ca-certificates net-tools libxml2-utils git curl libudev1 libxml2-utils iptables iproute2 jq
1010
rm -rf /var/lib/apt/lists/*
1111

1212
curl https://raw.githubusercontent.com/spring-io/concourse-java-scripts/v0.0.2/concourse-java.sh > /opt/concourse-java.sh

0 commit comments

Comments
 (0)