- Add ISL support,

- Add ISL display to supervisor HTTPD status page,
- Add SERVER_SV_HTTPD_ENABLED env variable,
- Use now supervisor 4.3.0,
- Use now rx3-docker/base:1.4.0-mga9 image,
- Rebuild for updates.
This commit is contained in:
2026-02-13 19:23:39 +01:00
parent dbb5451c01
commit 448c084b2f
5 changed files with 165 additions and 39 deletions

View File

@@ -8,6 +8,7 @@ FROM ${IMG_FROM_URL}
ARG IMG_NAME
ARG IMG_NAME_FULL
ARG IMG_VERSION
ARG IMG_URL
ARG IMG_MAINTAINER
LABEL org.rx3.${IMG_NAME}.name=${IMG_NAME_FULL}
@@ -27,6 +28,88 @@ ARG SERVER_DNSMASQ_INI=/etc/supervisord.d/dnsmasq.ini
ARG SERVER_DNSMASQ_CONF=/etc/dnsmasq.conf
ARG SERVER_RESOLV_CONF=/etc/resolv.conf
ARG SERVER_SV_INI=/etc/supervisord.d/supervisord.ini
ARG SERVER_SV_HTTPD_INI=/etc/supervisord.d/supervisord-httpd.ini
ARG SERVER_SV_HTTPD_PAGE=/usr/lib/python3.10/site-packages/supervisor/ui/status.html
ARG SERVER_SV_HTTPD_CSS=/usr/lib/python3.10/site-packages/supervisor/ui/stylesheets/supervisor.css
#-----------------------------------------------------------------------------------------------------------------------
ARG SERVER_SV_HTML_IMG_B='status" />'
#-----------------------------------------------------------------------------------------------------------------------
ARG SERVER_SV_HTML_IMG_A='status"/> \n\
<div id="isl">IMG_NAME_VERSION \n\
<div id="isl-tab"> \n\
<table> \n\
<tbody> \n\
IMG_STACK_LOG \n\
</tbody> \n\
</table> \n\
</div> \n\
</div>' \n\
#-----------------------------------------------------------------------------------------------------------------------
#-----------------------------------------------------------------------------------------------------------------------
ARG SERVER_SV_CSS_HEADER_B='repeat-x;'
#-----------------------------------------------------------------------------------------------------------------------
ARG SERVER_SV_CSS_HEADER_A='repeat-x; \n\
display: flex; \n\
align-items: center; \n\
justify-content: space-between; \n\
font-size: 14px; \n\
font-weight: bold; \n\
} \n\
\n\
\#isl { \n\
position: relative; \n\
display: inline-block; \n\
cursor: pointer; \n\
} \n\
\n\
\#isl-tab { \n\
visibility: hidden; \n\
width: fit-content; \n\
background: #00000000; \n\
color: white; \n\
padding: 2px; \n\
border-radius: 4px; \n\
position: absolute; \n\
z-index: 1; \n\
top: 100%; \n\
left: 50%; \n\
transform: translateX(-50%); \n\
opacity: 0; \n\
transition: opacity 0.3s; \n\
} \n\
\n\
\#isl:hover #isl-tab { \n\
visibility: visible; \n\
opacity: 1; \n\
} \n\
\n\
\#isl-tab table td, \n\
\#isl-tab table th { \n\
white-space: nowrap; \n\
padding: 4px 8px; \n\
border: 1px solid #666; \n\
} \n\
\n\
\#isl-tab table th { \n\
border-bottom: 1px solid #888; \n\
} \n\
\n\
\#isl-tab table { \n\
border-collapse: collapse; \n\
width: fit-content; \n\
max-width: 500px; \n\
overflow-x: auto; \n\
border: 1px solid #666; \n\
'
#-----------------------------------------------------------------------------------------------------------------------
#-----------------------------------------------------------------------------------------------------------------------
@@ -81,15 +164,15 @@ else
\n\
cp '${SERVER_DNSMASQ_CONF}'.dist '${SERVER_DNSMASQ_CONF}' \n\
\n\
echo "" >> '${SERVER_DNSMASQ_CONF}' \n\
echo "# Listen local address" >> '${SERVER_DNSMASQ_CONF}' \n\
echo "interface=lo" >> '${SERVER_DNSMASQ_CONF}' \n\
echo "bind-interfaces" >> '${SERVER_DNSMASQ_CONF}' \n\
echo "" >> '${SERVER_DNSMASQ_CONF}' \n\
echo "port=53 # DNS only" >> '${SERVER_DNSMASQ_CONF}' \n\
echo "no-dhcp-interface= # disables DHCPv4" >> '${SERVER_DNSMASQ_CONF}' \n\
echo "" >> '${SERVER_DNSMASQ_CONF}' \n\
echo "# Forward local domains" >> '${SERVER_DNSMASQ_CONF}' \n\
echo "" >> '${SERVER_DNSMASQ_CONF}' \n\
echo "# Listen local address" >> '${SERVER_DNSMASQ_CONF}' \n\
echo "interface=lo" >> '${SERVER_DNSMASQ_CONF}' \n\
echo "bind-interfaces" >> '${SERVER_DNSMASQ_CONF}' \n\
echo "" >> '${SERVER_DNSMASQ_CONF}' \n\
echo "port=53 # DNS only" >> '${SERVER_DNSMASQ_CONF}' \n\
echo "no-dhcp-interface= # disables DHCPv4" >> '${SERVER_DNSMASQ_CONF}' \n\
echo "" >> '${SERVER_DNSMASQ_CONF}' \n\
echo "# Forward local domains" >> '${SERVER_DNSMASQ_CONF}' \n\
\n\
for map in ${SERVER_DNS_MAP} \n\
do \n\
@@ -101,19 +184,19 @@ else
domain="$1" \n\
server="$2" \n\
\n\
echo "server=/${domain}/${server}" >> '${SERVER_DNSMASQ_CONF}' \n\
echo "server=/${domain}/${server}" >> '${SERVER_DNSMASQ_CONF}' \n\
done \n\
\n\
echo "" >> '${SERVER_DNSMASQ_CONF}' \n\
echo "# Forward all other queries to default server" >> '${SERVER_DNSMASQ_CONF}' \n\
echo "server=${SERVER_DNS_DEFAULT}" >> '${SERVER_DNSMASQ_CONF}' \n\
echo "" >> '${SERVER_DNSMASQ_CONF}' \n\
echo "# Forward all other queries to default server" >> '${SERVER_DNSMASQ_CONF}' \n\
echo "server=${SERVER_DNS_DEFAULT}" >> '${SERVER_DNSMASQ_CONF}' \n\
\n\
cp /etc/resolv.conf /etc/resolv.conf.old \n\
\n\
echo "# Generated by DNSMasq init script" > '${SERVER_RESOLV_CONF}' \n\
echo "" >> '${SERVER_RESOLV_CONF}' \n\
echo "nameserver 127.0.0.1" >> '${SERVER_RESOLV_CONF}' \n\
echo "search ${SERVER_DNS_SEARCH}" >> '${SERVER_RESOLV_CONF}' \n\
echo "# Generated by DNSMasq init script" > '${SERVER_RESOLV_CONF}' \n\
echo "" >> '${SERVER_RESOLV_CONF}' \n\
echo "nameserver 127.0.0.1" >> '${SERVER_RESOLV_CONF}' \n\
echo "search ${SERVER_DNS_SEARCH}" >> '${SERVER_RESOLV_CONF}' \n\
\n\
fi'
#-----------------------------------------------------------------------------------------------------------------------
@@ -121,17 +204,19 @@ fi'
#-----------------------------------------------------------------------------------------------------------------------
ARG SUPERVISORD='#!/bin/bash \n\
\n\
exec supervisord -c /etc/supervisord.conf'
#-----------------------------------------------------------------------------------------------------------------------
#-----------------------------------------------------------------------------------------------------------------------
ARG SUPERVISORD_INI='[inet_http_server] \n\
port=*:'${SERVER_PORT_SV_INT}' \n\
if [[ "${SERVER_SV_HTTPD_ENABLED}" == "FALSE" ]] \n\
then \n\
file_enable "'${SERVER_SV_HTTPD_INI}'" FALSE \n\
else \n\
file_enable "'${SERVER_SV_HTTPD_INI}'" TRUE \n\
fi \n\
\n\
[supervisord] \n\
nodaemon=true \n\
childlogdir='${SERVER_LOG_SV_DIR}' \n\
user=root'
cp '${SERVER_SV_HTTPD_CSS}.ref' '${SERVER_SV_HTTPD_CSS}' \n\
cp '${SERVER_SV_HTTPD_PAGE}.ref' '${SERVER_SV_HTTPD_PAGE}' \n\
sed -i -e "s%IMG_NAME_VERSION%$(isl_last)%" '${SERVER_SV_HTTPD_PAGE}' \n\
sed -i -e "s%IMG_STACK_LOG%$(isl_html_dump)%" '${SERVER_SV_HTTPD_PAGE}' \n\
\n\
exec supervisord -c /etc/supervisord.conf'
#-----------------------------------------------------------------------------------------------------------------------
#-----------------------------------------------------------------------------------------------------------------------
@@ -144,9 +229,22 @@ ARG DNSMASQ_INI='[program:dnsmasq]
command=dnsmasq -k'
#-----------------------------------------------------------------------------------------------------------------------
#-----------------------------------------------------------------------------------------------------------------------
ARG SUPERVISORD_INI='[supervisord] \n\
nodaemon=true \n\
childlogdir='${SERVER_LOG_SV_DIR}' \n\
user=root'
#-----------------------------------------------------------------------------------------------------------------------
#-----------------------------------------------------------------------------------------------------------------------
ARG SUPERVISORD_HTTPD_INI='[inet_http_server] \n\
port=*:'${SERVER_PORT_SV_INT}
#-----------------------------------------------------------------------------------------------------------------------
RUN urpmi.update -a \
RUN . /etc/profile.d/rx3.sh && isl_add ${IMG_URL} \
&& urpmi.update -a \
&& urpmi --force dnsmasq myip supervisor \
&& rm -f /var/log/README \
&& echo -e "${INIT_SHELL}" | sed -e "s/\`/'/g" -e 's/ *$//' > /usr/local/sbin/init.sh \
@@ -154,25 +252,35 @@ RUN urpmi.update -a
&& mkdir /etc/rc.d/rcD.d \
&& ln -s /etc/rc.d/rcD.d /etc \
&& mkdir "${SERVER_LOG_INIT_DIR}" \
&& echo -e "${CROND}" | sed -e "s/\`/'/g" -e 's/ *$//' > /etc/init.d/crond \
&& echo -e "${DNSMASQ}" | sed -e "s/\`/'/g" -e 's/ *$//' > /etc/init.d/dnsmasq \
&& echo -e "${SUPERVISORD}" | sed -e "s/\`/'/g" -e 's/ *$//' > /etc/init.d/supervisord \
&& echo -e "${CROND}" | sed -e "s/\`/'/g" -e 's/ *$//' > /etc/init.d/crond \
&& echo -e "${DNSMASQ}" | sed -e "s/\`/'/g" -e 's/ *$//' > /etc/init.d/dnsmasq \
&& echo -e "${SUPERVISORD}" | sed -e "s/\`/'/g" -e 's/ *$//' > /etc/init.d/supervisord \
&& chmod a+x /etc/init.d/crond \
&& chmod a+x /etc/init.d/dnsmasq \
&& chmod a+x /etc/init.d/supervisord \
&& ln -s /etc/init.d/crond /etc/rcD.d/S60crond \
&& ln -s /etc/init.d/dnsmasq /etc/rcD.d/S65dnsmasq \
&& ln -s /etc/init.d/supervisord /etc/rcD.d/S99supervisord \
&& echo -e "${CROND_INI}" | sed -e "s/\`/'/g" -e 's/ *$//' > /etc/supervisord.d/crond.ini \
&& echo -e "${DNSMASQ_INI}" | sed -e "s/\`/'/g" -e 's/ *$//' > /etc/supervisord.d/dnsmasq.ini \
&& echo -e "${SUPERVISORD_INI}" | sed -e "s/\`/'/g" -e 's/ *$//' > /etc/supervisord.d/supervisord.ini \
&& mv "${SERVER_DNSMASQ_CONF}" "${SERVER_DNSMASQ_CONF}.dist"
&& echo -e "${CROND_INI}" | sed -e "s/\`/'/g" -e 's/ *$//' > ${SERVER_CROND_INI} \
&& echo -e "${DNSMASQ_INI}" | sed -e "s/\`/'/g" -e 's/ *$//' > ${SERVER_DNSMASQ_INI} \
&& echo -e "${SUPERVISORD_INI}" | sed -e "s/\`/'/g" -e 's/ *$//' > ${SERVER_SV_INI} \
&& echo -e "${SUPERVISORD_HTTPD_INI}" | sed -e "s/\`/'/g" -e 's/ *$//' > ${SERVER_SV_HTTPD_INI} \
&& mv "${SERVER_DNSMASQ_CONF}" "${SERVER_DNSMASQ_CONF}.dist" \
&& mv "${SERVER_SV_HTTPD_PAGE}" "${SERVER_SV_HTTPD_PAGE}.ref" \
&& sed -i -e "s%${SERVER_SV_HTML_IMG_B}%${SERVER_SV_HTML_IMG_A}%" "${SERVER_SV_HTTPD_PAGE}.ref" \
&& mv "${SERVER_SV_HTTPD_CSS}" "${SERVER_SV_HTTPD_CSS}.ref" \
&& sed -i -e "s/${SERVER_SV_CSS_HEADER_B}/${SERVER_SV_CSS_HEADER_A}/" "${SERVER_SV_HTTPD_CSS}.ref"
VOLUME ${SERVER_LOG_INIT_DIR}
VOLUME ${SERVER_LOG_SV_DIR}
EXPOSE ${SERVER_PORT_SV_INT}
CMD []
ENTRYPOINT ["init.sh"]

