1
- FROM debian:jessie
1
+ FROM debian:jessie-slim
2
2
3
3
# add our user and group first to make sure their IDs get assigned consistently, regardless of whatever dependencies get added
4
4
RUN groupadd -r redis && useradd -r -g redis redis
5
5
6
- RUN apt-get update && apt-get install -y --no-install-recommends \
7
- ca-certificates \
8
- wget \
9
- && rm -rf /var/lib/apt/lists/*
10
-
11
6
# grab gosu for easy step-down from root
12
- ENV GOSU_VERSION 1.7
13
- RUN set -x \
14
- && wget -O /usr/local/bin/gosu "https://github.com/tianon/gosu/releases/download/$GOSU_VERSION/gosu-$(dpkg --print-architecture)" \
15
- && wget -O /usr/local/bin/gosu.asc "https://github.com/tianon/gosu/releases/download/$GOSU_VERSION/gosu-$(dpkg --print-architecture).asc" \
16
- && export GNUPGHOME="$(mktemp -d)" \
17
- && gpg --keyserver ha.pool.sks-keyservers.net --recv-keys B42F6819007F00F88E364FD4036A9C25BF357DD4 \
18
- && gpg --batch --verify /usr/local/bin/gosu.asc /usr/local/bin/gosu \
19
- && rm -r "$GNUPGHOME" /usr/local/bin/gosu.asc \
20
- && chmod +x /usr/local/bin/gosu \
21
- && gosu nobody true
7
+ # https://github.com/tianon/gosu/releases
8
+ ENV GOSU_VERSION 1.10
9
+ RUN set -ex; \
10
+ \
11
+ fetchDeps='ca-certificates wget' ; \
12
+ apt-get update; \
13
+ apt-get install -y --no-install-recommends $fetchDeps; \
14
+ rm -rf /var/lib/apt/lists/*; \
15
+ \
16
+ dpkgArch="$(dpkg --print-architecture | awk -F- '{ print $NF }')" ; \
17
+ wget -O /usr/local/bin/gosu "https://github.com/tianon/gosu/releases/download/$GOSU_VERSION/gosu-$dpkgArch" ; \
18
+ wget -O /usr/local/bin/gosu.asc "https://github.com/tianon/gosu/releases/download/$GOSU_VERSION/gosu-$dpkgArch.asc" ; \
19
+ export GNUPGHOME="$(mktemp -d)" ; \
20
+ gpg --keyserver ha.pool.sks-keyservers.net --recv-keys B42F6819007F00F88E364FD4036A9C25BF357DD4; \
21
+ gpg --batch --verify /usr/local/bin/gosu.asc /usr/local/bin/gosu; \
22
+ rm -r "$GNUPGHOME" /usr/local/bin/gosu.asc; \
23
+ chmod +x /usr/local/bin/gosu; \
24
+ gosu nobody true; \
25
+ \
26
+ apt-get purge -y --auto-remove $fetchDeps
22
27
23
28
ENV REDIS_VERSION 3.2.9
24
29
ENV REDIS_DOWNLOAD_URL http://download.redis.io/releases/redis-3.2.9.tar.gz
25
30
ENV REDIS_DOWNLOAD_SHA 6eaacfa983b287e440d0839ead20c2231749d5d6b78bbe0e0ffa3a890c59ff26
26
31
27
- RUN apt-get update && apt-get install -y libc6-i386 --no-install-recommends && rm -rf /var/lib/apt/lists/*
32
+ RUN apt-get update && apt-get install -y --no-install-recommends \
33
+ libc6-i386 \
34
+ && rm -rf /var/lib/apt/lists/*
28
35
29
36
# for redis-sentinel see: http://redis.io/topics/sentinel
30
- RUN set -ex \
37
+ RUN set -ex; \
31
38
\
32
- && buildDeps=' \
39
+ buildDeps=' \
40
+ wget \
41
+ \
33
42
gcc \
34
43
gcc-multilib \
35
44
libc6-dev-i386 \
36
45
make \
37
- ' \
38
- && apt-get update \
39
- && apt-get install -y $buildDeps --no-install-recommends \
40
- && rm -rf /var/lib/apt/lists/* \
46
+ ' ; \
47
+ apt-get update; \
48
+ apt-get install -y $buildDeps --no-install-recommends; \
49
+ rm -rf /var/lib/apt/lists/*; \
41
50
\
42
- && wget -O redis.tar.gz "$REDIS_DOWNLOAD_URL" \
43
- && echo "$REDIS_DOWNLOAD_SHA *redis.tar.gz" | sha256sum -c - \
44
- && mkdir -p /usr/src/redis \
45
- && tar -xzf redis.tar.gz -C /usr/src/redis --strip-components=1 \
46
- && rm redis.tar.gz \
51
+ wget -O redis.tar.gz "$REDIS_DOWNLOAD_URL" ; \
52
+ echo "$REDIS_DOWNLOAD_SHA *redis.tar.gz" | sha256sum -c -; \
53
+ mkdir -p /usr/src/redis; \
54
+ tar -xzf redis.tar.gz -C /usr/src/redis --strip-components=1; \
55
+ rm redis.tar.gz; \
47
56
\
48
57
# Disable Redis protected mode [1] as it is unnecessary in context
49
58
# of Docker. Ports are not automatically exposed when running inside
50
59
# Docker, but rather explicitely by specifying -p / -P.
51
60
# [1] https://github.com/antirez/redis/commit/edd4d555df57dc84265fdfb4ef59a4678832f6da
52
- && grep -q '^#define CONFIG_DEFAULT_PROTECTED_MODE 1$' /usr/src/redis/src/server.h \
53
- && sed -ri 's!^(#define CONFIG_DEFAULT_PROTECTED_MODE) 1$!\1 0!' /usr/src/redis/src/server.h \
54
- && grep -q '^#define CONFIG_DEFAULT_PROTECTED_MODE 0$' /usr/src/redis/src/server.h \
61
+ grep -q '^#define CONFIG_DEFAULT_PROTECTED_MODE 1$' /usr/src/redis/src/server.h; \
62
+ sed -ri 's!^(#define CONFIG_DEFAULT_PROTECTED_MODE) 1$!\1 0!' /usr/src/redis/src/server.h; \
63
+ grep -q '^#define CONFIG_DEFAULT_PROTECTED_MODE 0$' /usr/src/redis/src/server.h; \
55
64
# for future reference, we modify this directly in the source instead of just supplying a default configuration flag because apparently "if you specify any argument to redis-server, [it assumes] you are going to specify everything"
56
65
# see also https://github.com/docker-library/redis/issues/4#issuecomment-50780840
57
66
# (more exactly, this makes sure the default behavior of "save on SIGTERM" stays functional by default)
58
67
\
59
- && make -C /usr/src/redis 32bit \
60
- && make -C /usr/src/redis install \
68
+ make -C /usr/src/redis -j "$(nproc)" 32bit; \
69
+ make -C /usr/src/redis install; \
61
70
\
62
- && rm -r /usr/src/redis \
71
+ rm -r /usr/src/redis; \
63
72
\
64
- && apt-get purge -y --auto-remove $buildDeps
73
+ apt-get purge -y --auto-remove $buildDeps
65
74
66
75
RUN mkdir /data && chown redis:redis /data
67
76
VOLUME /data
@@ -71,4 +80,4 @@ COPY docker-entrypoint.sh /usr/local/bin/
71
80
ENTRYPOINT ["docker-entrypoint.sh" ]
72
81
73
82
EXPOSE 6379
74
- CMD [ "redis-server" ]
83
+ CMD ["redis-server" ]
0 commit comments