ClickHouse/docker/server/Dockerfile

70 lines
2.5 KiB
Docker
Raw Normal View History

2020-07-06 10:44:47 +00:00
FROM ubuntu:20.04
2016-06-15 16:50:33 +00:00
2020-06-10 19:26:44 +00:00
ARG repository="deb https://repo.clickhouse.tech/deb/stable/ main/"
ARG version=21.3.1.*
2018-09-21 22:00:57 +00:00
ARG gosu_ver=1.10
2021-01-15 17:58:51 +00:00
# user/group precreated explicitly with fixed uid/gid on purpose.
# It is especially important for rootless containers: in that case entrypoint
# can't do chown and owners of mounted volumes should be configured externally.
# We do that in advance at the begining of Dockerfile before any packages will be
# installed to prevent picking those uid / gid by some unrelated software.
# The same uid / gid (101) is used both for alpine and ubuntu.
RUN groupadd -r clickhouse --gid=101 \
&& useradd -r -g clickhouse --uid=101 --home-dir=/var/lib/clickhouse --shell=/bin/bash clickhouse \
&& apt-get update \
2018-09-21 22:00:57 +00:00
&& apt-get install --yes --no-install-recommends \
apt-transport-https \
ca-certificates \
2018-09-21 22:00:57 +00:00
dirmngr \
gnupg \
&& mkdir -p /etc/apt/sources.list.d \
&& apt-key adv --keyserver keyserver.ubuntu.com --recv E0C56BD4 \
&& echo $repository > /etc/apt/sources.list.d/clickhouse.list \
&& apt-get update \
2020-07-03 21:55:00 +00:00
&& env DEBIAN_FRONTEND=noninteractive \
2020-07-06 08:20:56 +00:00
apt-get --yes -o "Dpkg::Options::=--force-confdef" -o "Dpkg::Options::=--force-confold" upgrade \
2018-09-21 22:00:57 +00:00
&& env DEBIAN_FRONTEND=noninteractive \
apt-get install --allow-unauthenticated --yes --no-install-recommends \
clickhouse-common-static=$version \
2018-12-10 15:23:21 +00:00
clickhouse-client=$version \
2018-09-21 22:00:57 +00:00
clickhouse-server=$version \
2018-12-10 15:23:21 +00:00
locales \
wget \
2018-09-21 22:00:57 +00:00
&& rm -rf \
/var/lib/apt/lists/* \
/var/cache/debconf \
/tmp/* \
&& apt-get clean \
&& mkdir -p /var/lib/clickhouse /var/log/clickhouse-server /etc/clickhouse-server /etc/clickhouse-client \
&& chmod ugo+Xrw -R /var/lib/clickhouse /var/log/clickhouse-server /etc/clickhouse-server /etc/clickhouse-client
2021-01-22 14:28:25 +00:00
# we need to allow "others" access to clickhouse folder, because docker container
# can be started with arbitrary uid (openshift usecase)
2016-06-15 16:50:33 +00:00
ADD https://github.com/tianon/gosu/releases/download/$gosu_ver/gosu-amd64 /bin/gosu
2018-12-10 15:23:21 +00:00
RUN locale-gen en_US.UTF-8
ENV LANG en_US.UTF-8
ENV LANGUAGE en_US:en
ENV LC_ALL en_US.UTF-8
ENV TZ UTC
2018-12-10 15:23:21 +00:00
2018-11-28 19:55:34 +00:00
RUN mkdir /docker-entrypoint-initdb.d
COPY docker_related_config.xml /etc/clickhouse-server/config.d/
2018-09-21 22:00:57 +00:00
COPY entrypoint.sh /entrypoint.sh
RUN chmod +x \
/entrypoint.sh \
/bin/gosu
2016-06-15 16:50:33 +00:00
EXPOSE 9000 8123 9009
2017-02-28 17:12:45 +00:00
VOLUME /var/lib/clickhouse
2016-06-15 16:50:33 +00:00
ENV CLICKHOUSE_CONFIG /etc/clickhouse-server/config.xml
2018-09-21 22:00:57 +00:00
ENTRYPOINT ["/entrypoint.sh"]