|
|
|
@ -5,42 +5,52 @@ RUN apt-get install -y build-essential wget ca-certificates |
|
|
|
|
|
|
|
ARG FDB_VERSION=7.4.5 |
|
|
|
ENV FDB_VERSION=${FDB_VERSION} |
|
|
|
ARG TARGETARCH |
|
|
|
|
|
|
|
# Install FoundationDB client libraries with SHA256 checksum verification |
|
|
|
# Known SHA256 checksums for FoundationDB client packages (verified 2025-01-19) |
|
|
|
# To add checksums for new versions: run docker/get_fdb_checksum.sh <version> |
|
|
|
RUN cd /tmp && \ |
|
|
|
case "${FDB_VERSION}" in \ |
|
|
|
"7.4.5") \ |
|
|
|
case "${TARGETARCH}" in \ |
|
|
|
"amd64") FDB_ARCH="amd64" ;; \ |
|
|
|
"arm64") FDB_ARCH="arm64" ;; \ |
|
|
|
*) echo "Unsupported architecture: ${TARGETARCH}" >&2; exit 1 ;; \ |
|
|
|
esac && \ |
|
|
|
case "${FDB_VERSION}_${FDB_ARCH}" in \ |
|
|
|
"7.4.5_amd64") \ |
|
|
|
EXPECTED_SHA256="eea6b98cf386a0848655b2e196d18633662a7440a7ee061c10e32153c7e7e112" ;; \ |
|
|
|
"7.3.43") \ |
|
|
|
"7.4.5_arm64") \ |
|
|
|
EXPECTED_SHA256="TBD_RUN_get_fdb_checksum_for_arm64" ;; \ |
|
|
|
"7.3.43_amd64") \ |
|
|
|
EXPECTED_SHA256="c3fa0a59c7355b914a1455dac909238d5ea3b6c6bc7b530af8597e6487c1651a" ;; \ |
|
|
|
"7.3.43_arm64") \ |
|
|
|
EXPECTED_SHA256="TBD_RUN_get_fdb_checksum_for_arm64" ;; \ |
|
|
|
*) \ |
|
|
|
echo "ERROR: No checksum available for FDB version ${FDB_VERSION}" >&2; \ |
|
|
|
echo "ERROR: No checksum available for FDB version ${FDB_VERSION} on ${FDB_ARCH}" >&2; \ |
|
|
|
echo "This is a security requirement. To add verification:" >&2; \ |
|
|
|
echo " 1. Run: docker/get_fdb_checksum.sh ${FDB_VERSION}" >&2; \ |
|
|
|
echo " 1. Run: docker/get_fdb_checksum.sh ${FDB_VERSION} ${FDB_ARCH}" >&2; \ |
|
|
|
echo " 2. Add the checksum to this Dockerfile" >&2; \ |
|
|
|
echo "Refusing to proceed without checksum verification." >&2; \ |
|
|
|
exit 1 ;; \ |
|
|
|
esac && \ |
|
|
|
wget https://github.com/apple/foundationdb/releases/download/${FDB_VERSION}/foundationdb-clients_${FDB_VERSION}-1_amd64.deb && \ |
|
|
|
echo "${EXPECTED_SHA256} foundationdb-clients_${FDB_VERSION}-1_amd64.deb" | sha256sum -c - || \ |
|
|
|
(echo "ERROR: Checksum verification failed for FoundationDB ${FDB_VERSION}" >&2; \ |
|
|
|
PACKAGE="foundationdb-clients_${FDB_VERSION}-1_${FDB_ARCH}.deb" && \ |
|
|
|
wget --timeout=30 --tries=3 https://github.com/apple/foundationdb/releases/download/${FDB_VERSION}/${PACKAGE} && \ |
|
|
|
echo "${EXPECTED_SHA256} ${PACKAGE}" | sha256sum -c - || \ |
|
|
|
(echo "ERROR: Checksum verification failed for FoundationDB ${FDB_VERSION} (${FDB_ARCH})" >&2; \ |
|
|
|
echo "Expected: ${EXPECTED_SHA256}" >&2; \ |
|
|
|
echo "This indicates either a corrupted download or potential tampering." >&2; \ |
|
|
|
exit 1) && \ |
|
|
|
dpkg -i foundationdb-clients_${FDB_VERSION}-1_amd64.deb && \ |
|
|
|
rm foundationdb-clients_${FDB_VERSION}-1_amd64.deb |
|
|
|
dpkg -i ${PACKAGE} && \ |
|
|
|
rm ${PACKAGE} |
|
|
|
|
|
|
|
# Set up FoundationDB environment variables for CGO |
|
|
|
ENV CGO_CFLAGS="-I/usr/include/foundationdb" |
|
|
|
ENV CGO_LDFLAGS="-lfdb_c" |
|
|
|
|
|
|
|
# build SeaweedFS |
|
|
|
RUN mkdir -p /go/src/github.com/seaweedfs/ |
|
|
|
RUN git clone https://github.com/seaweedfs/seaweedfs /go/src/github.com/seaweedfs/seaweedfs |
|
|
|
ARG BRANCH=master |
|
|
|
RUN cd /go/src/github.com/seaweedfs/seaweedfs && git checkout $BRANCH |
|
|
|
RUN mkdir -p /go/src/github.com/seaweedfs/ && \ |
|
|
|
git clone --depth 1 --branch ${BRANCH} https://github.com/seaweedfs/seaweedfs /go/src/github.com/seaweedfs/seaweedfs |
|
|
|
RUN cd /go/src/github.com/seaweedfs/seaweedfs/weed \ |
|
|
|
&& export LDFLAGS="-X github.com/seaweedfs/seaweedfs/weed/util/version.COMMIT=$(git rev-parse --short HEAD)" \ |
|
|
|
&& go install -tags "5BytesOffset foundationdb" -ldflags "${LDFLAGS}" |
|
|
|
@ -59,22 +69,33 @@ RUN apt-get update && \ |
|
|
|
|
|
|
|
# Install FoundationDB client library in runtime image with SHA256 checksum verification |
|
|
|
ARG FDB_VERSION=7.4.5 |
|
|
|
ARG TARGETARCH |
|
|
|
RUN cd /tmp && \ |
|
|
|
case "${FDB_VERSION}" in \ |
|
|
|
"7.4.5") \ |
|
|
|
case "${TARGETARCH}" in \ |
|
|
|
"amd64") FDB_ARCH="amd64" ;; \ |
|
|
|
"arm64") FDB_ARCH="arm64" ;; \ |
|
|
|
*) echo "Unsupported architecture: ${TARGETARCH}" >&2; exit 1 ;; \ |
|
|
|
esac && \ |
|
|
|
case "${FDB_VERSION}_${FDB_ARCH}" in \ |
|
|
|
"7.4.5_amd64") \ |
|
|
|
EXPECTED_SHA256="eea6b98cf386a0848655b2e196d18633662a7440a7ee061c10e32153c7e7e112" ;; \ |
|
|
|
"7.3.43") \ |
|
|
|
"7.4.5_arm64") \ |
|
|
|
EXPECTED_SHA256="TBD_RUN_get_fdb_checksum_for_arm64" ;; \ |
|
|
|
"7.3.43_amd64") \ |
|
|
|
EXPECTED_SHA256="c3fa0a59c7355b914a1455dac909238d5ea3b6c6bc7b530af8597e6487c1651a" ;; \ |
|
|
|
"7.3.43_arm64") \ |
|
|
|
EXPECTED_SHA256="TBD_RUN_get_fdb_checksum_for_arm64" ;; \ |
|
|
|
*) \ |
|
|
|
echo "ERROR: No checksum available for FDB version ${FDB_VERSION}" >&2; \ |
|
|
|
echo "Run docker/get_fdb_checksum.sh ${FDB_VERSION} to get the checksum" >&2; \ |
|
|
|
echo "ERROR: No checksum available for FDB version ${FDB_VERSION} on ${FDB_ARCH}" >&2; \ |
|
|
|
echo "Run docker/get_fdb_checksum.sh ${FDB_VERSION} ${FDB_ARCH} to get the checksum" >&2; \ |
|
|
|
exit 1 ;; \ |
|
|
|
esac && \ |
|
|
|
wget https://github.com/apple/foundationdb/releases/download/${FDB_VERSION}/foundationdb-clients_${FDB_VERSION}-1_amd64.deb && \ |
|
|
|
echo "${EXPECTED_SHA256} foundationdb-clients_${FDB_VERSION}-1_amd64.deb" | sha256sum -c - || \ |
|
|
|
(echo "ERROR: Checksum verification failed for FoundationDB ${FDB_VERSION}" >&2; exit 1) && \ |
|
|
|
dpkg -i foundationdb-clients_${FDB_VERSION}-1_amd64.deb && \ |
|
|
|
rm foundationdb-clients_${FDB_VERSION}-1_amd64.deb |
|
|
|
PACKAGE="foundationdb-clients_${FDB_VERSION}-1_${FDB_ARCH}.deb" && \ |
|
|
|
wget --timeout=30 --tries=3 https://github.com/apple/foundationdb/releases/download/${FDB_VERSION}/${PACKAGE} && \ |
|
|
|
echo "${EXPECTED_SHA256} ${PACKAGE}" | sha256sum -c - || \ |
|
|
|
(echo "ERROR: Checksum verification failed for FoundationDB ${FDB_VERSION} (${FDB_ARCH})" >&2; exit 1) && \ |
|
|
|
dpkg -i ${PACKAGE} && \ |
|
|
|
rm ${PACKAGE} |
|
|
|
|
|
|
|
# Copy SeaweedFS binary and configuration |
|
|
|
COPY --from=builder /go/bin/weed /usr/bin/ |
|
|
|
|