共计 1450 个字符,预计需要花费 4 分钟才能阅读完成。
最近在应用 Docker Compose 部署服务时,我在 docker-compose.yml
文件中应用了 $PWD 变量来指定 HOST 门路。然而,我发现指定的门路并没有达到预期成果。
问题复现
先来看一段 docker-compose.yml
的配置文件:
version: "3.9"
services:
xui:
image: enwaiax/x-ui
container_name: xui
volumes:
- $PWD/db/:/etc/x-ui/
- $PWD/cert/:/root/cert/
restart: unless-stopped
network_mode: host
我将 docker-compose.yml
放到了 /data/apps/x-ui
目录下,下面的配置文件看起来并没有任何问题,应用了 $PWD
变量来示意当前目录,那么依照预期的话,HOST 相对挂载门路为:
- /data/apps/x-ui/db/
- /data/apps/x-ui/cert/
当我执行 sudo docker-compose up -d
运行容器的时候,并没有报错,然而 HOST 挂载门路并未依照预期的工作,理论的 HOST 相对挂载门路确变成了:
- /db/
- /cert/
看起来仿佛 $PWD
变量丢了或者没有失效?
问题剖析与解决
于是我把这个问题抛给了 ChatGPT 征询了下,给我的答案是:
看起来你的问题的确是 $PWD
变量没有失效。这可能是因为你在应用 sudo
时,环境变量未能传递给 docker-compose
命令。
要解决这个问题,你能够尝试以下办法:
- 将
$PWD
替换为绝对路径。例如,将/data/apps/x-ui
作为挂载门路的前缀:
version: "3.9"
services:
xui:
image: enwaiax/x-ui
container_name: xui
volumes:
- /data/apps/x-ui/db/:/etc/x-ui/
- /data/apps/x-ui/cert/:/root/cert/
restart: unless-stopped
network_mode: host
- 应用
sudo -E
选项来保留环境变量:
sudo -E docker-compose up -d
这将确保 $PWD
变量在执行 docker-compose
命令时放弃失效。不过须要留神的是,应用 -E
选项可能存在肯定的平安危险,因为它会将以后用户的所有环境变量传递给 sudo
命令。请确保你理解可能的危险,并确保以后环境中没有蕴含敏感信息的变量。
解决方案补充
在下面的问题中,ChatGPT 给出了 2 种解决方案都能解决 $PWD
变量生效的问题,其实还有另一种计划就是应用相对路径,比方:
version: "3.9"
services:
xui:
image: enwaiax/x-ui
container_name: xui
volumes:
- ./db/:/etc/x-ui/
- ./cert/:/root/cert/
restart: unless-stopped
network_mode: host
而后再进入 /data/apps/x-ui
目录下执行 sudo docker-compose -d
即可。
结语
在应用 sudo
命令时,局部环境变量可能无奈正确传递给后续命令。为了解决这个问题,咱们能够应用 sudo -E
参数来保留环境变量,或者防止依赖环境变量,转而应用绝对路径或相对路径。这一点须要特地留神,尤其是当普通用户通过 sudo
命令操作 Docker 时。
此文章首发于我的独立博客:https://blog.xiaoz.org/archives/18657