更新:现在最新的Docker Mac版本已经使用原生的Mac虚拟化,只要用Docker即可,不用再才用本文的繁琐方案了,文件共享什么的只要在Docker中设置好就能轻松共享。
其实Mac下已经能满足我们大部分开发需求了。但是,Mac毕竟不同于Linux,一些环境在Mac需要特殊配置。现在利用VMWare Fusion + CoreOS + Docker这样的组合可以实现开发和部署同样的环境,况且现在docker已经成为一个趋势。
另外选用这个组合主要还是看中CoreOS的极简特性,占用资源比较小,在Macbook Pro上跑几个CoreOS虚拟机问题不大,然后再配合Docker,俨然一个服务器集群。
最新版本的CoreOS提供了ova格式,另外也对VMWare提供了比较好的支持。这里,我们主要利用VMWare的vmx文件配合CoreOS中的Cloud-config对CoreOS进行配置,比如添加用户、添加ssh_authorized_keys、启动服务等等。
一、安装CoreOS
详细的安装过程见这里:https://coreos.com/os/docs/latest/booting-on-vmware.html
使用Fusion安装比较简单,直接打开ova文件就行,安装过程中会弹出一个选择框,点击重试即可。
安装好后,不要着急运行,可以先配置一下网络,让虚拟机仅在本机可见。
然后,在虚拟机资源库中找到coreos,点击右键选择“在Finder中显示”,然后点击右键选择“显示包内容”,找到.vmx文件,我这里的文件名是coreos_production_vmware_ova.vmx。我们就是通过配置这个vmx文件来配置CoreOS。
先创建一个简单的cloud-config文件,内容如下:
#cloud-config
hostname: coreos0
users:
- name: "drsun"
passwd: "$6$rounds=4096$8mcy5d..."
groups:
- "sudo"
- "docker"
ssh-authorized-keys:
- "ssh-rsa AAAAB3Nza..."
cloud-config文件的必须以#cloud-config开始
其中hostname用来设置主机名,这里将主机名设为coreos0
users增加了一个用户,name设置用户名,passed字段设置密码,groups是将用户添加到用户组,这里将用户添加sudo和docker的group,ssh-authorized-keys添加的key,可以使用ssh -i 命令直接登录。
创建密码:
$ openssl passwd -1
Password:
Verifying - Password:
$1$Vo4vqWcd$qli5Tb8wW8DKBtKJqWkIw1
创建ssh-authorized-keys
$ ssh-keygen -t rsa
Generating public/private rsa key pair.
Enter file in which to save the key (/Users/drsun/.ssh/id_rsa): id_rsa
Enter passphrase (empty for no passphrase):
Enter same passphrase again:
Your identification has been saved in id_rsa.
Your public key has been saved in id_rsa.pub.
将生成的id_rsa.pub文件中内容放到ssh-authorized-keys中。
需要注意的是cloud-config是yaml格式,详细的配置见这里具体Cloud-config详细配置请参考这里:https://github.com/coreos/coreos-cloudinit/blob/master/Documentation/cloud-config.md
配置好cloud-config,执行下面命令将cloud-config文件编码
gzip -c cloud-config | base64 && echo
然后在vmx文件中追加如下两行:
guestinfo.coreos.config.data = “这里是编码后的cloud-config文件内容"
guestinfo.coreos.config.data.encoding = "gzip+base64"
虚拟机启动后会在console显示本机IP,此时可以使用在cloud-config中添加的用户通过ssh登录虚拟机。
二、文件共享
我们当然不想直接在虚拟机下开发,那么代码怎么同步到虚拟机中呢?
这里可以使用NFS协议来共享。
这里假设我们的开发目录是/Users/drsun/work
然后执行如下命令创建NFS共享
sudo echo "/Users/drsun/work -alldirs" >> /etc/exports
sudo nfsd enable #确认NFSD服务开启
sudo nfsd update #刷新NFSD共享资源
showmount -e #显示当前共享的资源
注意目录中如果用空格需要对空格转义。另外,共享的目录还会涉及权限相关,可以在Finder中先设置好。
此时在虚拟机中可以执行
sudo mount 10.200.79.156:/Users/drsun/study/coreos /home/core/study
将共享的目录挂载到虚拟机中之后在通过docker的数据卷功能挂载到容器中。