打造 Mac 下的完美开发环境

特别提醒:本文所描述的内容略微有点蛋疼,仅适合像我这样喜欢折腾,并且有软件洁癖的 Mac 用户;否则,请用包容的心态看待它。。。

背景

我使用的是 Mac 电脑,平时捣鼓一些东西时需要用到各种开发环境。虽说 Mac OS 对开发者非常友好,但是作为一个喜欢折腾,并且有软件洁癖的人来说,问题也不少:

拿 Web Server 来说,Mac 自带了 Apache,但我更喜欢用 Nginx,我的线上服务都是用的 Nginx。于是我面临两个选择:要么开发环境和线上环境使用不同的 Server;要么在 Mac 上再装一个 Nginx。这两者我都不能接受:前者意味着我要为不同的 Server 写不同的配置,违背了最基本的「Do Not Repeat Yourself」原则;后者违背了我「同功能软件绝不装两个」的洁癖原则。

再者,Mac 下大部分软件,要么可以从 App Store 获得,要么挂载 dmg 安装包后把 App 拖进 Application 文件夹即可;卸载则直接拖进废纸篓(当然 AppCleaner 必不可少),十分优雅自然。可是,大部分跟开发有关的安装包都是 pkg 格式,需要一步步安装确认,装完没有图标,完全不知道装哪儿去了不说,想卸载都难,相当不环保。更有甚者,很多开发相关软件只提供源码包,需要自己编译。

说到在 Mac 下编译软件,不出意外都会遇到「缺少 gcc」这样的错误。这个问题最简单的解决方案是装那个好几百 M 的 command line tools。这还算好,以前你得装好几 G 的 Xcode。

Mac 自带了很多开发环境,如 Python、Ruby 什么的,开箱即用。但是,想升级它们又不是一件简单的事情。实际上去 Python 官网下载最新的 Python for Mac 装完后会发现,系统自带的 Python 并没更新,新版 Python 装在另外一个位置,系统同时拥有了两个版本的 Python 有木有!

最后再说一个问题:费尽心思弄好的环境,很可能被系统升级弄坏!例如升到 Mac OS 10.9 Mavericks 之后,系统自带的 Python 被升到 2.7.5,之前装的库统统不见了!JDK 木有了!Node 环境也得重装!

准备

给我提供线上服务的 VPS 们(一台 Linode 和一台 DigitalOcean,哈哈)都是装的 Ubuntu 13.04。理想的开发环境当然是跟线上保持一致,但 Mac OS 太好用了,我总不至于装个 Ubuntu 日常使用吧。

文章过半,主角终于要露面了,它就是「Parallels Desktop 9」,也就是俗称的虚拟机软件。为什么是 9 呢?前面说过我的 Mac 升级到 10.9 了,最新的系统当然需要最新的软件来配。。。说到 PD 9 想到个坑爹的事情,某天我收到一封来自 PD 官方的邮件,大意是「你现在可以以 XXX 的优惠价购买新增了 XX 项超牛功能的 PD9,机会难得别错过」,然后我一冲动就花 XXX 升级了。直到某天看到这个:

parallels desktop (真相是:虽然都是 XXX 元,选升级会附赠长达半年之久的我完全用不上的 iPad PD 服务)

好了,言归正传,想必大家已经猜到了我是准备在虚拟机里安装与线上一致的 Ubuntu 13.04,来作为我的开发环境宿主系统。没错,我确实是这么做的。

开工

Ubuntu 选择 Server 版就可以了,一来跟线上保持完全一致,二来也完全用不上它的图形界面。内存分配 1G 足够了。整个系统装完,硬盘才用了不到 3G。在我产于 Early 2013 的高配 rMBP 13 上,这个虚拟系统休眠和恢复速度相当快。实际上,现在主流电脑的性能,都卡在硬盘上,换成 SSD 就飞快了。

PD 默认使用的虚拟机联网方式,保证了虚拟机 IP 固定不变。在虚拟机下通过 ifconfig 命令获得 IP 后,编辑 Mac 的 Host 文件,用一个好记的单词指向它,例如我用的是「Q」。

为了更方便地在 Mac 中控制虚拟机,我们给它装个 SSH Server,在虚拟机中「apt-get install openssh-server」就可以了。这样,在 Mac 下,直接「ssh jerry@Q 」就能连上虚拟机了。顺手再建立到虚拟机的信任关系,以后输入密码这一步就可以省了。

接下来,在这个纯正的 Ubuntu 下安装需要的所有软件,有 apt-get 感觉真好。由于虚拟机系统走的是本地网络,下载速度没国外 VPS 那么快,换成国内源会好不少。

我的 MySql 也装在虚拟机里,可以通过同样装在虚拟机里的 phpMyAdmin 来管理它;也可以直接让 MySql 允许远程连接,用 Sequel Pro 这个免费好用的 App 来管理;还可以通过 Sequel Pro 的 SSH 隧道连接来管理它。

我的代码存放在 Mac 中,在 PD 配置共享,让虚拟机可以读写。这样一来我可以继续在 Mac 下编写和管理代码,另一方面,虚拟机中的开发环境又能访问到最新代码。

Mac 系统中,有一些用来存放文件属性的隐藏文件,例如 .DS_Store。如果不想在虚拟机中看到它们,可以修改 .bashrc 文件中 ll 别名如下,用 -I 参数排除不想看到的内容:

alias ll='ls -alF -I .DS_Store'

备份

经过上面这一番折腾之后的成果,当然要好好保存。我的 Mac 系统有 Time Machine 定期做备份,所以我的代码们是安全的。而虚拟机里只有运行环境,没有数据(开发环境的 MySql 数据不重要,忽略),没必要定期备份。我在配置好所有环境后,给虚拟机做了一个快照,方便弄坏时恢复,再把整个虚拟机文件在移动硬盘上也拷贝了一份,这样就万无一失了。

后记

这么弄好之后用了几周,我对这个方案非常满意。首先,我的开发环境无论怎样折腾都没关系,大不了从快照恢复再来;Mac 系统也干干净净,简洁优雅。附带的好处是,不想写码时,把虚拟机休眠,那些用不到的开发环境瞬间消失不见。真是招之则来,挥之则去!

注:这篇文章写于 500 多天前,实际上现在利用虚拟机部署开发环境的做法已经很普遍了,例如 vagrantdocker。我本人也改为使用 vagrant 了。详情请看这里:开始使用 Vagrant

本文链接:参与评论 »

--EOF--

提醒:本文最后更新于 1154 天前,文中所描述的信息可能已发生改变,请谨慎使用。

专题「开发工具」的其他文章 »

Comments