gpt4 book ai didi

docker - 作为 alpine 容器中的非 root 用户的 Vault 开发模式初始化错误 :/dev/null/. Vault 不是目录

转载 作者:行者123 更新时间:2023-12-02 19:29:30 27 4
gpt4 key购买 nike

标题总结了它。 Dockerfile 如下。我在构建中没有其他错误。 docker run 命令吐出 Error initializing当我在 ENTRYPOINT 之前将用户设置为保管库时,如下所示.

  • 如果我注释掉 USER vault服务器启动没有错误。
  • 如果我将 -dev 选项删除到 vault server但离开 USER vault服务器启动没有错误。

  • 它在/dev/null 中寻找什么,或者它为什么会在那里寻找?我无法在任何相关的谷歌搜索中找到对/dev/null 的任何引用。
    > docker build -t vault-deploy .
    > docker run --rm -it --cap-add=IPC_LOCK -p 127.0.0.1:8200:8200 vault-deploy



    Api Address: http://0.0.0.0:8200
    Cgo: enabled
    Cluster Address: https://0.0.0.0:8201
    Listener 1: tcp (addr: "0.0.0.0:8200", cluster address: "0.0.0.0:8201", max_request_duration: "1m30s", max_request_size: "33554432", tls: "disabled")
    Log Level: trace
    Mlock: supported: true, enabled: false
    Storage: file
    Version: Vault v0.11.0

    Error initializing Dev mode: open /dev/null/.vault: not a directory

    Vault-dev-config.hcl:
    storage "file" {
    path = "/var/vault/data"
    }

    (如果我使用 storage "inmem" {} 或只是让它使用默认配置,我会得到相同的行为。)

    Dockerfile:
    FROM [INTERNAL DOCKER IMAGE REPOSITORY]/alpine-python3

    # Vault is in the testing repository, edge branch.
    RUN echo "http://dl-cdn.alpinelinux.org/alpine/edge/testing" >> /etc/apk/repositories

    # - - - - - - - - - - - - - - - - - - - - - - - -
    # Container packages.
    # libcap: For the setcap executable.
    # - - - - - - - - - - - - - - - - - - - - - - - -
    RUN apk update \
    && apk --no-cache add -u vault \
    && apk add --update libcap \
    && rm -rf /var/cache/apk/*


    # - - - - - - - - - - - - - - - - - - - - - - - -
    # Execution configuration.
    # - - - - - - - - - - - - - - - - - - - - - - - -
    # We won't run as root.
    RUN mv /usr/sbin/vault /usr/bin
    RUN chown vault /usr/bin/vault

    # Make sure the vault executable can run mlock to prevent swapping to disk. We
    # also have to run the container with --cap-add=IPC_LOCK.
    RUN setcap cap_ipc_lock=+ep $(readlink -f /usr/bin/vault)

    # - - - - - - - - - - - - - - - - - - - - - - - -
    # Create and set ownership of /var/vault.
    # Only needed if we're putting a file storage back end here.
    # - - - - - - - - - - - - - - - - - - - - - - - -
    RUN mkdir /var/vault
    RUN chown -R vault:vault /var/vault

    # - - - - - - - - - - - - - - - - - - - - - - - -
    # Create, populate and set ownership of /etc/vault.
    # - - - - - - - - - - - - - - - - - - - - - - - -
    RUN mkdir /etc/vault

    COPY vault-dev-config.hcl /etc/vault/vault-dev-config.hcl
    RUN chmod 600 /etc/vault/vault-dev-config.hcl

    RUN chown -R vault:vault /etc/vault

    # - - - - - - - - - - - - - - - - - - - - - - - -
    # Prepare for launch.
    # - - - - - - - - - - - - - - - - - - - - - - - -
    USER vault
    #Error initializing Dev mode: open /dev/null/.vault: not a directory

    ENTRYPOINT vault server \
    -dev \
    -log-level trace \
    -dev-listen-address 0.0.0.0:8200 \
    -config /etc/vault/vault-dev-config.hcl

    最佳答案

    在 Vault google 组中找到答案。在开发模式下,Vault 将根 key 写入 $HOME/.vault .在我的容器中,保管库用户没有登录或 $HOME , 所以 $HOME默认为 /dev/null .设置$HOME/var/vault解决了这个问题。

    关于docker - 作为 alpine 容器中的非 root 用户的 Vault 开发模式初始化错误 :/dev/null/. Vault 不是目录,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/52866722/

    27 4 0
    Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
    广告合作:1813099741@qq.com 6ren.com