- 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:
178
Dockerfile
178
Dockerfile
@@ -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\
|
||||
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\
|
||||
[supervisord] \n\
|
||||
nodaemon=true \n\
|
||||
childlogdir='${SERVER_LOG_SV_DIR}' \n\
|
||||
user=root'
|
||||
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"]
|
||||
|
||||
@@ -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.
|
||||
|
||||
@@ -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
|
||||
------------------------------------------------------------------------------------------------------------------------------------
|
||||
|
||||
@@ -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}
|
||||
|
||||
6
env.dist
6
env.dist
@@ -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"
|
||||
|
||||
Reference in New Issue
Block a user