View File

@@ -5,10 +5,11 @@ Welcome to Rx3-Docker/Server docker image!
This project aims to build a Mageia server docker image to be used by other Rx3 packaging projects.
Features:
- Curtently based on rx3-docker/base:1.3.6-mga9 image,
- Curtently based on rx3-docker/base:1.4.0-mga9 image,
- Init script calling in order sub scripts in /etc/init.d & /etc/rcD.d,
- supervisord managing services,
- crond & logrotate configured & crond disabled by default,
- supervisord httpd configured and enabled by default,
- crond & logrotate configured with crond disabled by default,
- DNS forwarding support with dnsmasq, disabled by default,
- myip tool,
- Export init & supivisor log directories as volume.

View File

@@ -1,3 +1,16 @@
------------------------------------------------------------------------------------------------------------------------------------
Rx3-Docker/Server V 1.3.0 - A. GIBERT - 2026/02/13
------------------------------------------------------------------------------------------------------------------------------------
- Add ISL support,
- Add ISL display to supervisor HTTPD status page,
- Add SERVER_SV_HTTPD_ENABLED env variable,
- Use now supervisor 4.3.0,
- Use now rx3-docker/base:1.4.0-mga9 image,
- Rebuild for updates.
------------------------------------------------------------------------------------------------------------------------------------
Rx3-Docker/Server V 1.2.7 - A. GIBERT - 2025/11/28
------------------------------------------------------------------------------------------------------------------------------------

