Fix docker files missing libwebsockets8 by building from source, fix docker test run by starting maridb service instead of mysql one.
This commit is contained in:
parent
e835596b27
commit
bac4706301
33
Dockerfile
33
Dockerfile
|
@ -32,7 +32,7 @@ RUN if [ "$(echo $MOSQUITTO_VERSION | head -c 1)" != 2 ]; then \
|
|||
make -j "$(nproc)" && \
|
||||
rm -rf /root/.cmake ; \
|
||||
fi
|
||||
|
||||
|
||||
WORKDIR /app
|
||||
|
||||
RUN mkdir -p mosquitto/auth mosquitto/conf.d
|
||||
|
@ -60,7 +60,7 @@ ARG BUILDPLATFORM
|
|||
|
||||
# Install TARGETPLATFORM parser to translate its value to GOOS, GOARCH, and GOARM
|
||||
COPY --from=tonistiigi/xx:golang / /
|
||||
RUN go env
|
||||
RUN go env
|
||||
|
||||
# Install needed libc and gcc for target platform.
|
||||
RUN if [ ! -z "$TARGETPLATFORM" ]; then \
|
||||
|
@ -89,9 +89,34 @@ RUN go build -buildmode=c-archive go-auth.go && \
|
|||
#Start from a new image.
|
||||
FROM debian:stable-slim
|
||||
|
||||
RUN apt update && apt install -y libwebsockets8 libc-ares2 openssl uuid tini
|
||||
RUN apt update && apt install -y libc-ares2 openssl uuid tini
|
||||
|
||||
RUN mkdir -p /var/lib/mosquitto /var/log/mosquitto
|
||||
# Get libwebsocket. Debian's libwebsockets is too old for Mosquitto version > 2.x so it gets built from source.
|
||||
RUN if [ "$(echo $MOSQUITTO_VERSION | head -c 1)" != 2 ]; then \
|
||||
apt install -y libwebsockets-dev ; \
|
||||
else \
|
||||
export LWS_VERSION=2.4.2 && \
|
||||
wget https://github.com/warmcat/libwebsockets/archive/v${LWS_VERSION}.tar.gz -O /tmp/lws.tar.gz && \
|
||||
mkdir -p /build/lws && \
|
||||
tar --strip=1 -xf /tmp/lws.tar.gz -C /build/lws && \
|
||||
rm /tmp/lws.tar.gz && \
|
||||
cd /build/lws && \
|
||||
cmake . \
|
||||
-DCMAKE_BUILD_TYPE=MinSizeRel \
|
||||
-DCMAKE_INSTALL_PREFIX=/usr \
|
||||
-DLWS_IPV6=ON \
|
||||
-DLWS_WITHOUT_BUILTIN_GETIFADDRS=ON \
|
||||
-DLWS_WITHOUT_CLIENT=ON \
|
||||
-DLWS_WITHOUT_EXTENSIONS=ON \
|
||||
-DLWS_WITHOUT_TESTAPPS=ON \
|
||||
-DLWS_WITH_SHARED=OFF \
|
||||
-DLWS_WITH_ZIP_FOPS=OFF \
|
||||
-DLWS_WITH_ZLIB=OFF && \
|
||||
make -j "$(nproc)" && \
|
||||
rm -rf /root/.cmake ; \
|
||||
fi
|
||||
|
||||
RUN mkdir -p /var/lib/mosquitto /var/log/mosquitto
|
||||
RUN groupadd mosquitto \
|
||||
&& useradd -s /sbin/nologin mosquitto -g mosquitto -d /var/lib/mosquitto \
|
||||
&& chown -R mosquitto:mosquitto /var/log/mosquitto/ \
|
||||
|
|
|
@ -11,11 +11,36 @@ ENV GO_VERSION=1.13.8
|
|||
WORKDIR /app
|
||||
|
||||
#Get mosquitto build dependencies.
|
||||
RUN apt-get update && apt-get install -y libwebsockets8 libwebsockets-dev libc-ares2 libc-ares-dev openssl uuid uuid-dev wget build-essential git
|
||||
RUN apt-get update && apt-get install -y libc-ares2 libc-ares-dev openssl uuid uuid-dev wget build-essential git
|
||||
|
||||
RUN if [ "$(echo $MOSQUITTO_VERSION | head -c 1)" != 2 ]; then \
|
||||
apt install -y libwebsockets-dev ; \
|
||||
else \
|
||||
export LWS_VERSION=2.4.2 && \
|
||||
wget https://github.com/warmcat/libwebsockets/archive/v${LWS_VERSION}.tar.gz -O /tmp/lws.tar.gz && \
|
||||
mkdir -p /build/lws && \
|
||||
tar --strip=1 -xf /tmp/lws.tar.gz -C /build/lws && \
|
||||
rm /tmp/lws.tar.gz && \
|
||||
cd /build/lws && \
|
||||
cmake . \
|
||||
-DCMAKE_BUILD_TYPE=MinSizeRel \
|
||||
-DCMAKE_INSTALL_PREFIX=/usr \
|
||||
-DLWS_IPV6=ON \
|
||||
-DLWS_WITHOUT_BUILTIN_GETIFADDRS=ON \
|
||||
-DLWS_WITHOUT_CLIENT=ON \
|
||||
-DLWS_WITHOUT_EXTENSIONS=ON \
|
||||
-DLWS_WITHOUT_TESTAPPS=ON \
|
||||
-DLWS_WITH_SHARED=OFF \
|
||||
-DLWS_WITH_ZIP_FOPS=OFF \
|
||||
-DLWS_WITH_ZLIB=OFF && \
|
||||
make -j "$(nproc)" && \
|
||||
rm -rf /root/.cmake ; \
|
||||
fi
|
||||
|
||||
RUN mkdir -p mosquitto/auth mosquitto/conf.d
|
||||
|
||||
RUN wget http://mosquitto.org/files/source/mosquitto-${MOSQUITTO_VERSION}.tar.gz
|
||||
RUN tar xzvf mosquitto-${MOSQUITTO_VERSION}.tar.gz && rm mosquitto-${MOSQUITTO_VERSION}.tar.gz
|
||||
RUN tar xzvf mosquitto-${MOSQUITTO_VERSION}.tar.gz && rm mosquitto-${MOSQUITTO_VERSION}.tar.gz
|
||||
|
||||
#Build mosquitto.
|
||||
RUN cd mosquitto-${MOSQUITTO_VERSION} && make WITH_WEBSOCKETS=yes && make install && cd ..
|
||||
|
|
|
@ -3,7 +3,7 @@
|
|||
# This script is make to be run in Docker image build by Dockerfile.test
|
||||
|
||||
service postgresql start
|
||||
service mysql start
|
||||
service mariadb start
|
||||
service redis-server start
|
||||
|
||||
sudo -u mongodb mongod --config /etc/mongod.conf &
|
||||
|
|
Loading…
Reference in New Issue