mirror of
https://github.com/sadan4/dotfiles.git
synced 2025-02-27 02:28:53 -05:00
use relative path rename dockerfile and change build arg try systemd tmpfiles add docker entrypoint use more systemd tmpfiles whoops i was missing a file remove home.files and move to systemd.tmpfiles dont use root make immutable make immutable v2 whoops remove +i needs to be executable
104 lines
4.3 KiB
Docker
104 lines
4.3 KiB
Docker
# Licensed under the Apache License, Version 2.0 (the "License"); you may not
|
|
# use this file except in compliance with the License. You may obtain a copy of
|
|
# the License at
|
|
#
|
|
# http://www.apache.org/licenses/LICENSE-2.0
|
|
#
|
|
# Unless required by applicable law or agreed to in writing, software
|
|
# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
|
|
# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
|
|
# License for the specific language governing permissions and limitations under
|
|
# the License.
|
|
|
|
FROM debian:bookworm-slim
|
|
|
|
LABEL maintainer="CouchDB Developers dev@couchdb.apache.org"
|
|
|
|
# Add CouchDB user account to make sure the IDs are assigned consistently
|
|
RUN groupadd -g 1000 -r couchdb && useradd -u 1000 -d /opt/couchdb -g couchdb couchdb
|
|
|
|
# be sure GPG and apt-transport-https are available and functional
|
|
RUN set -ex; \
|
|
apt-get update; \
|
|
apt-get install -y --no-install-recommends \
|
|
apt-transport-https \
|
|
ca-certificates \
|
|
dirmngr \
|
|
gnupg \
|
|
; \
|
|
rm -rf /var/lib/apt/lists/*
|
|
|
|
# grab tini for signal handling and zombie reaping
|
|
# see https://github.com/apache/couchdb-docker/pull/28#discussion_r141112407
|
|
RUN set -eux; \
|
|
apt-get update; \
|
|
apt-get install -y --no-install-recommends tini; \
|
|
rm -rf /var/lib/apt/lists/*; \
|
|
tini --version
|
|
|
|
# http://docs.couchdb.org/en/latest/install/unix.html#installing-the-apache-couchdb-packages
|
|
ENV GPG_COUCH_KEY \
|
|
# gpg: rsa8192 205-01-19 The Apache Software Foundation (Package repository signing key) <root@apache.org>
|
|
390EF70BB1EA12B2773962950EE62FB37A00258D
|
|
RUN set -eux; \
|
|
apt-get update; \
|
|
apt-get install -y curl; \
|
|
export GNUPGHOME="$(mktemp -d)"; \
|
|
curl -fL -o keys.asc https://couchdb.apache.org/repo/keys.asc; \
|
|
gpg --batch --import keys.asc; \
|
|
gpg --batch --export "${GPG_COUCH_KEY}" > /usr/share/keyrings/couchdb-archive-keyring.gpg; \
|
|
command -v gpgconf && gpgconf --kill all || :; \
|
|
rm -rf "$GNUPGHOME"; \
|
|
apt-key list; \
|
|
apt purge -y --autoremove curl; \
|
|
rm -rf /var/lib/apt/lists/*
|
|
|
|
ENV COUCHDB_VERSION 3.4.2
|
|
|
|
RUN . /etc/os-release; \
|
|
echo "deb [signed-by=/usr/share/keyrings/couchdb-archive-keyring.gpg] https://apache.jfrog.io/artifactory/couchdb-deb/ ${VERSION_CODENAME} main" | \
|
|
tee /etc/apt/sources.list.d/couchdb.list >/dev/null
|
|
|
|
# https://github.com/apache/couchdb-pkg/blob/master/debian/README.Debian
|
|
RUN set -eux; \
|
|
apt-get update; \
|
|
\
|
|
echo "couchdb couchdb/mode select none" | debconf-set-selections; \
|
|
# we DO want recommends this time
|
|
DEBIAN_FRONTEND=noninteractive apt-get install -y --allow-downgrades --allow-remove-essential --allow-change-held-packages \
|
|
couchdb="$COUCHDB_VERSION"~bookworm \
|
|
; \
|
|
# Undo symlinks to /var/log and /var/lib
|
|
rmdir /var/lib/couchdb /var/log/couchdb; \
|
|
rm /opt/couchdb/data /opt/couchdb/var/log; \
|
|
mkdir -p /opt/couchdb/data /opt/couchdb/var/log; \
|
|
chown couchdb:couchdb /opt/couchdb/data /opt/couchdb/var/log; \
|
|
chmod 777 /opt/couchdb/data /opt/couchdb/var/log; \
|
|
# Remove file that sets logging to a file
|
|
rm /opt/couchdb/etc/default.d/10-filelog.ini; \
|
|
# Check we own everything in /opt/couchdb. Matches the command in dockerfile_entrypoint.sh
|
|
find /opt/couchdb \! \( -user couchdb -group couchdb \) -exec chown -f couchdb:couchdb '{}' +; \
|
|
# Setup directories and permissions for config. Technically these could be 555 and 444 respectively
|
|
# but we keep them as 755 and 644 for consistency with CouchDB defaults and the dockerfile_entrypoint.sh.
|
|
find /opt/couchdb/etc -type d ! -perm 0755 -exec chmod -f 0755 '{}' +; \
|
|
find /opt/couchdb/etc -type f ! -perm 0644 -exec chmod -f 0644 '{}' +; \
|
|
# only local.d needs to be writable for the docker_entrypoint.sh
|
|
chmod -f 0777 /opt/couchdb/etc/local.d; \
|
|
# apt clean-up
|
|
rm -rf /var/lib/apt/lists/*;
|
|
|
|
# Add configuration
|
|
COPY --chown=couchdb:couchdb 10-docker-default.ini /opt/couchdb/etc/default.d/
|
|
COPY --chown=couchdb:couchdb vm.args /opt/couchdb/etc/
|
|
|
|
COPY docker-entrypoint.sh /usr/local/bin
|
|
RUN ln -s usr/local/bin/docker-entrypoint.sh /docker-entrypoint.sh # backwards compat
|
|
ENTRYPOINT ["tini", "--", "/docker-entrypoint.sh"]
|
|
|
|
VOLUME /opt/couchdb/data
|
|
|
|
# 5984: Main CouchDB endpoint
|
|
# 4369: Erlang portmap daemon (epmd)
|
|
# 9100: CouchDB cluster communication port
|
|
EXPOSE 5984 4369 9100
|
|
CMD ["/opt/couchdb/bin/couchdb"]
|