docker desktop win10挂载问题解决

更新于2020/8/13

适用

此文章适用于安装完docker desktop install ,for windows10,并且是默认使用wsl2安装的docker。现在的win10家庭版也已经支持安装。
注意如果我们不把docker集成到已有的wsl2的linux发行版(如图),docker自己的发行版是没有bash(如果有进入docker发行版shell的方法请大佬告知)


没有其他wsl2的linux分发版

尝试

docker的wsl2分发版

在power shell输入(CMD 不支持将 UNC 路径作为当前目录)

> docker --version
Docker version 19.03.12, build 48a66213fe
> wsl -l -v
  NAME                   STATE           VERSION
* docker-desktop-data    Running         2
  docker-desktop         Running         2
> cd \\wsl$\docker-desktop-data
> dir
    目录: \\wsl$\docker-desktop-data

Mode                 LastWriteTime         Length Name
----                 -------------         ------ ----
d-----         2020/8/12     10:44                isocache
d-----         2020/8/12     10:25                etc
d-----         2020/8/12     10:25                version-pack-data
d-----         2020/8/12     10:25                mnt
d-----         2020/8/12     15:07                sys
d-----         2020/8/12     15:07                dev
d-----         2020/8/12     10:25                sbin
d-----         2020/8/12     10:25                bin
d-----         2020/8/12     15:07                run
d-----         2020/8/12     15:07                proc
d-----         2019/4/11      0:35                lost+found
------         2020/6/10     12:39         631968 init
------         2020/5/27     18:57        2359704 wsl-keepalive

最开始的想法是docker的分发版中是不是可以像Linux一样的挂载文件,可惜没有成功。
在docker-desktop-data会保存docker的iamge和容器数据,暂时不清楚docker-desktop分发版的作用,可能是docker实际运行的分发版?
通过查看官方的文档,发现docker wsl2安装的版本Settings已经没有Shared Devices选项,因为docker的文件挂载交给了wsl2的机制处理。
我们可以看到docker安装后wsl2默认的分发版是dockers-desktop-data,尝试使用sh或者bash进入这个分发版:

> wsl -l -v
  NAME                   STATE           VERSION
* docker-desktop-data    Running         2
  docker-desktop         Running         2
> wsl
> bash
> 

可以看到这个Linux分发版中没有sh和bash。我们切换为另一个分发版:

> wslconfig /setdefault docker-desktop
> wsl
DESKTOP-xxxxxxx:/tmp/docker-desktop-root/mnt/host/c# exit
> bash
DESKTOP-xxxxxxx:/tmp/docker-desktop-root/mnt/host/c# ll
bash: ll: command not found
DESKTOP-xxxxxxx:/tmp/docker-desktop-root/mnt/host/c# ls -a
.
..
0409
(省略)

很明显,docker-desktop分发版中有sh和bash。但是这个分发版的根目录其实不是docker挂载时的根目录。

> bash
DESKTOP-8JLAOP6:/tmp/docker-desktop-root/mnt/host/c# cd /
DESKTOP-8JLAOP6:/# docker
bash: docker: command not found
DESKTOP-8JLAOP6:/#

挂载尝试运行

官方文档介绍了挂载的方法
https://docs.docker.com/docker-for-windows/wsl/

官方的示例

由于我们不想安装其他的wsl2发行版,只好用不推荐的直接挂载windows文件夹的方法。
但是最后发现(挂载桌面文件示例)

docker run -v /mnt/c/Users/user/Desktop/...:<container-path> <image>

不报错但根本没有挂载成功。

解决

可能是官方文档的失误,我又查找了wsl2的说明文档,找到了win系统磁盘在wsl2上的设置文件:

DESKTOP-xxxxxxx:/# vi etc/wsl.conf
[automount]
root = /mnt/host
crossDistro = true
options = "metadata"
~
~

显然c盘映射到了/mnt/host/c,而不是/mnt/c。但是使用此路径挂载依旧无效。
最后在前辈的文章https://www.jianshu.com/p/18593d1f4fc3上找到答案,此处记录一下正确的挂载命令:

docker run -v //c/Users/user/Desktop/...:<container-path> <image>

注意盘符一定要小写。
挂载文件一定要注意windows的CRLF文件在Linux上有兼容问题,最好始终使用LF文件,windows上的IDE基本都可以正常读取LF文件。windows上的git默认选项会自动把项目的LF换为CRLF,取消方法

git config --global core.autocrlf false

优化性能

既然官方建议我们在linux文件系统下进行挂载,我最后找到了方法把挂载文件放在Linux文件系统中。通过文件资源管理器将挂载文件直接放入docker的运行时根目录下(开启docker后才可以访问)

> cd \\wsl$\docker-desktop\mnt\version-pack\containers\services\docker\rootfs

比如我们要挂载下面的文件夹:(可以直接在windows文件资源管理器地址栏输入查看)

\\wsl$\docker-desktop\mnt\version-pack\containers\services\docker\rootfs\tmp\mydir

命令为

docker run -v /tmp/mydir:<container-path> <image>

更新:注意这个目录是运行时目录,docker停止运行后会失去持久化,重启后还原为原目录。暂时没有找到其持久化的方法。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。