View File

@@ -17,6 +17,7 @@ services:
IMG_NAME: ${IMG_NAME}
IMG_NAME_FULL: ${IMG_NAME_FULL}
IMG_VERSION: ${IMG_VERSION}
IMG_URL: ${IMG_URL}
IMG_MAINTAINER: ${IMG_MAINTAINER}
IMG_FROM_URL: ${IMG_FROM_URL}
@@ -32,6 +33,7 @@ services:
SERVER_DNS_DEFAULT: ${SERVER_DNS_DEFAULT}
SERVER_DNS_MAP: ${SERVER_DNS_MAP}
SERVER_DNS_SEARCH: ${SERVER_DNS_SEARCH}
SERVER_SV_HTTPD_ENABLED: ${SERVER_SV_HTTPD_ENABLED}
volumes:
- ./var/log/init:${SERVER_LOG_INIT_DIR}

View File

@@ -18,13 +18,13 @@ ORG_URL_PREFIX="${ORG_REGISTRY}/${ORG_NAME}"
IMG_NAME="server"
IMG_NAME_FULL="Rx3-Docker/Server Docker Image"
IMG_VERSION="1.2.7-mga9"
IMG_VERSION="1.3.0-mga9"
IMG_MAINTAINER='"Arnaud G. GIBERT" <arnaud@rx3.net>'
IMG_URL_PREFIX="${ORG_URL_PREFIX}"
IMG_URL="${IMG_URL_PREFIX}/${IMG_NAME}:${IMG_VERSION}"
IMG_FROM_URL="${ORG_URL_PREFIX}/base:1.3.6-mga9"
IMG_FROM_URL="${ORG_URL_PREFIX}/base:1.4.0-mga9"
@@ -43,6 +43,8 @@ SERVER_PORT_SV_INT=9001
SERVER_LOG_INIT_DIR="/var/log/init"
SERVER_LOG_SV_DIR="/var/log/supervisor"
SERVER_SV_HTTPD_ENABLED="TRUE"
SERVER_CROND_ENABLED="FALSE"
SERVER_DNS_ENABLED="FALSE"