Windows 10下使用Docker配置开发环境

考虑到效率问题以及镜像速度以及容器尺寸等等因素,决定使用Docker而放弃Vagrant制作开发环境。我对开发环境的需求就两条:

  1. 可以通过共享文件夹本地编辑,容器中运行
  2. 有远程访问的端口,可以登录各种服务、远程调试等

风闻alpine尺寸很小,本打算用apline做基础镜像。后来发现主要应用面为嵌入式设备,没有gcc,用的是musl-libc;所使用的binutils也是busybox版本;此外一些bash命令功能不完全,如diff没有--exclude选项。所以还是老老实实回归ubuntu了。

最新的Docker for Windows 10已经不用Docker Toolbox(使用virtualbox做虚拟化)了,改用了微软原生的Hyper-V技术,理论上后者是从硬件开始虚拟化,效率会更高。然而二者是互斥的,也就是说当你打开了Hyper-V支持之后,virtualbox就用不了了。下面开工:

  1. 下载Docker for Windows,无它。
  2. 添加国内镜像:状态栏右键docker图标->Settings->Daemon->"Registry mirrors",加入Docker的官方国内镜像“https://registry.docker-cn.com”
  3. 添加共享盘符:状态栏右键docker图标->Settings->Shared Drives,勾选共享目录
  4. 执行docker pull ubuntu下载ubuntu镜像
  5. 执行docker create -it -v D:\works:/works ubuntu创建包含ubuntu的容器,并挂载本地目录D:\works到容器中的/works目录下。其中参数-i打开交互, -t为容器打开终端,合起来就是为容器打开一个可交互的终端。而-v则指明了本地目录和容器目录之间的映射。你还可以加上--name *YOUR_NAME* 参数为你新创建的容器起一个华丽的名字。
  6. 执行docker ps -a查找刚创建的容器的id,然后执行docker start CONTAINER_ID后台启动该容器。若要进入该容器,需要执行docker exec -it CONTAINER_ID sh让容器执行命令bash。这三步有可能存在的问题是docker start之后容器无事可做就退出了,而docker exec只能在运行中的容器里执行命令。于是利用docker run将以上种种合成一步,具体为:
     docker run -it -v D:\works:/works --name YOUR_NAME ubuntu bash

如此创建的目录映射,即使系统的docker服务重启了都还是存在的。注意:本地目录需要采用绝对路径(Linux下可以使用'~'),如果是相对路径的话,docker会认为是其服务默认路径(太长太难找)下的子目录,并自动创建之。

  1. 修改ubuntu的镜像为国内镜像,如阿里云的镜像。
     # 备份原始文件
     cp /etc/apk/repositories  /etc/apt/sources.list.bak
     # 修改为国内镜像源,将所有的archive.ubuntu.com替换为mirros.aliyun.com
     sudo gedit /etc/apt/sources.list
     # 更新索引
     sudo apt-get update
  1. 安装必须的包,如:apt-get install git等,可以开工了。使用build-dep参数安装包的时候,尝试将/etc/apt/sources.list里面的dep-src源的注释去掉,如“xenial main restricted”的。不然会出现类似“Unable to find a source package for qemu”的错误。如果想添加源,会用到add-apt-repository命令,该命令不是由python-software-properties包提供。可以安装apt-file命令,用apt-file search查找包含该命令的需要安装的包。

你可能感兴趣的:(Windows 10下使用Docker配置开发环境)