镜像构建历史
# 2026-04-17 21:45:33 0.00B 设置默认要执行的命令
CMD ["/app/start-all.sh"]
# 2026-04-17 21:45:33 0.00B 设置环境变量 TOKENIZERS_PARALLELISM
ENV TOKENIZERS_PARALLELISM=false
# 2026-04-17 21:45:33 0.00B 设置环境变量 HF_HUB_VERBOSITY
ENV HF_HUB_VERBOSITY=error
# 2026-04-17 21:45:33 0.00B 设置环境变量 TRANSFORMERS_VERBOSITY
ENV TRANSFORMERS_VERBOSITY=error
# 2026-04-17 21:45:33 0.00B 设置环境变量 PYTHONUNBUFFERED
ENV PYTHONUNBUFFERED=1
# 2026-04-17 21:45:33 0.00B 设置环境变量 HINDSIGHT_ENABLE_CP
ENV HINDSIGHT_ENABLE_CP=true
# 2026-04-17 21:45:33 0.00B 设置环境变量 HINDSIGHT_ENABLE_API
ENV HINDSIGHT_ENABLE_API=true
# 2026-04-17 21:45:33 0.00B 设置环境变量 HINDSIGHT_CP_DATAPLANE_API_URL
ENV HINDSIGHT_CP_DATAPLANE_API_URL=http://localhost:8888
# 2026-04-17 21:45:33 0.00B 设置环境变量 NODE_ENV
ENV NODE_ENV=production
# 2026-04-17 21:45:33 0.00B 设置环境变量 HINDSIGHT_API_LOG_LEVEL
ENV HINDSIGHT_API_LOG_LEVEL=info
# 2026-04-17 21:45:33 0.00B 设置环境变量 HINDSIGHT_API_PORT
ENV HINDSIGHT_API_PORT=8888
# 2026-04-17 21:45:33 0.00B 设置环境变量 HINDSIGHT_API_HOST
ENV HINDSIGHT_API_HOST=0.0.0.0
# 2026-04-17 21:45:33 0.00B 声明容器运行时监听的端口
EXPOSE [8888/tcp 9999/tcp]
# 2026-04-17 21:45:33 307.42MB 执行命令并创建新的镜像层
RUN |2 PRELOAD_ML_MODELS=true INCLUDE_LOCAL_MODELS=true /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-04-17 21:44:58 0.00B 设置环境变量 HF_HUB_DOWNLOAD_TIMEOUT
ENV HF_HUB_DOWNLOAD_TIMEOUT=600
# 2026-04-17 21:44:58 0.00B 定义构建参数
ARG INCLUDE_LOCAL_MODELS=true
# 2026-04-17 21:44:58 0.00B 定义构建参数
ARG PRELOAD_ML_MODELS=true
# 2026-04-17 21:44:58 2.61MB 执行命令并创建新的镜像层
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-04-17 21:44:57 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-04-17 21:44:57 0.00B 执行命令并创建新的镜像层
RUN /bin/sh -c mkdir -p /home/hindsight/.pg0 # buildkit
# 2026-04-17 21:44:57 0.00B 指定运行容器时使用的用户
USER hindsight
# 2026-04-17 21:44:56 1.83GB 执行命令并创建新的镜像层
RUN /bin/sh -c chown -R hindsight:hindsight /app # buildkit
# 2026-04-17 21:44:15 0.00B 执行命令并创建新的镜像层
RUN /bin/sh -c chmod +x /app/start-all.sh # buildkit
# 2026-04-17 21:44:15 8.46KB 复制新文件或目录到容器中
COPY docker/standalone/start-all.sh /app/start-all.sh # buildkit
# 2026-04-17 21:44:15 0.00B 设置工作目录为/app
WORKDIR /app
# 2026-04-17 21:44:15 73.66KB 复制新文件或目录到容器中
COPY /app/memory-poc/hindsight-control-plane/public ./public # buildkit
# 2026-04-17 21:44:15 2.50MB 复制新文件或目录到容器中
COPY /app/memory-poc/hindsight-control-plane/.next/static ./.next/static # buildkit
# 2026-04-17 21:44:15 38.51MB 复制新文件或目录到容器中
COPY /app/memory-poc/hindsight-control-plane/standalone ./ # buildkit
# 2026-04-17 21:42:34 0.00B 设置工作目录为/app/control-plane
WORKDIR /app/control-plane
# 2026-04-17 21:42:34 7.59MB 复制新文件或目录到容器中
COPY /app/hindsight-clients/typescript /app/sdk # buildkit
# 2026-04-17 21:42:33 1.79GB 复制新文件或目录到容器中
COPY /app/api /app/api # buildkit
# 2026-04-17 21:42:20 8.93KB 执行命令并创建新的镜像层
RUN /bin/sh -c useradd -m -s /bin/bash hindsight # buildkit
# 2026-04-17 21:42:20 337.71MB 执行命令并创建新的镜像层
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-04-17 21:40:59 0.00B 设置工作目录为/app
WORKDIR /app
# 2026-04-07 10:27:00 0.00B 设置默认要执行的命令
CMD ["python3"]
# 2026-04-07 10:27:00 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-04-07 10:27:00 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-04-07 10:18:53 0.00B 设置环境变量 PYTHON_SHA256
ENV PYTHON_SHA256=272179ddd9a2e41a0fc8e42e33dfbdca0b3711aa5abf372d3f2d51543d09b625
# 2026-04-07 10:18:53 0.00B 设置环境变量 PYTHON_VERSION
ENV PYTHON_VERSION=3.11.15
# 2026-04-07 10:18:53 0.00B 设置环境变量 GPG_KEY
ENV GPG_KEY=A035C8C19219BA821ECEA86B64E628F8D684696D
# 2026-04-07 10:18:53 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-04-07 10:18:53 0.00B 设置环境变量 LANG
ENV LANG=C.UTF-8
# 2026-04-07 10:18:53 0.00B 设置环境变量 PATH
ENV PATH=/usr/local/bin:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin
# 2026-04-06 08:00:00 78.61MB
# debian.sh --arch 'amd64' out/ 'trixie' '@1775433600'
镜像信息
{
"Id": "sha256:5301e5a0538f7ec6bd0260c65b8106ebc9e1f36cc4a67bcab57ad5fe83cf3eda",
"RepoTags": [
"ghcr.io/vectorize-io/hindsight:0.5.3",
"swr.cn-north-4.myhuaweicloud.com/ddn-k8s/ghcr.io/vectorize-io/hindsight:0.5.3"
],
"RepoDigests": [
"ghcr.io/vectorize-io/hindsight@sha256:e1872804e6a9ff16d95b66e42f3ffb22a9f986d1dc91a861f8467ddf544ad842",
"swr.cn-north-4.myhuaweicloud.com/ddn-k8s/ghcr.io/vectorize-io/hindsight@sha256:1086902f21ab9ca0021b1660f0f1c2455f61c0651d9171aba8c6edfde1980e66"
],
"Parent": "",
"Comment": "buildkit.dockerfile.v0",
"Created": "2026-04-17T13:45:33.639635319Z",
"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-04-17T13:40:54.787Z",
"org.opencontainers.image.description": "Hindsight: Agent Memory That Learns",
"org.opencontainers.image.licenses": "MIT",
"org.opencontainers.image.revision": "6ae6663c0df770e2e8ce8a7f2d1c5e1779d892b8",
"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.5.3"
}
},
"Architecture": "amd64",
"Os": "linux",
"Size": 4442692293,
"GraphDriver": {
"Data": {
"LowerDir": "/var/lib/docker/overlay2/5b5ca473756fe247c8849f89974bbe5b3156a182dd784f45575f027355ac50c4/diff:/var/lib/docker/overlay2/c0342c720bc19fd08c8884b305b3cda992cb06a6955fdb194d49f98df53b3810/diff:/var/lib/docker/overlay2/4572d3b8e1e2c9dadb59b0beb261981149c0ae107b5359deb8e4c8fe3326e2bc/diff:/var/lib/docker/overlay2/6ee8ead7f4e109e140bbcddb2677d3dd859b0cb4303aaab6dc8c983344b7cb0f/diff:/var/lib/docker/overlay2/8dd495d42565625320272cc9cfb20cfdffd0af7f6d6002e1339b04f23e5d02a3/diff:/var/lib/docker/overlay2/96e6e1e8d3a1abbfeffe587f93933001160500bb477e0930e52a292cfc8a3b2f/diff:/var/lib/docker/overlay2/ea48fbd042de26a16a1899010e8f084334d6e13ac1a723cbb9a70ddb9fad4f8e/diff:/var/lib/docker/overlay2/948233b1e45623ec83330be561f80e3c34a1c232640584f792a5c27f6912abad/diff:/var/lib/docker/overlay2/cf1b61742296f5a8c5758aa48f9602a24fb93f792a376c1a7c0f13f70bbf6604/diff:/var/lib/docker/overlay2/a2d99b6efb24ea7820dbd9062a3b961aa013d8611257d4a9da14c102a2128bf5/diff:/var/lib/docker/overlay2/ade3bbdc2662c1b7ac3b0168dd9c0e22919c61def45d23f7c2a81d31a9901283/diff:/var/lib/docker/overlay2/8b21f3d4598a87ece220ac25bace41a67fe2e11cee9b40b30fae06b8d0ced961/diff:/var/lib/docker/overlay2/e22a6f758c5d39bfc5fcb8baeabe871bcd177888da6df227b3219b4845818df6/diff:/var/lib/docker/overlay2/81eb49001b5389e6074866f7fba33c09dbf07c0663455d58cca1451642123036/diff:/var/lib/docker/overlay2/96acd30f2f5f07aa6611014cac8153a1f61c3b27d996ad9c1a7e09142ea61b78/diff:/var/lib/docker/overlay2/79c0d114531ad355fbb8a784900aeceea2b838e543a63ff2fd4134b512b0861b/diff:/var/lib/docker/overlay2/c76f8b3b4bd82d466a4091482c13dc6d4b54e39d074fafdc1f93823623823b4f/diff:/var/lib/docker/overlay2/e48a79b34c22e6bde3382abce648725ae76849fd24a3448a7aaa9477dde56461/diff:/var/lib/docker/overlay2/73b30a8c00486fcac9795861fa968fa9cf4da3e05bd3a7a399d85fadd604f815/diff",
"MergedDir": "/var/lib/docker/overlay2/b2eb9e5635b181b86b51243cc353c1628af2439f496af69d45d244348d0dc072/merged",
"UpperDir": "/var/lib/docker/overlay2/b2eb9e5635b181b86b51243cc353c1628af2439f496af69d45d244348d0dc072/diff",
"WorkDir": "/var/lib/docker/overlay2/b2eb9e5635b181b86b51243cc353c1628af2439f496af69d45d244348d0dc072/work"
},
"Name": "overlay2"
},
"RootFS": {
"Type": "layers",
"Layers": [
"sha256:60e70dddd9ea3b1c77c62fe78be1d9f485706b6fe6052c3d88612bd8f56acd67",
"sha256:8076efe3d64ead47a6ac47b688eaba9e19790cd297c7adf15871341d7f1fdb29",
"sha256:6c445a4198d4ece50efa22a99bfa32828954a325c63a8db1ba6ebb1525c9a012",
"sha256:b9d46130ce8be37cb8a372ecf64214756468fe0d6b1d999017cd9865ee37b83d",
"sha256:63776c153d35734c92f26bc5c1c63198b6df81c48aa89ba2768b08016acbb69a",
"sha256:a30ef6f66e1cd37c2394e8ba0de0e6bba4bdec0fc53e397809ba4f6557332ad9",
"sha256:8f32a3d218e0fc9840fc1677e0b698db7ac90f909e8bbfe5d3818b2411c3f5ef",
"sha256:a817162491a4a89e3b373c07198515d67d93896535d407f0776bc974678006d5",
"sha256:b11b5501d70099ea07da5cf61d7483ffbf0b5cacd0255ec23f29195e415cef4a",
"sha256:40efbf252f8851cd7e6381f4de75f2ac176f6ad50229d34dbc39b9a6a3843e7b",
"sha256:acedd8ce500a8c5f7f5732ad9d4299e7aa86b3d086155546ef1e1b869da04389",
"sha256:def2b21f817cd6fb89869488f344d70722c5983763bf300de624d79fb0f55844",
"sha256:e342f67d5b04b062431c1b53649ab47ccabc92dcc63ffc25297262b31e523990",
"sha256:5f70bf18a086007016e948b04aed3b82103a36bea41755b6cddfaf10ace3c6ef",
"sha256:434e11477ae9822a337d5df30d706c30cecb442b17a788657c270db519ef05c0",
"sha256:5f70bf18a086007016e948b04aed3b82103a36bea41755b6cddfaf10ace3c6ef",
"sha256:245bb808817ac2f5cc636bac4b647c0d8d3cc0b1aaf5b918d1674afcd2842f16",
"sha256:369161da8f86d5b069387c711ea32d26a24d2c50e775de9f8d5abf67a0e15b64",
"sha256:62d6506fd8404f7f4bd39535dd4fd20ecd69bb9efb4a0e3725fa933d4b90b35a",
"sha256:c2129770b74bb506f547a9d6333b4675d56f5a240bd5bf5aa94227dda768435e"
]
},
"Metadata": {
"LastTagTime": "2026-04-20T18:01:36.188031306+08:00"
}
}