镜像构建历史
# 2026-04-17 08:26:43 0.00B 设置默认要执行的命令
CMD ["redis-server"]
# 2026-04-17 08:26:43 0.00B 声明容器运行时监听的端口
EXPOSE map[6379/tcp:{}]
# 2026-04-17 08:26:43 0.00B 配置容器启动时运行的命令
ENTRYPOINT ["docker-entrypoint.sh"]
# 2026-04-17 08:26:43 4.85KB 复制新文件或目录到容器中
COPY docker-entrypoint.sh /usr/local/bin/ # buildkit
# 2026-04-17 08:26:43 0.00B 设置工作目录为/data
WORKDIR /data
# 2026-04-17 08:26:43 0.00B 创建挂载点用于持久化数据或共享数据
VOLUME [/data]
# 2026-04-17 08:26:43 0.00B 执行命令并创建新的镜像层
RUN |2 REDIS_DOWNLOAD_URL=https://github.com/redis/redis/archive/refs/tags/8.4.2.tar.gz REDIS_DOWNLOAD_SHA=805cffb55e7d4939442bd9328618d922e3b25a1e0ba0fc348015ea9ba3ff4aa8 /bin/sh -c mkdir /data && chown redis:redis /data # buildkit
# 2026-04-17 08:26:43 86.09MB 执行命令并创建新的镜像层
RUN |2 REDIS_DOWNLOAD_URL=https://github.com/redis/redis/archive/refs/tags/8.4.2.tar.gz REDIS_DOWNLOAD_SHA=805cffb55e7d4939442bd9328618d922e3b25a1e0ba0fc348015ea9ba3ff4aa8 /bin/sh -c set -eux; apk add --no-cache --virtual .build-deps coreutils dpkg-dev dpkg gcc linux-headers make musl-dev openssl-dev g++; arch="$(dpkg --print-architecture | awk -F- '{ print $NF }')"; case "$arch" in 'amd64') export BUILD_WITH_MODULES=yes; export INSTALL_RUST_TOOLCHAIN=yes; export DISABLE_WERRORS=yes ;; 'arm64') export BUILD_WITH_MODULES=yes; export INSTALL_RUST_TOOLCHAIN=yes; export DISABLE_WERRORS=yes ;; *) echo >&2 "Modules are NOT supported! unsupported architecture: '$arch'"; export BUILD_WITH_MODULES=no ;; esac; if [ "$BUILD_WITH_MODULES" = "yes" ]; then apk add --no-cache --virtual .module-build-deps autoconf automake bash bsd-compat-headers build-base cargo clang clang-static clang-libclang cmake curl g++ git libffi-dev libgcc libtool llvm-dev ncurses-dev openssh openssl py-virtualenv py3-cryptography py3-pip py3-virtualenv python3 python3-dev rsync tar unzip which xsimd xz; fi; pip install -q --upgrade setuptools && pip install -q --upgrade pip && PIP_BREAK_SYSTEM_PACKAGES=1 pip install -q addict toml jinja2 ramp-packer ; wget -O redis.tar.gz "$REDIS_DOWNLOAD_URL"; echo "$REDIS_DOWNLOAD_SHA *redis.tar.gz" | sha256sum -c -; mkdir -p /usr/src/redis; tar -xzf redis.tar.gz -C /usr/src/redis --strip-components=1; rm redis.tar.gz; grep -E '^ *createBoolConfig[(]"protected-mode",.*, *1 *,.*[)],$' /usr/src/redis/src/config.c; sed -ri 's!^( *createBoolConfig[(]"protected-mode",.*, *)1( *,.*[)],)$!\10\2!' /usr/src/redis/src/config.c; grep -E '^ *createBoolConfig[(]"protected-mode",.*, *0 *,.*[)],$' /usr/src/redis/src/config.c; gnuArch="$(dpkg-architecture --query DEB_BUILD_GNU_TYPE)"; extraJemallocConfigureFlags="--build=$gnuArch"; dpkgArch="$(dpkg --print-architecture)"; case "${dpkgArch##*-}" in amd64 | i386 | x32) extraJemallocConfigureFlags="$extraJemallocConfigureFlags --with-lg-page=12" ;; *) extraJemallocConfigureFlags="$extraJemallocConfigureFlags --with-lg-page=16" ;; esac; extraJemallocConfigureFlags="$extraJemallocConfigureFlags --with-lg-hugepage=21"; grep -F 'cd jemalloc && ./configure ' /usr/src/redis/deps/Makefile; sed -ri 's!cd jemalloc && ./configure !&'"$extraJemallocConfigureFlags"' !' /usr/src/redis/deps/Makefile; grep -F "cd jemalloc && ./configure $extraJemallocConfigureFlags " /usr/src/redis/deps/Makefile; export RUST_DYN_CRT=1; export BUILD_TLS=yes; if [ "$BUILD_WITH_MODULES" = "yes" ]; then make -C /usr/src/redis/modules/redisjson get_source; sed -i 's/^RUST_FLAGS=$/RUST_FLAGS += -C target-feature=-crt-static/' /usr/src/redis/modules/redisjson/src/Makefile ; grep -E 'RUST_FLAGS' /usr/src/redis/modules/redisjson/src/Makefile; fi; make -C /usr/src/redis -j "$(nproc)" all; make -C /usr/src/redis install; serverMd5="$(md5sum /usr/local/bin/redis-server | cut -d' ' -f1)"; export serverMd5; find /usr/local/bin/redis* -maxdepth 0 -type f -not -name redis-server -exec sh -eux -c ' md5="$(md5sum "$1" | cut -d" " -f1)"; test "$md5" = "$serverMd5"; ' -- '{}' ';' -exec ln -svfT 'redis-server' '{}' ';' ; make -C /usr/src/redis distclean; rm -r /usr/src/redis; runDeps="$( scanelf --needed --nobanner --format '%n#p' --recursive /usr/local | tr ',' '\n' | sort -u | awk 'system("[ -e /usr/local/lib/" $1 " ]") == 0 { next } { print "so:" $1 }' )"; apk add --no-network --virtual .redis-rundeps $runDeps; if [ "$BUILD_WITH_MODULES" = "yes" ]; then apk del --no-network .module-build-deps; fi; apk del --no-network .build-deps; rm -rf ~/.cache ~/.gitconfig; redis-cli --version; redis-server --version; # buildkit
# 2026-04-17 08:26:43 0.00B 定义构建参数
ARG REDIS_DOWNLOAD_SHA=805cffb55e7d4939442bd9328618d922e3b25a1e0ba0fc348015ea9ba3ff4aa8
# 2026-04-17 08:26:43 0.00B 定义构建参数
ARG REDIS_DOWNLOAD_URL=https://github.com/redis/redis/archive/refs/tags/8.4.2.tar.gz
# 2026-04-17 08:19:28 575.80KB 执行命令并创建新的镜像层
RUN /bin/sh -c set -eux; apk add --no-cache tzdata setpriv ; # buildkit
# 2026-04-17 08:19:28 3.05KB 执行命令并创建新的镜像层
RUN /bin/sh -c set -eux; addgroup -S -g 1000 redis; adduser -S -G redis -u 999 redis # buildkit
# 2026-04-17 07:53:02 0.00B 设置默认要执行的命令
CMD ["/bin/sh"]
# 2026-04-17 07:53:02 8.32MB 复制文件或目录到容器中
ADD alpine-minirootfs-3.22.4-x86_64.tar.gz / # buildkit
镜像信息
{
"Id": "sha256:98668220e452d235e71330a242ccd72903adb4ad595b95b5a453a723b89356c7",
"RepoTags": [
"redis:8.4.2-alpine",
"swr.cn-north-4.myhuaweicloud.com/ddn-k8s/docker.io/redis:8.4.2-alpine"
],
"RepoDigests": [
"redis@sha256:e1b6db24cb4fdd89f4bc9be09f671ea3bec92fbd7042554f76c34aa2be9b59ad",
"swr.cn-north-4.myhuaweicloud.com/ddn-k8s/docker.io/redis@sha256:1e92a859904b5f1b054b5c1d9dd0c017ca67aa27e912410c0084b5b0bb1173cf"
],
"Parent": "",
"Comment": "buildkit.dockerfile.v0",
"Created": "2026-04-17T00:26:43.314063339Z",
"Container": "",
"ContainerConfig": null,
"DockerVersion": "",
"Author": "",
"Config": {
"Hostname": "",
"Domainname": "",
"User": "",
"AttachStdin": false,
"AttachStdout": false,
"AttachStderr": false,
"ExposedPorts": {
"6379/tcp": {}
},
"Tty": false,
"OpenStdin": false,
"StdinOnce": false,
"Env": [
"PATH=/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin"
],
"Cmd": [
"redis-server"
],
"Image": "",
"Volumes": {
"/data": {}
},
"WorkingDir": "/data",
"Entrypoint": [
"docker-entrypoint.sh"
],
"OnBuild": null,
"Labels": null
},
"Architecture": "amd64",
"Os": "linux",
"Size": 94996171,
"GraphDriver": {
"Data": {
"LowerDir": "/var/lib/docker/overlay2/63e9b5135a412a57be8d00fba61eb4835dfc1cca674ad95e01c311d9666fac28/diff:/var/lib/docker/overlay2/8ff9c66948761adefd6252d3bf4c3224cab006d432d877746fcebecde77c751f/diff:/var/lib/docker/overlay2/dc6ea1c30385653449cfe72969bf7ed2df482392b8a89dcb04acdd21a9990496/diff:/var/lib/docker/overlay2/fe6b1d608ea29ba4ca7e7d3a5ebe28f48e11358de326b18368fbbcfb15f00596/diff:/var/lib/docker/overlay2/5744a7dd7902d894c947e67d691a54b6ba73df6629e25400b3e53ee3cea0dec6/diff:/var/lib/docker/overlay2/47c2747570f40bb25c7a484481f4287508b816ce46ea89f67c37861a42dc2d9d/diff",
"MergedDir": "/var/lib/docker/overlay2/396708abfb5974ffd7fb88afead239e09a887f6503cdbdcb3f1f358733d11934/merged",
"UpperDir": "/var/lib/docker/overlay2/396708abfb5974ffd7fb88afead239e09a887f6503cdbdcb3f1f358733d11934/diff",
"WorkDir": "/var/lib/docker/overlay2/396708abfb5974ffd7fb88afead239e09a887f6503cdbdcb3f1f358733d11934/work"
},
"Name": "overlay2"
},
"RootFS": {
"Type": "layers",
"Layers": [
"sha256:0854555d70acaa318b38ee50bc667cb51ff6bf0757624624c7ff3b6fe17459a0",
"sha256:44ee43943c88441c1ba930c46f3d508a46e95c0d905c2f120c6b0799dc897c0e",
"sha256:b6a1cff2f852beb521abc61dc584b74233a5a20d87760d17314db8e642979994",
"sha256:618920b9019d8832e751c1cb8d3471b251ad0cd63653ca5564b9f7c820c083d0",
"sha256:9d9879f3fc93e24afa8daecd7a84f0538548925381b076bf0486f0927dec0d71",
"sha256:5f70bf18a086007016e948b04aed3b82103a36bea41755b6cddfaf10ace3c6ef",
"sha256:28872e0c15a491b5ffd8915d6d07fbdd7cbb4a21006f3751b104413b8c1360d1"
]
},
"Metadata": {
"LastTagTime": "2026-04-20T10:24:31.860345041+08:00"
}
}