2018-03-17 22:04:12 +00:00
|
|
|
# Pre-define ARGs to ensure correct scope
|
2018-08-02 10:06:38 +01:00
|
|
|
ARG GLIBC_VER=2.28
|
2018-08-20 00:51:46 +01:00
|
|
|
ARG BUSYB_VER=1.29.2
|
2018-07-09 15:40:33 +01:00
|
|
|
ARG SU_EXEC_VER=0.3
|
|
|
|
ARG TINI_VER=0.18.0
|
2018-03-17 22:04:12 +00:00
|
|
|
|
2018-03-16 16:11:54 +00:00
|
|
|
FROM spritsail/debian-builder as builder
|
2017-05-10 21:55:40 +01:00
|
|
|
|
2017-05-11 22:15:10 +01:00
|
|
|
ARG ARCH=x86_64
|
2017-08-09 19:44:55 +01:00
|
|
|
ARG ARCH_ALT=i686
|
2017-05-10 21:55:40 +01:00
|
|
|
|
2018-03-17 22:04:12 +00:00
|
|
|
ARG GLIBC_VER
|
|
|
|
ARG BUSYB_VER
|
|
|
|
ARG SU_EXEC_VER
|
|
|
|
ARG TINI_VER
|
2017-05-12 01:30:49 +01:00
|
|
|
|
2017-05-22 17:06:05 +01:00
|
|
|
ARG PREFIX=/output
|
|
|
|
WORKDIR $PREFIX
|
2017-05-11 10:36:22 +01:00
|
|
|
|
2017-05-11 23:37:11 +01:00
|
|
|
#Set up our dependencies, configure the output filesystem a bit
|
2017-09-20 12:32:21 +01:00
|
|
|
RUN mkdir -p dev etc home proc root tmp usr/{bin,lib/pkgconfig,lib32} var && \
|
2017-08-16 01:39:57 +01:00
|
|
|
# Set up directories in a very confusing but very worky way
|
|
|
|
ln -sv usr/lib lib64 && \
|
|
|
|
ln -sv usr/lib lib && \
|
|
|
|
ln -sv usr/bin bin && \
|
|
|
|
ln -sv usr/bin sbin && \
|
|
|
|
ln -sv bin usr/sbin
|
2017-05-11 23:37:11 +01:00
|
|
|
|
2017-08-15 21:54:36 +01:00
|
|
|
WORKDIR /tmp/glibc/build
|
2017-05-10 21:55:40 +01:00
|
|
|
|
2017-05-12 11:50:24 +01:00
|
|
|
# Download and build glibc from source
|
2018-02-04 22:10:40 +00:00
|
|
|
RUN apt install -y bison && \
|
|
|
|
curl -fL https://ftp.gnu.org/gnu/glibc/glibc-${GLIBC_VER}.tar.xz \
|
2017-08-15 21:54:36 +01:00
|
|
|
| tar xJ --strip-components=1 -C .. && \
|
2017-08-09 21:29:31 +01:00
|
|
|
\
|
2017-08-16 17:43:37 +01:00
|
|
|
echo "slibdir=/usr/lib" >> configparms && \
|
|
|
|
echo "rtlddir=/usr/lib" >> configparms && \
|
2017-05-12 11:50:24 +01:00
|
|
|
echo "sbindir=/bin" >> configparms && \
|
2017-08-15 21:54:36 +01:00
|
|
|
echo "rootsbindir=/sbin" >> configparms && \
|
|
|
|
echo "build-programs=yes" >> configparms && \
|
2017-08-09 21:29:31 +01:00
|
|
|
\
|
2017-08-15 21:54:36 +01:00
|
|
|
../configure \
|
2017-08-16 17:43:37 +01:00
|
|
|
--prefix=/usr \
|
|
|
|
--libdir=/usr/lib \
|
|
|
|
--libexecdir=/usr/lib \
|
2017-05-12 11:50:24 +01:00
|
|
|
--enable-add-ons \
|
|
|
|
--enable-obsolete-rpc \
|
|
|
|
--enable-kernel=3.10.0 \
|
|
|
|
--enable-bind-now \
|
|
|
|
--disable-profile \
|
|
|
|
--enable-stackguard-randomization \
|
|
|
|
--enable-stack-protector=strong \
|
|
|
|
--enable-lock-elision \
|
|
|
|
--enable-multi-arch \
|
|
|
|
--disable-werror && \
|
2017-08-09 21:42:08 +01:00
|
|
|
make -j "$(nproc)" && \
|
2017-08-15 21:54:36 +01:00
|
|
|
make -j "$(nproc)" install_root="$(pwd)/out" install
|
2017-05-12 11:50:24 +01:00
|
|
|
|
2017-08-16 17:43:37 +01:00
|
|
|
RUN strip -s out/sbin/ldconfig && \
|
2017-08-15 21:54:36 +01:00
|
|
|
# Patch ldd to use sh not bash
|
2017-08-16 17:43:37 +01:00
|
|
|
sed -i '1s/.*/#!\/bin\/sh/' out/usr/bin/ldd && \
|
2017-09-09 00:18:24 +01:00
|
|
|
sed -i 's/lib64/lib/g' out/usr/bin/ldd && \
|
2017-08-16 17:43:37 +01:00
|
|
|
# Copy glibc libs & loader
|
|
|
|
cp -d out/usr/lib/*.so* "${PREFIX}/usr/lib" && \
|
|
|
|
cp -d out/usr/bin/ldd "${PREFIX}/bin" && \
|
2017-08-15 21:54:36 +01:00
|
|
|
cp -d out/sbin/ldconfig "${PREFIX}/sbin" && \
|
|
|
|
\
|
2017-08-16 17:43:37 +01:00
|
|
|
echo /usr/lib32 > "${PREFIX}/etc/ld.so.conf"
|
2017-05-12 11:50:24 +01:00
|
|
|
|
2017-08-09 21:16:39 +01:00
|
|
|
WORKDIR /tmp/busybox
|
|
|
|
|
|
|
|
# Download and build busybox from source
|
2017-08-09 21:39:40 +01:00
|
|
|
RUN curl -fL https://busybox.net/downloads/busybox-${BUSYB_VER}.tar.bz2 \
|
2017-08-09 21:29:31 +01:00
|
|
|
| tar xj --strip-components=1 && \
|
|
|
|
# Use default configuration
|
|
|
|
make defconfig && \
|
2017-08-09 21:42:08 +01:00
|
|
|
make -j "$(nproc)" && \
|
2017-08-09 21:29:31 +01:00
|
|
|
cp busybox "${PREFIX}/bin" && \
|
2017-08-09 21:16:39 +01:00
|
|
|
# "Install" busybox, creating symlinks to all binaries it provides
|
2017-08-09 21:42:28 +01:00
|
|
|
./busybox --list-full | xargs -i ln -s /bin/busybox "${PREFIX}/{}"
|
2017-08-09 21:16:39 +01:00
|
|
|
|
2018-08-31 16:31:25 +01:00
|
|
|
WORKDIR /tmp/su-exec
|
|
|
|
|
|
|
|
# Download and build su-exec from source
|
|
|
|
RUN apt-get -y install xxd
|
|
|
|
RUN curl -fL https://github.com/frebib/su-exec/archive/v${SU_EXEC_VER}.tar.gz \
|
|
|
|
| tar xz --strip-components=1 && \
|
|
|
|
make && \
|
|
|
|
strip -s su-exec && \
|
|
|
|
mv su-exec "${PREFIX}/sbin"
|
|
|
|
|
|
|
|
WORKDIR /tmp/tini
|
|
|
|
|
|
|
|
# Download and build tini from source
|
|
|
|
ADD tini-gnudef.patch /tmp
|
|
|
|
RUN curl -fL https://github.com/krallin/tini/archive/v${TINI_VER}.tar.gz \
|
|
|
|
| tar xz --strip-components=1 && \
|
|
|
|
patch -p1 < /tmp/tini-gnudef.patch && \
|
|
|
|
cmake . && \
|
|
|
|
make tini && \
|
|
|
|
mv tini "${PREFIX}/sbin"
|
|
|
|
|
2017-05-22 18:09:32 +01:00
|
|
|
WORKDIR $PREFIX
|
|
|
|
|
2017-08-15 23:14:46 +01:00
|
|
|
# Generate initial ld.so.cache so ELF binaries work.
|
|
|
|
# This is important otherwise everything will error with
|
|
|
|
# 'no such file or directory' when looking for libraries
|
2017-08-16 20:30:14 +01:00
|
|
|
RUN ${PREFIX}/sbin/ldconfig -r ${PREFIX} && \
|
|
|
|
# Copy UTC localtime to output
|
|
|
|
cp /usr/share/zoneinfo/Etc/UTC etc/
|
2017-08-15 23:14:46 +01:00
|
|
|
|
2017-05-11 22:15:10 +01:00
|
|
|
# =============
|
|
|
|
|
|
|
|
FROM scratch
|
2018-03-17 22:04:12 +00:00
|
|
|
|
|
|
|
ARG BUSYB_VER
|
|
|
|
ARG GLIBC_VER
|
2018-03-26 15:56:13 +01:00
|
|
|
ARG SU_EXEC_VER
|
|
|
|
ARG TINI_VER
|
2018-03-17 22:04:12 +00:00
|
|
|
|
|
|
|
LABEL maintainer="Spritsail <busybox@spritsail.io>" \
|
|
|
|
org.label-schema.vendor="Spritsail" \
|
|
|
|
org.label-schema.name="Busybox" \
|
|
|
|
org.label-schema.url="https://github.com/spritsail/busybox" \
|
|
|
|
org.label-schema.description="Busybox and GNU libc built from source" \
|
2018-03-26 15:56:13 +01:00
|
|
|
org.label-schema.version=${BUSYB_VER}/${GLIBC_VER} \
|
|
|
|
io.spritsail.version.busybox=${BUSYB_VER} \
|
|
|
|
io.spritsail.version.glibc=${GLIBC_VER} \
|
|
|
|
io.spritsail.version.su-exec=${SU_EXEC_VER} \
|
|
|
|
io.spritsail.version.tini=${TINI_VER}
|
2018-03-17 22:04:12 +00:00
|
|
|
|
2017-05-10 21:55:40 +01:00
|
|
|
WORKDIR /
|
2017-08-09 14:06:52 +01:00
|
|
|
|
2018-04-17 14:19:46 +01:00
|
|
|
SHELL ["/bin/sh", "-exc"]
|
|
|
|
|
2017-05-12 00:34:57 +01:00
|
|
|
COPY --from=builder /output/ /
|
2017-08-16 20:30:14 +01:00
|
|
|
# Add default skeleton configuration files
|
2018-04-17 14:21:02 +01:00
|
|
|
COPY skel/ /
|
|
|
|
RUN chmod 1777 /tmp && \
|
2018-09-04 18:52:45 +01:00
|
|
|
chmod 775 /usr/bin/*
|
2018-02-05 21:10:26 +00:00
|
|
|
|
2017-08-16 20:30:14 +01:00
|
|
|
ENV ENV="/etc/profile"
|
2018-07-09 13:14:35 +01:00
|
|
|
ENV PATH=/usr/local/sbin:/usr/local/bin:/usr/bin
|
2017-08-16 01:55:47 +01:00
|
|
|
|
2018-04-17 14:19:46 +01:00
|
|
|
ENTRYPOINT ["/sbin/tini" , "--"]
|
2017-08-09 14:21:09 +01:00
|
|
|
CMD ["/bin/sh"]
|