Skip to content

Commit fbde06e

Browse files
committed
fix Dockerfile: streamline library installation and update paths for cross-compilation
1 parent 4ba0e07 commit fbde06e

File tree

1 file changed

+12
-13
lines changed

1 file changed

+12
-13
lines changed

Dockerfile

Lines changed: 12 additions & 13 deletions
Original file line numberDiff line numberDiff line change
@@ -3,35 +3,34 @@ WORKDIR /usr/src/sqlpage
33
ARG TARGETARCH
44
ARG BUILDARCH
55
RUN apt-get update && \
6+
mkdir -p /opt/sqlpage-libs && \
67
if [ "$TARGETARCH" = "$BUILDARCH" ]; then \
78
rustup target list --installed > TARGET && \
89
echo gcc > LINKER && \
9-
apt-get install -y gcc libgcc-s1 cmake unixodbc-dev && \
10-
cp /lib/*/libgcc_s.so.1 .; \
11-
cp /lib/*/libodbc.so.2 .; \
12-
cp /lib/*/libltdl.so.7 .; \
10+
apt-get install -y gcc libgcc-s1 cmake unixodbc-dev libodbc2 libltdl7 && \
11+
LIBDIR="/lib/*"; \
12+
USRLIBDIR="/usr/lib/*"; \
1313
elif [ "$TARGETARCH" = "arm64" ]; then \
1414
echo aarch64-unknown-linux-gnu > TARGET && \
1515
echo aarch64-linux-gnu-gcc > LINKER && \
1616
dpkg --add-architecture arm64 && apt-get update && \
17-
apt-get install -y gcc-aarch64-linux-gnu libgcc-s1-arm64-cross unixodbc-dev:arm64 && \
18-
cp /usr/aarch64-linux-gnu/lib/libgcc_s.so.1 .; \
19-
cp /usr/lib/aarch64-linux-gnu/libodbc.so.2 .; \
20-
cp /usr/lib/aarch64-linux-gnu/libltdl.so.7 .; \
17+
apt-get install -y gcc-aarch64-linux-gnu libgcc-s1-arm64-cross unixodbc-dev:arm64 libodbc2:arm64 libltdl7:arm64 && \
18+
LIBDIR="/lib/aarch64-linux-gnu"; \
19+
USRLIBDIR="/usr/lib/aarch64-linux-gnu"; \
2120
elif [ "$TARGETARCH" = "arm" ]; then \
2221
echo armv7-unknown-linux-gnueabihf > TARGET && \
2322
echo arm-linux-gnueabihf-gcc > LINKER && \
2423
dpkg --add-architecture armhf && apt-get update && \
25-
apt-get install -y gcc-arm-linux-gnueabihf libgcc-s1-armhf-cross cmake libclang1 unixodbc-dev:armhf && \
24+
apt-get install -y gcc-arm-linux-gnueabihf libgcc-s1-armhf-cross cmake libclang1 unixodbc-dev:armhf libodbc2:armhf libltdl7:armhf && \
2625
cargo install --force --locked bindgen-cli && \
2726
echo "-I/usr/lib/gcc-cross/arm-linux-gnueabihf/12/include -I/usr/arm-linux-gnueabihf/include" > BINDGEN_EXTRA_CLANG_ARGS; \
28-
cp /usr/arm-linux-gnueabihf/lib/libgcc_s.so.1 .; \
29-
cp /usr/lib/arm-linux-gnueabihf/libodbc.so.2 .; \
30-
cp /usr/lib/arm-linux-gnueabihf/libltdl.so.7 .; \
27+
LIBDIR="/lib/arm-linux-gnueabihf"; \
28+
USRLIBDIR="/usr/lib/arm-linux-gnueabihf"; \
3129
else \
3230
echo "Unsupported cross compilation target: $TARGETARCH"; \
3331
exit 1; \
3432
fi && \
33+
cp $LIBDIR/libgcc_s.so.1 $USRLIBDIR/libodbc.so.2 $USRLIBDIR/libltdl.so.7 /opt/sqlpage-libs/ && \
3534
rustup target add $(cat TARGET) && \
3635
cargo init .
3736

@@ -62,7 +61,7 @@ ENV SQLPAGE_WEB_ROOT=/var/www
6261
ENV SQLPAGE_CONFIGURATION_DIRECTORY=/etc/sqlpage
6362
WORKDIR /var/www
6463
COPY --from=builder /usr/src/sqlpage/sqlpage.bin /usr/local/bin/sqlpage
65-
COPY --from=builder /usr/src/sqlpage/*.so.* /lib/
64+
COPY --from=builder /opt/sqlpage-libs/* /lib/
6665
USER sqlpage
6766
COPY --from=builder --chown=sqlpage:sqlpage /usr/src/sqlpage/sqlpage/sqlpage.db sqlpage/sqlpage.db
6867
EXPOSE 8080

0 commit comments

Comments
 (0)