镜像构建历史
# 2026-06-09 21:00:46 0.00B 设置默认要执行的命令
CMD ["/app/start-all.sh"]
# 2026-06-09 21:00:46 0.00B 设置环境变量 TOKENIZERS_PARALLELISM
ENV TOKENIZERS_PARALLELISM=false
# 2026-06-09 21:00:46 0.00B 设置环境变量 HF_HUB_VERBOSITY
ENV HF_HUB_VERBOSITY=error
# 2026-06-09 21:00:46 0.00B 设置环境变量 TRANSFORMERS_VERBOSITY
ENV TRANSFORMERS_VERBOSITY=error
# 2026-06-09 21:00:46 0.00B 设置环境变量 PYTHONUNBUFFERED
ENV PYTHONUNBUFFERED=1
# 2026-06-09 21:00:46 0.00B 设置环境变量 HINDSIGHT_ENABLE_CP
ENV HINDSIGHT_ENABLE_CP=true
# 2026-06-09 21:00:46 0.00B 设置环境变量 HINDSIGHT_ENABLE_API
ENV HINDSIGHT_ENABLE_API=true
# 2026-06-09 21:00:46 0.00B 设置环境变量 HINDSIGHT_CP_DATAPLANE_API_URL
ENV HINDSIGHT_CP_DATAPLANE_API_URL=http://localhost:8888
# 2026-06-09 21:00:46 0.00B 设置环境变量 NODE_ENV
ENV NODE_ENV=production
# 2026-06-09 21:00:46 0.00B 设置环境变量 HINDSIGHT_API_LOG_LEVEL
ENV HINDSIGHT_API_LOG_LEVEL=info
# 2026-06-09 21:00:46 0.00B 设置环境变量 HINDSIGHT_API_PORT
ENV HINDSIGHT_API_PORT=8888
# 2026-06-09 21:00:46 0.00B 设置环境变量 HINDSIGHT_API_HOST
ENV HINDSIGHT_API_HOST=0.0.0.0
# 2026-06-09 21:00:46 0.00B 声明容器运行时监听的端口
EXPOSE [8888/tcp 9999/tcp]
# 2026-06-09 21:00:46 0.00B 执行命令并创建新的镜像层
RUN |2 PRELOAD_ML_MODELS=false INCLUDE_LOCAL_MODELS=false /bin/sh -c if [ "$PRELOAD_ML_MODELS" = "true" ] && [ "$INCLUDE_LOCAL_MODELS" = "true" ]; then MAX_RETRIES=3; RETRY_DELAY=10; for i in $(seq 1 $MAX_RETRIES); do echo "Attempt $i/$MAX_RETRIES: Downloading ML models..."; /app/api/.venv/bin/python -c "import os; os.environ['HF_HUB_DOWNLOAD_TIMEOUT'] = '600'; from sentence_transformers import SentenceTransformer, CrossEncoder; print('Downloading embedding model...'); SentenceTransformer('BAAI/bge-small-en-v1.5'); print('Downloading cross-encoder model...'); CrossEncoder('cross-encoder/ms-marco-MiniLM-L-6-v2'); print('Models cached successfully')" && break; if [ $i -lt $MAX_RETRIES ]; then echo "Attempt $i failed, retrying in ${RETRY_DELAY}s..."; sleep $RETRY_DELAY; RETRY_DELAY=$((RETRY_DELAY * 2)); fi; done; if [ $i -eq $MAX_RETRIES ] && ! /app/api/.venv/bin/python -c "from sentence_transformers import SentenceTransformer; SentenceTransformer('BAAI/bge-small-en-v1.5')" 2>/dev/null; then echo "ERROR: Failed to download models after $MAX_RETRIES attempts"; exit 1; fi; elif [ "$INCLUDE_LOCAL_MODELS" != "true" ]; then echo "Skipping ML model preload (local-models not included)"; else echo "Skipping ML model preload"; fi # buildkit
# 2026-06-09 21:00:46 0.00B 设置环境变量 HF_HUB_DOWNLOAD_TIMEOUT
ENV HF_HUB_DOWNLOAD_TIMEOUT=600
# 2026-06-09 21:00:46 0.00B 定义构建参数
ARG INCLUDE_LOCAL_MODELS=false
# 2026-06-09 21:00:46 0.00B 定义构建参数
ARG PRELOAD_ML_MODELS=false
# 2026-06-09 21:00:46 2.56MB 执行命令并创建新的镜像层
RUN /bin/sh -c MAX_RETRIES=3; RETRY_DELAY=5; for i in $(seq 1 $MAX_RETRIES); do echo "Attempt $i/$MAX_RETRIES: Downloading tiktoken encoding..."; /app/api/.venv/bin/python -c "import tiktoken; print('Downloading cl100k_base encoding...'); tiktoken.get_encoding('cl100k_base'); print('Tiktoken encoding cached successfully')" && break; if [ $i -lt $MAX_RETRIES ]; then echo "Attempt $i failed, retrying in ${RETRY_DELAY}s..."; sleep $RETRY_DELAY; RETRY_DELAY=$((RETRY_DELAY * 2)); fi; done; if [ $i -eq $MAX_RETRIES ]; then echo "ERROR: Failed to download tiktoken encoding after $MAX_RETRIES attempts"; exit 1; fi # buildkit
# 2026-06-09 21:00:44 0.00B 设置环境变量 PATH
ENV PATH=/app/api/.venv/bin:/usr/local/bin:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin
# 2026-06-09 21:00:44 0.00B 执行命令并创建新的镜像层
RUN /bin/sh -c chmod 755 /home/hindsight # buildkit
# 2026-06-09 21:00:44 0.00B 执行命令并创建新的镜像层
RUN /bin/sh -c mkdir -p /home/hindsight/.pg0 # buildkit
# 2026-06-09 21:00:44 0.00B 指定运行容器时使用的用户
USER hindsight
# 2026-06-09 21:00:44 950.46MB 执行命令并创建新的镜像层
RUN /bin/sh -c chown -R hindsight:hindsight /app # buildkit
# 2026-06-09 21:00:25 0.00B 执行命令并创建新的镜像层
RUN /bin/sh -c chmod +x /app/start-all.sh # buildkit
# 2026-06-09 21:00:24 11.35KB 复制新文件或目录到容器中
COPY docker/standalone/start-all.sh /app/start-all.sh # buildkit
# 2026-06-09 21:00:24 0.00B 设置工作目录为/app
WORKDIR /app
# 2026-06-09 21:00:24 73.66KB 复制新文件或目录到容器中
COPY /app/memory-poc/hindsight-control-plane/public ./public # buildkit
# 2026-06-09 21:00:24 2.76MB 复制新文件或目录到容器中
COPY /app/memory-poc/hindsight-control-plane/.next/static ./.next/static # buildkit
# 2026-06-09 21:00:24 48.26MB 复制新文件或目录到容器中
COPY /app/memory-poc/hindsight-control-plane/standalone ./ # buildkit
# 2026-06-09 20:58:25 0.00B 设置工作目录为/app/control-plane
WORKDIR /app/control-plane
# 2026-06-09 20:58:25 7.69MB 复制新文件或目录到容器中
COPY /app/hindsight-clients/typescript /app/sdk # buildkit
# 2026-06-09 20:58:24 894.51MB 复制新文件或目录到容器中
COPY /app/api /app/api # buildkit
# 2026-06-09 20:58:18 8.93KB 执行命令并创建新的镜像层
RUN /bin/sh -c useradd -m -s /bin/bash hindsight # buildkit
# 2026-06-09 20:58:18 328.60MB 执行命令并创建新的镜像层
RUN /bin/sh -c apt-get update && apt-get install -y curl procps libxml2 libssl3 libgssapi-krb5-2 libossp-uuid16 && (apt-get install -y libicu72 2>/dev/null || apt-get install -y libicu74 2>/dev/null || apt-get install -y libicu76 2>/dev/null || true) && curl -fsSL https://deb.nodesource.com/setup_20.x | bash - && apt-get install -y nodejs && rm -rf /var/lib/apt/lists/* && pip install --no-cache-dir uv # buildkit
# 2026-06-09 20:57:06 0.00B 设置工作目录为/app
WORKDIR /app
# 2026-05-20 07:52:06 0.00B 设置默认要执行的命令
CMD ["python3"]
# 2026-05-20 07:52:06 36.00B 执行命令并创建新的镜像层
RUN /bin/sh -c set -eux; for src in idle3 pip3 pydoc3 python3 python3-config; do dst="$(echo "$src" | tr -d 3)"; [ -s "/usr/local/bin/$src" ]; [ ! -e "/usr/local/bin/$dst" ]; ln -svT "$src" "/usr/local/bin/$dst"; done # buildkit
# 2026-05-20 07:52:06 42.05MB 执行命令并创建新的镜像层
RUN /bin/sh -c set -eux; savedAptMark="$(apt-mark showmanual)"; apt-get update; apt-get install -y --no-install-recommends dpkg-dev gcc gnupg libbluetooth-dev libbz2-dev libc6-dev libdb-dev libffi-dev libgdbm-dev liblzma-dev libncursesw5-dev libreadline-dev libsqlite3-dev libssl-dev make tk-dev uuid-dev wget xz-utils zlib1g-dev ; wget -O python.tar.xz "https://www.python.org/ftp/python/${PYTHON_VERSION%%[a-z]*}/Python-$PYTHON_VERSION.tar.xz"; echo "$PYTHON_SHA256 *python.tar.xz" | sha256sum -c -; wget -O python.tar.xz.asc "https://www.python.org/ftp/python/${PYTHON_VERSION%%[a-z]*}/Python-$PYTHON_VERSION.tar.xz.asc"; GNUPGHOME="$(mktemp -d)"; export GNUPGHOME; gpg --batch --keyserver hkps://keys.openpgp.org --recv-keys "$GPG_KEY"; gpg --batch --verify python.tar.xz.asc python.tar.xz; gpgconf --kill all; rm -rf "$GNUPGHOME" python.tar.xz.asc; mkdir -p /usr/src/python; tar --extract --directory /usr/src/python --strip-components=1 --file python.tar.xz; rm python.tar.xz; cd /usr/src/python; gnuArch="$(dpkg-architecture --query DEB_BUILD_GNU_TYPE)"; ./configure --build="$gnuArch" --enable-loadable-sqlite-extensions --enable-optimizations --enable-option-checking=fatal --enable-shared $(test "${gnuArch%%-*}" != 'riscv64' && echo '--with-lto') --with-ensurepip ; nproc="$(nproc)"; EXTRA_CFLAGS="$(dpkg-buildflags --get CFLAGS)"; LDFLAGS="$(dpkg-buildflags --get LDFLAGS)"; LDFLAGS="${LDFLAGS:-} -Wl,--strip-all"; make -j "$nproc" "EXTRA_CFLAGS=${EXTRA_CFLAGS:-}" "LDFLAGS=${LDFLAGS:-}" ; rm python; make -j "$nproc" "EXTRA_CFLAGS=${EXTRA_CFLAGS:-}" "LDFLAGS=${LDFLAGS:-} -Wl,-rpath='\$\$ORIGIN/../lib'" python ; make install; cd /; rm -rf /usr/src/python; find /usr/local -depth \( \( -type d -a \( -name test -o -name tests -o -name idle_test \) \) -o \( -type f -a \( -name '*.pyc' -o -name '*.pyo' -o -name 'libpython*.a' \) \) \) -exec rm -rf '{}' + ; ldconfig; apt-mark auto '.*' > /dev/null; apt-mark manual $savedAptMark; find /usr/local -type f -executable -not \( -name '*tkinter*' \) -exec ldd '{}' ';' | awk '/=>/ { so = $(NF-1); if (index(so, "/usr/local/") == 1) { next }; gsub("^/(usr/)?", "", so); printf "*%s\n", so }' | sort -u | xargs -rt dpkg-query --search | awk 'sub(":$", "", $1) { print $1 }' | sort -u | xargs -r apt-mark manual ; apt-get purge -y --auto-remove -o APT::AutoRemove::RecommendsImportant=false; apt-get dist-clean; export PYTHONDONTWRITEBYTECODE=1; python3 --version; pip3 install --disable-pip-version-check --no-cache-dir --no-compile 'setuptools==79.0.1' 'wheel<0.46' ; pip3 --version # buildkit
# 2026-05-20 07:43:52 0.00B 设置环境变量 PYTHON_SHA256
ENV PYTHON_SHA256=272179ddd9a2e41a0fc8e42e33dfbdca0b3711aa5abf372d3f2d51543d09b625
# 2026-05-20 07:43:52 0.00B 设置环境变量 PYTHON_VERSION
ENV PYTHON_VERSION=3.11.15
# 2026-05-20 07:43:52 0.00B 设置环境变量 GPG_KEY
ENV GPG_KEY=A035C8C19219BA821ECEA86B64E628F8D684696D
# 2026-05-20 07:43:52 3.81MB 执行命令并创建新的镜像层
RUN /bin/sh -c set -eux; apt-get update; apt-get install -y --no-install-recommends ca-certificates netbase tzdata ; apt-get dist-clean # buildkit
# 2026-05-20 07:43:52 0.00B 设置环境变量 LANG
ENV LANG=C.UTF-8
# 2026-05-20 07:43:52 0.00B 设置环境变量 PATH
ENV PATH=/usr/local/bin:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin
# 2026-05-18 08:00:00 78.62MB
# debian.sh --arch 'amd64' out/ 'trixie' '@1779062400'
镜像信息
{
"Id": "sha256:f9334f661d7a984d9cc67ddfa46911f6ed5324e9047d32f4b5d51103c05b2c9a",
"RepoTags": [
"ghcr.io/vectorize-io/hindsight:0.8.1-slim",
"ghcr.io/vectorize-io/hindsight:latest-slim",
"swr.cn-north-4.myhuaweicloud.com/ddn-k8s/ghcr.io/vectorize-io/hindsight:0.8.1-slim",
"swr.cn-north-4.myhuaweicloud.com/ddn-k8s/ghcr.io/vectorize-io/hindsight:latest-slim"
],
"RepoDigests": [
"ghcr.io/vectorize-io/hindsight@sha256:3ab626f49349b7f079872afab4e508b139c1f95dfdd3ddf87034f7daf180839f",
"swr.cn-north-4.myhuaweicloud.com/ddn-k8s/ghcr.io/vectorize-io/hindsight@sha256:7cbca019b38d86d20a1051db3cd1aa9da2e8925b8e66cd268f5a0fe3a0283dac"
],
"Parent": "",
"Comment": "buildkit.dockerfile.v0",
"Created": "2026-06-09T13:00:46.625772849Z",
"Container": "",
"ContainerConfig": null,
"DockerVersion": "",
"Author": "",
"Config": {
"Hostname": "",
"Domainname": "",
"User": "hindsight",
"AttachStdin": false,
"AttachStdout": false,
"AttachStderr": false,
"ExposedPorts": {
"8888/tcp": {},
"9999/tcp": {}
},
"Tty": false,
"OpenStdin": false,
"StdinOnce": false,
"Env": [
"PATH=/app/api/.venv/bin:/usr/local/bin:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin",
"LANG=C.UTF-8",
"GPG_KEY=A035C8C19219BA821ECEA86B64E628F8D684696D",
"PYTHON_VERSION=3.11.15",
"PYTHON_SHA256=272179ddd9a2e41a0fc8e42e33dfbdca0b3711aa5abf372d3f2d51543d09b625",
"HF_HUB_DOWNLOAD_TIMEOUT=600",
"HINDSIGHT_API_HOST=0.0.0.0",
"HINDSIGHT_API_PORT=8888",
"HINDSIGHT_API_LOG_LEVEL=info",
"NODE_ENV=production",
"HINDSIGHT_CP_DATAPLANE_API_URL=http://localhost:8888",
"HINDSIGHT_ENABLE_API=true",
"HINDSIGHT_ENABLE_CP=true",
"PYTHONUNBUFFERED=1",
"TRANSFORMERS_VERBOSITY=error",
"HF_HUB_VERBOSITY=error",
"TOKENIZERS_PARALLELISM=false"
],
"Cmd": [
"/app/start-all.sh"
],
"ArgsEscaped": true,
"Image": "",
"Volumes": null,
"WorkingDir": "/app",
"Entrypoint": null,
"OnBuild": null,
"Labels": {
"org.opencontainers.image.created": "2026-06-09T12:57:00.441Z",
"org.opencontainers.image.description": "Hindsight: Agent Memory That Learns",
"org.opencontainers.image.licenses": "MIT",
"org.opencontainers.image.revision": "4dc149a1ace63c4223fd939f3b815cfa3b7afa45",
"org.opencontainers.image.source": "https://github.com/vectorize-io/hindsight",
"org.opencontainers.image.title": "hindsight",
"org.opencontainers.image.url": "https://github.com/vectorize-io/hindsight",
"org.opencontainers.image.version": "0.8.1-slim"
}
},
"Architecture": "amd64",
"Os": "linux",
"Size": 2359414876,
"GraphDriver": {
"Data": {
"LowerDir": "/var/lib/docker/overlay2/d0c6c1e30a5e8212e721b75725d05ea47b0c2a7a6bdcea74c37bd344b50a6aae/diff:/var/lib/docker/overlay2/6d5ae69a25a0074baed7dba864a1200e3558b4d95ec1f070d2c1bf15b695c8f6/diff:/var/lib/docker/overlay2/3b4d8a674b1c048384e3025f18c591397f505b58e44ea2583fff677e775ce4a6/diff:/var/lib/docker/overlay2/c7259e0db5787c665e2bbf3269f7419968f7e21bc75e42cc2f91a67cb28a5b19/diff:/var/lib/docker/overlay2/68ae44125dae90653816389c85f88516bc0a0ba61c0d40af3d963785c3a0c30d/diff:/var/lib/docker/overlay2/e6c3ca5495ba04f3b4b6a2cd77a465e6aad110f4c431052c004d456c0737a9dc/diff:/var/lib/docker/overlay2/1b96eb7f5ad1229b95764502035fce9baa61498979d861ecc280553111d44f60/diff:/var/lib/docker/overlay2/e3a1793b36f905a9e17e836153418166f5f971e95a9d3519fbc75f5f6ffce9b5/diff:/var/lib/docker/overlay2/bb406ce596792aa5f58e10968af38e2c67e8678d82d7d3c74d74541be9d45ee6/diff:/var/lib/docker/overlay2/4c1ebd90a98ec4e7f34c5f41dfe27377f93d4b7e0a874bce9339819d76810c1e/diff:/var/lib/docker/overlay2/947d4b9e06f577308b6b82e5c8c3b68a9fd10c7612e554053a37314ca038d200/diff:/var/lib/docker/overlay2/4de3d966c059f36b92ac0e8afcbfec556537e75647baa0c2720a786c6dade7a3/diff:/var/lib/docker/overlay2/981a1784a912f1540b78b907e78023a339fad7a6fe500fcdabd8d0c529e64d61/diff:/var/lib/docker/overlay2/77c01ac6c6235e17dc1ca395d85b98a0fb6c2c326be4ec5bd6793023ecb744ec/diff:/var/lib/docker/overlay2/2222753d9c3debc725ae9e4dbfdbb0b6630923eb168d1820ecaa7adb09e2d34b/diff:/var/lib/docker/overlay2/4772437853f7f4967ee8f5a24573ecefd054ea248aefdd6a544912c56c26bea3/diff:/var/lib/docker/overlay2/97c6e32f971d153cfa6f93d0f59773c9d879ec67bd27dc30f66c5cea43874886/diff:/var/lib/docker/overlay2/d56e40da9769eb7ecd235d012dd5cf28ca40c25f13a56075884fdcd6cfbd90a3/diff:/var/lib/docker/overlay2/1195f6999f770996df5aebe24e6459f7d0c199c32cd31b53f4fc93b79eb2fb24/diff:/var/lib/docker/overlay2/cd0bbc9c69e026633d38a0c4693c779a3d10a0542c78032cd6cc9dbe54fe597d/diff",
"MergedDir": "/var/lib/docker/overlay2/b71cfb51ec0991a2098d6a4979abdaa220daaaed3928ced0261aa1aaa0d15964/merged",
"UpperDir": "/var/lib/docker/overlay2/b71cfb51ec0991a2098d6a4979abdaa220daaaed3928ced0261aa1aaa0d15964/diff",
"WorkDir": "/var/lib/docker/overlay2/b71cfb51ec0991a2098d6a4979abdaa220daaaed3928ced0261aa1aaa0d15964/work"
},
"Name": "overlay2"
},
"RootFS": {
"Type": "layers",
"Layers": [
"sha256:219a998c60509502b47b97f1158067d5dd62640d2d689560d32cfd5594f6bc40",
"sha256:98df1ca0e575d9026c1abd12994fad3c14effa4558d50b6961fd586930956b26",
"sha256:bffa3c30a00bb534b2e3637bd26d9a75e095172be7d0b33924f1a61bf6cb2120",
"sha256:89bfb82659d056dd4ef25b8b3f99c7a97874083d86d92924e931ffa2fb7c7861",
"sha256:db9d78d11fc6e2aaa7a00c5b208d591237851805711d15e5a238040cac7ccd06",
"sha256:7032272e6b44628c02915df90864a521aa5f321faee41569484215eeb4e8e43c",
"sha256:215aa377fa2f579ac217f3ab03f99b62aa357b955ade1dc577831c0656ec8e5c",
"sha256:626d1aeffbed064f3ae6f10cdd191a10b568c8eaadc38f2bfc71cb36a3a0d4a0",
"sha256:0bc5461ee559037a07b6aff1335fa7b1b3dee93523f11f001f85b2e4023a5da2",
"sha256:c2dd8d3a18e1817c95a566d283f96af330d4e54aad7445cafd256717836f75aa",
"sha256:a0bf1d12c06eeec61262b7f8c08a14ffd72d15626d14c5d5fc7be89abafc9841",
"sha256:e06f429f8d6efbd3df0fc3c30c1bd20753b0ad0f7832394865f73ed55cf17735",
"sha256:072c825d1528f00e3decebe0933969ea3c1ca18076c5a0a35680c876603e7f3c",
"sha256:5f70bf18a086007016e948b04aed3b82103a36bea41755b6cddfaf10ace3c6ef",
"sha256:4fe8278683bcd09874e7d7ae967964fe7b9490fb412c17aa48bf4ed0c23b67bd",
"sha256:5f70bf18a086007016e948b04aed3b82103a36bea41755b6cddfaf10ace3c6ef",
"sha256:3a68bc46eba9119428fba6ee8c261fdb9d9be640ba3a42ac17f3e392cc250a61",
"sha256:a4d3c681a74079c6018d5483aa40d20110202f2cc0f2d4cc1a0d715d305eda5a",
"sha256:103cc28a6f11392b095aeb21775220aa07840b6703b7615c4ecb3cef8fbe8438",
"sha256:3fe8b5376ce2a4fd9a54cf2b335f2dfa288d8b4599bb66310c5c37393d967583",
"sha256:5f70bf18a086007016e948b04aed3b82103a36bea41755b6cddfaf10ace3c6ef"
]
},
"Metadata": {
"LastTagTime": "2026-06-10T22:33:16.220088192+08:00"
}
}