本文讲的是Windows 2016 TP5上的Docker初次体验, 【编者的话】微软5.28发布Windows 2016 Technical Preview 5,作者第一时间上手,记录发现的新变化,看样子要接着往下写呢。这是第一篇,快来瞅瞅吧。

昨天(2016年4月28日),微软宣布Windows 2016 Technical Preview 5可用。我当然要赶紧查看一下新的TP5和去年11月份发布的TP4有什么不同了。 因为还没找到Azure模板(更新:今天我找到了 Windows Server 2016 Technical Preview 5 ),我是在 TP5 branch 上准备封装模板(packer templates)的,不过想要自动构建和安装Docker以及Docker基本镜像,还需要一些修改。

虽然没有一个完美的解决方案,但构建第一个Vagrant box也是一个很好的开头,剩下的步骤就手动按照这篇来

Container Host Deployment - Windows Server

我真是要陷到这个自动化工作流里面去了

1. packer build
2. vagrant box add
3. vagrant up
4. vagrant destroy -f

不过你不会,因为要建立一个这样的测试环境,设置起来很难。

如果你没这个耐心去搞一个完整的封装模板,可以按照

Arun Gupta的步骤在VirtualBox创建一个TP5 VM

下面我们来看看TP5有什么新东西吧。

太快了—再也不用sleep

在TP5中用Windows Dockerfile创建Docker镜像,比之前在TP4中 快 多了,另外以前每个 run

命令中都要sleep几秒,现在sleep完全没必要,赶紧删了吧。 

IP地址可查

之前TP4中的一个移植障碍( Docker Birthday app to TP4 Windows containers

)是不能获取每个容器的IP地址。现在只要运行 docker inspect

便可以显示容器IP了。

之后我会测试

docker-compose.yml

文件中的链接,看是否能用简单的host名建立一个简单的多容器应用。

不过这已经是Windows容器网络的一次提升了。

npipe就是你的unix socket

还有一个有意思的事儿,Docker引擎现在可以监听一个Windows命名的管道(pipe),就像Linux上的Unix socket。

这就导致你运行Docker命令的行为非常Unix化,你必须要“sudo”一下:

在没有管理员权限时尝试运行Docker客户端,你根本就连不上。

有一个办法可以允许指定用户使用这个命名管道,类似在Linux上把用户添加到docker group,不过我在这次小测试中还没找到这个group的名字。

Kitematic 和 Windows兼容(Kitematic meets Windows (again))

当晚我还在并行虚拟机中玩了一把Windows测试版的Docker,虚拟机中同时安装了Kitematic。因为测试版不是通过VirtualBox使用Kitematic的,我认为在TP5上应该也能用。所以我移除了Beta download的压缩文件,稍微调整了我的TP5设置,使得Kitematic和Window Docker Engine之间可以通信。

我采取的方法相当实用,把本地TCP端口2375添加到Docker Engine:

notepad C:\ProgramData\docker\runDockerDaemon.cmd

再把dockerd命令改成:

dockerd -H npipe:// -H 127.0.0.1:2375

然后运行:

restart-service docker

下载的测试版kitematic也会搜索

docker.local

,所以我在主机表中加了回环IP地址:

notepad C:\Windows\system32\drivers\etc\hosts  

现在Kitematic启动时不再创建新的本地的虚拟机,也不会在左侧的窗口显示本地Windows容器了。启动时不再创建新的本地的虚拟机,也不会在左侧的窗口显示本地Windows容器了。

TP5还有很多东西要去探索,现在你能可以在Docker Hub上pull/push Docker镜像。

敬请期待即将出炉的新博客。有了TP5,社区可以更好的关注Docker在Windows上的进步,还能查看Windows Docker Engine上的最新改进和pull请求。

如果这篇文章对你有用,请分享给朋友和同事。如果你有问题或更好的建议,请留下评论。你还可以在推特

@ stefscherer

关注我。