Merge pull request #33 from frol/patch-1
Updated the process of native libs builds to make it more reliable
This commit is contained in:
commit
30341c0cfb
38
Dockerfile
38
Dockerfile
|
@ -53,37 +53,35 @@ RUN curl https://sh.rustup.rs -sSf | \
|
||||||
rustup target add x86_64-unknown-linux-musl
|
rustup target add x86_64-unknown-linux-musl
|
||||||
ADD cargo-config.toml /home/rust/.cargo/config
|
ADD cargo-config.toml /home/rust/.cargo/config
|
||||||
|
|
||||||
# We'll build our libraries in subdirectories of /home/rust/libs. Please
|
|
||||||
# clean up when you're done.
|
|
||||||
WORKDIR /home/rust/libs
|
|
||||||
|
|
||||||
# Build a static library version of OpenSSL using musl-libc. This is
|
# Build a static library version of OpenSSL using musl-libc. This is
|
||||||
# needed by the popular Rust `hyper` crate.
|
# needed by the popular Rust `hyper` crate.
|
||||||
RUN echo "Building OpenSSL" && \
|
RUN echo "Building OpenSSL" && \
|
||||||
VERS=1.0.2l && \
|
cd /tmp && \
|
||||||
curl -O https://www.openssl.org/source/openssl-$VERS.tar.gz && \
|
OPENSSL_VERSION=1.0.2l && \
|
||||||
tar xvzf openssl-$VERS.tar.gz && cd openssl-$VERS && \
|
curl -LO "https://www.openssl.org/source/openssl-$OPENSSL_VERSION.tar.gz" && \
|
||||||
|
tar xvzf "openssl-$OPENSSL_VERSION.tar.gz" && cd "openssl-$OPENSSL_VERSION" && \
|
||||||
env CC=musl-gcc ./Configure no-shared no-zlib -fPIC --prefix=/usr/local/musl linux-x86_64 && \
|
env CC=musl-gcc ./Configure no-shared no-zlib -fPIC --prefix=/usr/local/musl linux-x86_64 && \
|
||||||
env C_INCLUDE_PATH=/usr/local/musl/include/ make depend && \
|
env C_INCLUDE_PATH=/usr/local/musl/include/ make depend && \
|
||||||
make && sudo make install && \
|
make && sudo make install && \
|
||||||
cd .. && rm -rf openssl-$VERS.tar.gz openssl-$VERS && \
|
\
|
||||||
echo "Building zlib" && \
|
echo "Building zlib" && \
|
||||||
VERS=1.2.11 && \
|
cd /tmp && \
|
||||||
cd /home/rust/libs && \
|
ZLIB_VERSION=1.2.11 && \
|
||||||
curl -LO http://zlib.net/zlib-$VERS.tar.gz && \
|
curl -LO "http://zlib.net/zlib-$ZLIB_VERSION.tar.gz" && \
|
||||||
tar xzf zlib-$VERS.tar.gz && cd zlib-$VERS && \
|
tar xzf "zlib-$ZLIB_VERSION.tar.gz" && cd "zlib-$ZLIB_VERSION" && \
|
||||||
CC=musl-gcc ./configure --static --prefix=/usr/local/musl && \
|
CC=musl-gcc ./configure --static --prefix=/usr/local/musl && \
|
||||||
make && sudo make install && \
|
make && sudo make install && \
|
||||||
cd .. && rm -rf zlib-$VERS.tar.gz zlib-$VERS && \
|
\
|
||||||
echo "Building libpq" && \
|
echo "Building libpq" && \
|
||||||
VERS=9.6.5 && \
|
cd /tmp && \
|
||||||
curl -o postgres.tar.gz https://ftp.postgresql.org/pub/source/v$VERS/postgresql-$VERS.tar.gz && \
|
POSTGRESQL_VERSION=9.6.5 && \
|
||||||
tar xzf postgres.tar.gz && \
|
curl -LO "https://ftp.postgresql.org/pub/source/v$POSTGRESQL_VERSION/postgresql-$POSTGRESQL_VERSION.tar.gz" && \
|
||||||
cd postgresql-$VERS && \
|
tar xzf "postgresql-$POSTGRESQL_VERSION.tar.gz" && cd "postgresql-$POSTGRESQL_VERSION" && \
|
||||||
CC=musl-gcc CPPFLAGS=-I/usr/local/musl/include LDFLAGS=-L/usr/local/musl/lib ./configure --with-openssl --without-readline --prefix=/usr/local/musl && \
|
CC=musl-gcc CPPFLAGS=-I/usr/local/musl/include LDFLAGS=-L/usr/local/musl/lib ./configure --with-openssl --without-readline --prefix=/usr/local/musl && \
|
||||||
cd src/interfaces/libpq && make all-static-lib && sudo make install-lib-static && cd ../../.. && \
|
cd src/interfaces/libpq && make all-static-lib && sudo make install-lib-static && \
|
||||||
cd src/bin/pg_config && make && sudo make install && cd ../.. && \
|
cd ../../bin/pg_config && make && sudo make install && \
|
||||||
cd .. && rm -rf postgres.tar.gz postgresql-$VERS
|
\
|
||||||
|
rm -r /tmp/*
|
||||||
|
|
||||||
ENV OPENSSL_DIR=/usr/local/musl/ \
|
ENV OPENSSL_DIR=/usr/local/musl/ \
|
||||||
OPENSSL_INCLUDE_DIR=/usr/local/musl/include/ \
|
OPENSSL_INCLUDE_DIR=/usr/local/musl/include/ \
|
||||||
|
|
Loading…
Reference in a new issue