updated
This commit is contained in:
159
Dockerfile
159
Dockerfile
@@ -9,16 +9,6 @@ LABEL description="ONLYOFFICE DocumentServer for ARM64 and AMD64"
|
|||||||
ARG BASE_VERSION
|
ARG BASE_VERSION
|
||||||
ARG PG_VERSION=16
|
ARG PG_VERSION=16
|
||||||
ARG PACKAGE_SUFFIX=t64
|
ARG PACKAGE_SUFFIX=t64
|
||||||
ENV OC_RELEASE_NUM=23
|
|
||||||
ENV OC_RU_VER=7
|
|
||||||
ENV OC_RU_REVISION_VER=0
|
|
||||||
ENV OC_RESERVED_NUM=25
|
|
||||||
ENV OC_RU_DATE=01
|
|
||||||
ENV OC_PATH=${OC_RELEASE_NUM}${OC_RU_VER}0000
|
|
||||||
ENV OC_FILE_SUFFIX=${OC_RELEASE_NUM}.${OC_RU_VER}.${OC_RU_REVISION_VER}.${OC_RESERVED_NUM}.${OC_RU_DATE}
|
|
||||||
ENV OC_VER_DIR=${OC_RELEASE_NUM}_${OC_RU_VER}
|
|
||||||
ENV OC_DOWNLOAD_URL=https://download.oracle.com/otn_software/linux/instantclient/${OC_PATH}
|
|
||||||
|
|
||||||
|
|
||||||
ENV LANG=en_US.UTF-8 \
|
ENV LANG=en_US.UTF-8 \
|
||||||
LANGUAGE=en_US:en \
|
LANGUAGE=en_US:en \
|
||||||
@@ -40,7 +30,7 @@ ENV COMPANY_NAME=$COMPANY_NAME \
|
|||||||
DS_PLUGIN_INSTALLATION=false \
|
DS_PLUGIN_INSTALLATION=false \
|
||||||
DS_DOCKER_INSTALLATION=true
|
DS_DOCKER_INSTALLATION=true
|
||||||
|
|
||||||
|
# Default internal DB credentials
|
||||||
ENV DB_TYPE=postgres \
|
ENV DB_TYPE=postgres \
|
||||||
DB_HOST=localhost \
|
DB_HOST=localhost \
|
||||||
DB_PORT=5432 \
|
DB_PORT=5432 \
|
||||||
@@ -48,178 +38,117 @@ ENV DB_TYPE=postgres \
|
|||||||
DB_USER=onlyoffice \
|
DB_USER=onlyoffice \
|
||||||
DB_PWD=onlyoffice
|
DB_PWD=onlyoffice
|
||||||
|
|
||||||
# Redis Configuration
|
# Redis
|
||||||
ENV REDIS_SERVER_HOST=localhost \
|
ENV REDIS_SERVER_HOST=localhost \
|
||||||
REDIS_SERVER_PORT=6379 \
|
REDIS_SERVER_PORT=6379 \
|
||||||
REDIS_ENABLED=true
|
REDIS_ENABLED=true
|
||||||
|
|
||||||
# RabbitMQ Configuration
|
# RabbitMQ
|
||||||
ENV AMQP_SERVER_HOST=localhost \
|
ENV AMQP_SERVER_HOST=localhost \
|
||||||
AMQP_SERVER_PORT=5672 \
|
AMQP_SERVER_PORT=5672 \
|
||||||
AMQP_SERVER_USER=guest \
|
AMQP_SERVER_USER=guest \
|
||||||
AMQP_SERVER_PWD=guest \
|
AMQP_SERVER_PWD=guest \
|
||||||
AMQP_SERVER_PROTO=amqp
|
AMQP_SERVER_PROTO=amqp
|
||||||
|
|
||||||
# JWT Configuration (disabled by default)
|
# JWT
|
||||||
ENV JWT_ENABLED=false \
|
ENV JWT_ENABLED=false \
|
||||||
JWT_SECRET=secret \
|
JWT_SECRET=secret \
|
||||||
JWT_HEADER=Authorization \
|
JWT_HEADER=Authorization \
|
||||||
JWT_IN_BODY=false
|
JWT_IN_BODY=false
|
||||||
|
|
||||||
# Other settings
|
# Other
|
||||||
ENV WOPI_ENABLED=false \
|
ENV WOPI_ENABLED=false \
|
||||||
GENERATE_FONTS=true \
|
GENERATE_FONTS=true \
|
||||||
METRICS_ENABLED=false \
|
METRICS_ENABLED=false \
|
||||||
PLUGINS_ENABLED=true \
|
PLUGINS_ENABLED=true \
|
||||||
DS_LOG_LEVEL=WARN
|
DS_LOG_LEVEL=WARN
|
||||||
|
|
||||||
# Create policy to allow services to start
|
# Allow services to start inside build
|
||||||
RUN echo "#!/bin/sh\nexit 0" > /usr/sbin/policy-rc.d
|
RUN echo "#!/bin/sh\nexit 0" > /usr/sbin/policy-rc.d
|
||||||
|
|
||||||
# Install base packages
|
# Base packages
|
||||||
RUN apt-get -y update && \
|
RUN apt-get -y update && \
|
||||||
apt-get -yq install \
|
apt-get -y install wget apt-transport-https gnupg locales lsb-release && \
|
||||||
wget \
|
|
||||||
apt-transport-https \
|
|
||||||
gnupg \
|
|
||||||
locales \
|
|
||||||
lsb-release && \
|
|
||||||
locale-gen en_US.UTF-8
|
locale-gen en_US.UTF-8
|
||||||
|
|
||||||
# Add Microsoft repository for SQL tools
|
# SQL tools repository
|
||||||
RUN wget -q -O /etc/apt/sources.list.d/mssql-release.list \
|
RUN wget -q -O /etc/apt/sources.list.d/mssql-release.list \
|
||||||
"https://packages.microsoft.com/config/ubuntu/$BASE_VERSION/prod.list" && \
|
"https://packages.microsoft.com/config/ubuntu/$BASE_VERSION/prod.list" && \
|
||||||
wget -q -O /tmp/microsoft.asc https://packages.microsoft.com/keys/microsoft.asc && \
|
wget -q -O /tmp/microsoft.asc https://packages.microsoft.com/keys/microsoft.asc && \
|
||||||
apt-key add /tmp/microsoft.asc && \
|
apt-key add /tmp/microsoft.asc && \
|
||||||
gpg --dearmor -o /usr/share/keyrings/microsoft-prod.gpg < /tmp/microsoft.asc
|
gpg --dearmor -o /usr/share/keyrings/microsoft-prod.gpg < /tmp/microsoft.asc
|
||||||
|
|
||||||
# Accept Microsoft fonts EULA
|
# Fonts EULA
|
||||||
RUN echo ttf-mscorefonts-installer msttcorefonts/accepted-mscorefonts-eula select true | debconf-set-selections
|
RUN echo ttf-mscorefonts-installer msttcorefonts/accepted-mscorefonts-eula select true | debconf-set-selections
|
||||||
|
|
||||||
# Install all required packages
|
# Install dependencies
|
||||||
RUN apt-get -y update && \
|
RUN apt-get -y update && \
|
||||||
ACCEPT_EULA=Y apt-get -yq install \
|
ACCEPT_EULA=Y apt-get -y install \
|
||||||
adduser \
|
adduser apt-utils bomstrip certbot cron curl htop \
|
||||||
apt-utils \
|
libaio1${PACKAGE_SUFFIX} libasound2${PACKAGE_SUFFIX} libboost-regex-dev \
|
||||||
bomstrip \
|
libcairo2 libcurl3-gnutls libcurl4 libgtk-3-0 libnspr4 libnss3 libstdc++6 \
|
||||||
certbot \
|
libxml2 libxss1 libxtst6 mssql-tools18 mysql-client nano net-tools \
|
||||||
cron \
|
netcat-openbsd nginx-extras postgresql postgresql-client pwgen \
|
||||||
curl \
|
rabbitmq-server redis-server sudo supervisor \
|
||||||
htop \
|
ttf-mscorefonts-installer unixodbc-dev unzip xvfb xxd zlib1g
|
||||||
libaio1${PACKAGE_SUFFIX} \
|
|
||||||
libasound2${PACKAGE_SUFFIX} \
|
|
||||||
libboost-regex-dev \
|
|
||||||
libcairo2 \
|
|
||||||
libcurl3-gnutls \
|
|
||||||
libcurl4 \
|
|
||||||
libgtk-3-0 \
|
|
||||||
libnspr4 \
|
|
||||||
libnss3 \
|
|
||||||
libstdc++6 \
|
|
||||||
libxml2 \
|
|
||||||
libxss1 \
|
|
||||||
libxtst6 \
|
|
||||||
mssql-tools18 \
|
|
||||||
mysql-client \
|
|
||||||
nano \
|
|
||||||
net-tools \
|
|
||||||
netcat-openbsd \
|
|
||||||
nginx-extras \
|
|
||||||
postgresql \
|
|
||||||
postgresql-client \
|
|
||||||
pwgen \
|
|
||||||
rabbitmq-server \
|
|
||||||
redis-server \
|
|
||||||
sudo \
|
|
||||||
supervisor \
|
|
||||||
ttf-mscorefonts-installer \
|
|
||||||
unixodbc-dev \
|
|
||||||
unzip \
|
|
||||||
xvfb \
|
|
||||||
xxd \
|
|
||||||
zlib1g || dpkg --configure -a
|
|
||||||
|
|
||||||
# Verify Microsoft fonts installation
|
# Verify fonts
|
||||||
RUN if [ $(find /usr/share/fonts/truetype/msttcorefonts -maxdepth 1 -type f -iname '*.ttf' | wc -l) -lt 30 ]; then \
|
RUN if [ $(find /usr/share/fonts/truetype/msttcorefonts -maxdepth 1 -type f | wc -l) -lt 20 ]; then \
|
||||||
echo 'msttcorefonts failed to download'; exit 1; \
|
echo "Fonts missing"; exit 1; \
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# Configure RabbitMQ for single CPU
|
# Redis bind to localhost
|
||||||
RUN echo "SERVER_ADDITIONAL_ERL_ARGS=\"+S 1:1\"" | tee -a /etc/rabbitmq/rabbitmq-env.conf
|
|
||||||
|
|
||||||
# Configure Redis to bind to localhost only
|
|
||||||
RUN sed -i "s/bind .*/bind 127.0.0.1/g" /etc/redis/redis.conf
|
RUN sed -i "s/bind .*/bind 127.0.0.1/g" /etc/redis/redis.conf
|
||||||
|
|
||||||
# Add wasm mime type to nginx
|
# Add wasm MIME
|
||||||
RUN sed 's|\(application\/zip.*\)|\1\n application\/wasm wasm;|' -i /etc/nginx/mime.types
|
RUN sed 's|\(application\/zip.*\)|\1\n application\/wasm wasm;|' -i /etc/nginx/mime.types
|
||||||
|
|
||||||
# Configure PostgreSQL
|
# PostgreSQL config
|
||||||
RUN pg_conftool $PG_VERSION main set listen_addresses 'localhost'
|
RUN pg_conftool $PG_VERSION main set listen_addresses 'localhost'
|
||||||
|
|
||||||
# Start PostgreSQL and create user/database
|
# Prepare internal PostgreSQL
|
||||||
RUN service postgresql restart && \
|
RUN service postgresql restart && \
|
||||||
sudo -u postgres psql -c "CREATE USER ${DB_USER} WITH password '${DB_PWD}';" && \
|
sudo -u postgres psql -c "CREATE ROLE ${DB_USER} LOGIN PASSWORD '${DB_PWD}';" && \
|
||||||
sudo -u postgres psql -c "CREATE DATABASE ${DB_NAME} OWNER ${DB_USER};"
|
sudo -u postgres psql -c "CREATE DATABASE ${DB_NAME} OWNER ${DB_USER};" && \
|
||||||
|
service postgresql stop
|
||||||
|
|
||||||
# Download and install Oracle Instant Client (architecture-specific)
|
# Install Oracle Instant Client
|
||||||
RUN wget -O basic.zip ${OC_DOWNLOAD_URL}/instantclient-basic-linux.$(dpkg --print-architecture | sed 's/amd64/x64/')-${OC_FILE_SUFFIX}.zip && \
|
RUN wget -q -O basic.zip https://download.oracle.com/otn_software/linux/instantclient/23070000/instantclient-basic-linux.$(dpkg --print-architecture | sed 's/amd64/x64/').23.7.0.0.0.25.01.zip && \
|
||||||
wget -O sqlplus.zip ${OC_DOWNLOAD_URL}/instantclient-sqlplus-linux.$(dpkg --print-architecture | sed 's/amd64/x64/')-${OC_FILE_SUFFIX}.zip && \
|
wget -q -O sqlplus.zip https://download.oracle.com/otn_software/linux/instantclient/23070000/instantclient-sqlplus-linux.$(dpkg --print-architecture | sed 's/amd64/x64/').23.7.0.0.0.25.01.zip && \
|
||||||
unzip -o basic.zip -d /usr/share && \
|
unzip -o basic.zip -d /usr/share && \
|
||||||
unzip -o sqlplus.zip -d /usr/share && \
|
unzip -o sqlplus.zip -d /usr/share && \
|
||||||
mv /usr/share/instantclient_${OC_VER_DIR} /usr/share/instantclient && \
|
mv /usr/share/instantclient_23_7 /usr/share/instantclient && \
|
||||||
find /usr/lib /lib -name "libaio.so.1$PACKAGE_SUFFIX" -exec bash -c 'ln -sf "$0" "$(dirname "$0")/libaio.so.1"' {} \; && \
|
|
||||||
rm -f basic.zip sqlplus.zip
|
rm -f basic.zip sqlplus.zip
|
||||||
|
|
||||||
# Stop services that were started during build
|
# Stop unwanted services
|
||||||
RUN service postgresql stop && \
|
RUN service postgresql stop && \
|
||||||
service redis-server stop && \
|
service redis-server stop && \
|
||||||
service rabbitmq-server stop && \
|
service rabbitmq-server stop && \
|
||||||
service supervisor stop && \
|
service supervisor stop && \
|
||||||
service nginx stop
|
service nginx stop
|
||||||
|
|
||||||
# Clean up apt cache
|
# Copy Supervisor configs & run script
|
||||||
RUN rm -rf /var/lib/apt/lists/*
|
|
||||||
|
|
||||||
# Copy configuration files
|
|
||||||
COPY config/supervisor/supervisor /etc/init.d/
|
COPY config/supervisor/supervisor /etc/init.d/
|
||||||
COPY config/supervisor/ds/*.conf /etc/supervisor/conf.d/
|
COPY config/supervisor/ds/*.conf /etc/supervisor/conf.d/
|
||||||
COPY run-document-server.sh /app/ds/run-document-server.sh
|
COPY run-document-server.sh /app/ds/run-document-server.sh
|
||||||
|
|
||||||
# Create sqlplus wrapper
|
|
||||||
RUN mkdir -p /usr/bin && \
|
|
||||||
echo '#!/bin/bash' > /usr/bin/sqlplus && \
|
|
||||||
echo 'export LD_LIBRARY_PATH=/usr/share/instantclient:$LD_LIBRARY_PATH' >> /usr/bin/sqlplus && \
|
|
||||||
echo 'exec /usr/share/instantclient/sqlplus "$@"' >> /usr/bin/sqlplus && \
|
|
||||||
chmod +x /usr/bin/sqlplus
|
|
||||||
|
|
||||||
# Expose ports
|
|
||||||
EXPOSE 80 443
|
EXPOSE 80 443
|
||||||
|
|
||||||
# Download and install ONLYOFFICE DocumentServer package
|
# Install ONLYOFFICE DocumentServer package
|
||||||
RUN PACKAGE_FILE="${COMPANY_NAME}-${PRODUCT_NAME}${PRODUCT_EDITION}${PACKAGE_VERSION:+_$PACKAGE_VERSION}_${TARGETARCH:-$(dpkg --print-architecture)}.deb" && \
|
RUN PACKAGE_FILE="${COMPANY_NAME}-${PRODUCT_NAME}${PRODUCT_EDITION}${PACKAGE_VERSION:+_$PACKAGE_VERSION}_${TARGETARCH:-$(dpkg --print-architecture)}.deb" && \
|
||||||
echo "Downloading package: $PACKAGE_BASEURL/$PACKAGE_FILE" && \
|
|
||||||
wget -q -P /tmp "$PACKAGE_BASEURL/$PACKAGE_FILE" && \
|
wget -q -P /tmp "$PACKAGE_BASEURL/$PACKAGE_FILE" && \
|
||||||
apt-get -y update && \
|
apt-get -y update && \
|
||||||
service postgresql start && \
|
service postgresql start && \
|
||||||
apt-get -yq install /tmp/$PACKAGE_FILE && \
|
apt-get -y install /tmp/$PACKAGE_FILE && \
|
||||||
# Clean up temp database used during installation
|
|
||||||
PGPASSWORD=$DB_PWD dropdb -h localhost -p 5432 -U $DB_USER $DB_NAME 2>/dev/null || true && \
|
|
||||||
sudo -u postgres psql -c "DROP ROLE IF EXISTS ${DB_USER};" 2>/dev/null || true && \
|
|
||||||
service postgresql stop && \
|
service postgresql stop && \
|
||||||
chmod 755 /etc/init.d/supervisor && \
|
rm -f /tmp/$PACKAGE_FILE
|
||||||
sed "s/COMPANY_NAME/${COMPANY_NAME}/g" -i /etc/supervisor/conf.d/*.conf && \
|
|
||||||
service supervisor stop && \
|
|
||||||
chmod 755 /app/ds/*.sh && \
|
|
||||||
# Add GO command for MSSQL scripts
|
|
||||||
printf "\nGO" >> "/var/www/$COMPANY_NAME/documentserver/server/schema/mssql/createdb.sql" && \
|
|
||||||
printf "\nGO" >> "/var/www/$COMPANY_NAME/documentserver/server/schema/mssql/removetbl.sql" && \
|
|
||||||
# Add exit command for Oracle scripts
|
|
||||||
printf "\nexit" >> "/var/www/$COMPANY_NAME/documentserver/server/schema/oracle/createdb.sql" && \
|
|
||||||
printf "\nexit" >> "/var/www/$COMPANY_NAME/documentserver/server/schema/oracle/removetbl.sql" && \
|
|
||||||
rm -f /tmp/$PACKAGE_FILE && \
|
|
||||||
rm -rf /var/log/$COMPANY_NAME && \
|
|
||||||
rm -rf /var/lib/apt/lists/*
|
|
||||||
|
|
||||||
|
# Recreate ONLYOFFICE DB with proper schema
|
||||||
|
RUN service postgresql start && \
|
||||||
|
sudo -u postgres psql -tc "SELECT 1 FROM pg_database WHERE datname='onlyoffice';" | grep -q 1 || \
|
||||||
|
sudo -u postgres psql -c "CREATE DATABASE onlyoffice OWNER onlyoffice;" && \
|
||||||
|
sudo -u postgres psql -d onlyoffice -f /var/www/onlyoffice/documentserver/server/schema/postgresql/createdb.sql && \
|
||||||
|
service postgresql stop
|
||||||
|
|
||||||
VOLUME /var/log/$COMPANY_NAME \
|
VOLUME /var/log/$COMPANY_NAME \
|
||||||
/var/lib/$COMPANY_NAME \
|
/var/lib/$COMPANY_NAME \
|
||||||
|
|||||||
Reference in New Issue
Block a user