镜像构建历史
# 2026-02-13 05:18:40 0.00B 设置默认要执行的命令
CMD ["redis-server"]
# 2026-02-13 05:18:40 0.00B 声明容器运行时监听的端口
EXPOSE map[6379/tcp:{}]
# 2026-02-13 05:18:40 0.00B 配置容器启动时运行的命令
ENTRYPOINT ["docker-entrypoint.sh"]
# 2026-02-13 05:18:40 4.85KB 复制新文件或目录到容器中
COPY docker-entrypoint.sh /usr/local/bin/ # buildkit
# 2026-02-13 05:18:40 0.00B 设置工作目录为/data
WORKDIR /data
# 2026-02-13 05:18:40 0.00B 创建挂载点用于持久化数据或共享数据
VOLUME [/data]
# 2026-02-13 05:18:40 0.00B 执行命令并创建新的镜像层
RUN |2 REDIS_DOWNLOAD_URL=https://github.com/redis/redis/archive/refs/tags/8.2.4.tar.gz REDIS_DOWNLOAD_SHA=b9d7252b26af9738aa686681151b0e798ef8b4afc092a838b3de0a12a36b1542 /bin/sh -c mkdir /data && chown redis:redis /data # buildkit
# 2026-02-13 05:18:40 61.73MB 执行命令并创建新的镜像层
RUN |2 REDIS_DOWNLOAD_URL=https://github.com/redis/redis/archive/refs/tags/8.2.4.tar.gz REDIS_DOWNLOAD_SHA=b9d7252b26af9738aa686681151b0e798ef8b4afc092a838b3de0a12a36b1542 /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-02-13 05:18:40 0.00B 定义构建参数
ARG REDIS_DOWNLOAD_SHA=b9d7252b26af9738aa686681151b0e798ef8b4afc092a838b3de0a12a36b1542
# 2026-02-13 05:18:40 0.00B 定义构建参数
ARG REDIS_DOWNLOAD_URL=https://github.com/redis/redis/archive/refs/tags/8.2.4.tar.gz
# 2026-02-13 05:09:30 575.78KB 执行命令并创建新的镜像层
RUN /bin/sh -c set -eux; apk add --no-cache tzdata setpriv ; # buildkit
# 2026-02-13 05:09:30 3.05KB 执行命令并创建新的镜像层
RUN /bin/sh -c set -eux; addgroup -S -g 1000 redis; adduser -S -G redis -u 999 redis # buildkit
# 2026-01-28 09:18:40 0.00B 设置默认要执行的命令
CMD ["/bin/sh"]
# 2026-01-28 09:18:40 8.32MB 复制文件或目录到容器中
ADD alpine-minirootfs-3.22.3-x86_64.tar.gz / # buildkit
镜像信息
{
"Id": "sha256:476a7fa567505e662f078b5dc4e738011b0861f9e2566eea3c238f46366fdb5b",
"RepoTags": [
"redis:8.2.4-alpine3.22",
"swr.cn-north-4.myhuaweicloud.com/ddn-k8s/docker.io/redis:8.2.4-alpine3.22"
],
"RepoDigests": [
"redis@sha256:a308ca111032fa8f306a2dc7be7ba5deb8b777ed5d258c733cddba48a1fd7904",
"swr.cn-north-4.myhuaweicloud.com/ddn-k8s/docker.io/redis@sha256:a1a0841686605f56bdfba5165fd80a6a1531a03910653de38816d93a70d62439"
],
"Parent": "",
"Comment": "buildkit.dockerfile.v0",
"Created": "2026-02-12T21:18:40.987208879Z",
"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": 70638470,
"GraphDriver": {
"Data": {
"LowerDir": "/var/lib/docker/overlay2/1f0d64dbf2013051432fb20dbe5efb58217a286e1660be962ede96a096298442/diff:/var/lib/docker/overlay2/324396db8437f53a49f0d1594d525d45db101008b204fe8449f008d989a435da/diff:/var/lib/docker/overlay2/ab4eab9518066b1b04b0dc101e05a85826df77e4c181e2f2fa1740d4ad9b4637/diff:/var/lib/docker/overlay2/15a82cc39266d80f8c14bcfe51649cc1b7a2fea4045aa73cae380a18b4c0458c/diff:/var/lib/docker/overlay2/21ff9a3ede53d40cc553dd8eaac2defb1dedc03d2ee083d81cb9dc07b0a02993/diff:/var/lib/docker/overlay2/01b596946268e6d765a2f7f0c6b45be0f8ad7125339cfa26d867e8f6f17dc8e2/diff",
"MergedDir": "/var/lib/docker/overlay2/775e58fd2d8b44146e78bd858d3d9800d52f6712eb8bd8584bf0d3dabb151f74/merged",
"UpperDir": "/var/lib/docker/overlay2/775e58fd2d8b44146e78bd858d3d9800d52f6712eb8bd8584bf0d3dabb151f74/diff",
"WorkDir": "/var/lib/docker/overlay2/775e58fd2d8b44146e78bd858d3d9800d52f6712eb8bd8584bf0d3dabb151f74/work"
},
"Name": "overlay2"
},
"RootFS": {
"Type": "layers",
"Layers": [
"sha256:cce92674e98722970ab3fdce76a2566f54db535beeb24f0b4397f070ab5f6987",
"sha256:ec78d2c6851eb96ef26b9f0ab5e3ac9cff4a6179388ae511149b86547c2ba64c",
"sha256:8358a2f699318d8f38495856fbf71c844e2ff2c4b05fcf68cbfada3bcc1a9951",
"sha256:7455e8b55126f3c44dda585edd76039328d120725676da2ffe88c5780a8099ce",
"sha256:d300f636fc6154b2a4895fff4dee7c481d8486cfbdb8da0b52313b618b5ed400",
"sha256:5f70bf18a086007016e948b04aed3b82103a36bea41755b6cddfaf10ace3c6ef",
"sha256:1cd0541c38fddaf73ce9477f1ba639bf64168624bd5999ef9f1c895d06ca6bc3"
]
},
"Metadata": {
"LastTagTime": "2026-02-19T19:07:08.735342611+08:00"
}
}