Commit e8eaeba2 authored by Phillip Webb's avatar Phillip Webb

Attempt to fix docker-lib.sh script

See gh-15158
parent 8fcad7bb
# Based on: https://github.com/concourse/docker-image-resource/blob/master/assets/common.sh # Based on: https://github.com/concourse/docker-image-resource/blob/master/assets/common.sh
LOG_FILE=${LOG_FILE:-/tmp/docker.log}
SKIP_PRIVILEGED=${SKIP_PRIVILEGED:-false}
STARTUP_TIMEOUT=${STARTUP_TIMEOUT:-120}
sanitize_cgroups() { sanitize_cgroups() {
mkdir -p /sys/fs/cgroup mkdir -p /sys/fs/cgroup
mountpoint -q /sys/fs/cgroup || \ mountpoint -q /sys/fs/cgroup || \
...@@ -13,7 +17,7 @@ sanitize_cgroups() { ...@@ -13,7 +17,7 @@ sanitize_cgroups() {
continue continue
fi fi
grouping="$(cat /proc/self/cgroup | cut -d: -f2 | grep "\\<$sys\\>")" grouping="$(cat /proc/self/cgroup | cut -d: -f2 | grep "\\<$sys\\>")" || true
if [ -z "$grouping" ]; then if [ -z "$grouping" ]; then
# subsystem not mounted anywhere; mount it on its own # subsystem not mounted anywhere; mount it on its own
grouping="$sys" grouping="$sys"
...@@ -38,44 +42,63 @@ sanitize_cgroups() { ...@@ -38,44 +42,63 @@ sanitize_cgroups() {
ln -s "$mountpoint" "/sys/fs/cgroup/$sys" ln -s "$mountpoint" "/sys/fs/cgroup/$sys"
fi fi
done done
if ! test -e /sys/fs/cgroup/systemd ; then
mkdir /sys/fs/cgroup/systemd
mount -t cgroup -o none,name=systemd none /sys/fs/cgroup/systemd
fi
} }
start_docker() { start_docker() {
mkdir -p /var/log mkdir -p /var/log
mkdir -p /var/run mkdir -p /var/run
sanitize_cgroups if [ "$SKIP_PRIVILEGED" = "false" ]; then
sanitize_cgroups
# check for /proc/sys being mounted readonly, as systemd does # check for /proc/sys being mounted readonly, as systemd does
if grep '/proc/sys\s\+\w\+\s\+ro,' /proc/mounts >/dev/null; then if grep '/proc/sys\s\+\w\+\s\+ro,' /proc/mounts >/dev/null; then
mount -o remount,rw /proc/sys mount -o remount,rw /proc/sys
fi
fi fi
local server_args="" local mtu=$(cat /sys/class/net/$(ip route get 8.8.8.8|awk '{ print $5 }')/mtu)
local server_args="--mtu ${mtu}"
local registry=""
for registry in $1; do server_args="${server_args}"
for registry in $3; do
server_args="${server_args} --insecure-registry ${registry}" server_args="${server_args} --insecure-registry ${registry}"
done done
if [ -n "$2" ]; then if [ -n "$4" ]; then
server_args="${server_args} --registry-mirror=$2" server_args="${server_args} --registry-mirror $4"
fi fi
if [ -n "$3" ]; then try_start() {
server_args="${server_args} -g=$3" dockerd --data-root /scratch/docker ${server_args} >$LOG_FILE 2>&1 &
fi echo $! > /tmp/docker.pid
dockerd --data-root /scratch/docker ${server_args} >/tmp/docker.log 2>&1 & sleep 1
echo $! > /tmp/docker.pid
trap stop_docker EXIT echo waiting for docker to come up...
until docker info >/dev/null 2>&1; do
sleep 1
if ! kill -0 "$(cat /tmp/docker.pid)" 2>/dev/null; then
return 1
fi
done
}
sleep 1 export server_args LOG_FILE
declare -fx try_start
trap stop_docker EXIT
until docker info >/dev/null 2>&1; do if ! timeout ${STARTUP_TIMEOUT} bash -ce 'while true; do try_start && break; done'; then
echo waiting for docker to come up... echo Docker failed to start within ${STARTUP_TIMEOUT} seconds.
sleep 1 return 1
done fi
} }
stop_docker() { stop_docker() {
...@@ -85,5 +108,5 @@ stop_docker() { ...@@ -85,5 +108,5 @@ stop_docker() {
fi fi
kill -TERM $pid kill -TERM $pid
wait $pid
} }
...@@ -6,7 +6,7 @@ set -ex ...@@ -6,7 +6,7 @@ set -ex
########################################################### ###########################################################
apt-get update apt-get update
apt-get install --no-install-recommends -y ca-certificates net-tools libxml2-utils git curl libudev1 libxml2-utils iptables jq apt-get install --no-install-recommends -y ca-certificates net-tools libxml2-utils git curl libudev1 libxml2-utils iptables iproute2 jq
rm -rf /var/lib/apt/lists/* rm -rf /var/lib/apt/lists/*
curl https://raw.githubusercontent.com/spring-io/concourse-java-scripts/v0.0.2/concourse-java.sh > /opt/concourse-java.sh curl https://raw.githubusercontent.com/spring-io/concourse-java-scripts/v0.0.2/concourse-java.sh > /opt/concourse-java.sh
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment