使用 Vagrant 打造跨平臺開發環境
Vagrant 是一款用來構建虛擬開發環境的工具,非常適合 php/python/ruby/java 這類語言開發 web 應用,“程式碼在我機子上執行沒有問題”這種說辭將成為歷史。
我們可以通過 Vagrant 封裝一個 Linux 的開發環境,分發給團隊成員。成員可以在自己喜歡的桌面系統(Mac/Windows/Linux)上開發程式,程式碼卻能統一在封裝好的環境裡執行,非常霸氣。
安裝步驟
1. 安裝 VirtualBox
虛擬機器還是得依靠 VirtualBox 來搭建,免費小巧。
下載地址:https://www.virtualbox.org/wiki/Downloads
* 雖然 Vagrant 也支援 VMware,不過 VMware 是收費的,對應的 Vagrant 版本也是收費的
2. 安裝 Vagrant
下載地址:http://downloads.vagrantup.com/ 根據提示一步步安裝。
此外,還得下載官方封裝好的基礎映象:
Ubuntu precise 32 VirtualBox http://files.vagrantup.com/precise32.box
Ubuntu precise 64 VirtualBox http://files.vagrantup.com/precise64.box
如果你要其他系統的映象,可以來這裡下載:http://www.vagrantbox.es/
* 鑑於國內網速,我們將下載映象的步驟單獨剝離出來了
3. 新增映象到 Vagrant
假設我們下載的映象存放路徑是 ~/box/precise64.box
,在終端裡輸入:
$ vagrant box add hahaha ~/box/precise64.box
hahaha
是我們給這個 box 命的名字,~/box/precise64.box
是 box 所在路徑
4. 初始化開發環境
建立一個開發目錄(比如:~/dev
),你也可以使用已有的目錄,切換到開發目錄裡,用 hahaha
映象初始化當前目錄的環境:
$ cd ~/dev # 切換目錄 $ vagrant init hahaha # 初始化 $ vagrant up # 啟動環境
你會看到終端顯示了啟動過程,啟動完成後,我們就可以用 SSH 登入虛擬機器了,剩下的步驟就是在虛擬機器裡配置你要執行的各種環境和引數了。
$ vagrant ssh # SSH 登入 $ cd /vagrant # 切換到開發目錄,也就是宿主機上的 `~/dev`
~/dev
目錄對應虛擬機器中的目錄是 /vagrant
Windows 使用者注意:Windows 終端並不支援 ssh,所以需要安裝第三方 SSH 客戶端,比如:Putty、Cygwin 等。
5. 其他設定
Vagrant 初始化成功後,會在初始化的目錄裡生成一個 Vagrantfile
的配置檔案,可以修改配置檔案進行個性化的定製。
Vagrant 預設是使用埠對映方式將虛擬機器的埠對映本地從而實現類似 http://localhost:80
這種訪問方式,這種方式比較麻煩,新開和修改埠的時候都得編輯。相比較而言,host-only 模式顯得方便多了。開啟 Vagrantfile
,將下面這行的註釋去掉(移除 #
)並儲存:
config.vm.network :private_network, ip: "192.168.33.10"
重啟虛擬機器,這樣我們就能用 192.168.33.10
訪問這臺機器了,你可以把 IP 改成其他地址,只要不產生衝突就行。
6. 打包分發
當你配置好開發環境後,退出並關閉虛擬機器。在終端裡對開發環境進行打包:
$ vagrant package
打包完成後會在當前目錄生成一個 package.box
的檔案,將這個檔案傳給其他使用者,其他使用者只要新增這個 box 並用其初始化自己的開發目錄就能得到一個一模一樣的開發環境了。
7. 常用命令
$ vagrant init # 初始化 $ vagrant up # 啟動虛擬機器 $ vagrant halt # 關閉虛擬機器 $ vagrant reload # 重啟虛擬機器 $ vagrant ssh # SSH 至虛擬機器 $ vagrant status # 檢視虛擬機器執行狀態 $ vagrant destroy # 銷燬當前虛擬機器
更多內容請查閱官方文件 http://docs.vagrantup.com/v2/cli/index.html
8. 注意事項
使用 Apache/Nginx 時會出現諸如圖片修改後但頁面重新整理仍然是舊檔案的情況,是由於靜態檔案快取造成的。需要對虛擬機器裡的 Apache/Nginx 配置檔案進行修改:
# Apache 配置新增: EnableSendfile off # Nginx 配置新增: sendfile off;
相關文章
- 使用VSCode和CMake構建跨平臺的C/C++開發環境VSCodeC++開發環境
- 跨平臺的C/C++整合開發環境 CLion 2022C++開發環境
- Vagrant 搭建開發環境實踐開發環境
- Vagrant:更好的個人開發環境開發環境
- Vagrant homestead (laravel)開發環境搭建(填坑)Laravel開發環境
- 基於 Vagrant 構建 PHP 開發環境PHP開發環境
- vagrant + centos/7 搭建自己的本地開發環境CentOS開發環境
- Vagrant 環境搭建
- 使用c++開發跨平臺的程式C++
- Nginx開發環境跨域配置Nginx開發環境跨域
- 用Vagrant構建統一的golang開發環境Golang開發環境
- 用 Vagrant 一鍵部署開發環境 kafka 叢集開發環境Kafka
- 基於 vagrant搭建移動端的開發環境開發環境
- Vagrant 搭建 CentOS 環境CentOS
- Hi3511平臺開發環境搭建資料開發環境
- 使用Termux打造你的移動開發平臺UX移動開發
- 2018-07-12 折騰一個開發環境Vagrant開發環境
- 打造跨平臺.NET Core後臺服務
- 跨平臺開發框架的大旗框架
- QT6跨平臺開發QT
- 跨平臺開發框架 Lynx 初探框架
- 1.Vagrant搭建統一開發環境 常用命令開發環境
- 打造優雅高效的 PHP 開發環境PHP開發環境
- 直播平臺開發經驗分享——直播平臺搭建環境配置詳解及分析
- [譯] 使用 Flutter 實現跨平臺移動端開發Flutter
- 移動跨平臺開發深度解析
- 00-跨平臺開發之FlutterFlutter
- 跨平臺開發Flutter初體驗Flutter
- APP跨平臺開發技術分析APP
- 跨平臺開發技術簡介!
- 利用 Vagrant 實現 Laravel 多個開發環境 (Ubuntu 18.4、Ubuntu 16.4) (with Bug)Laravel開發環境Ubuntu
- vagrant構建centos虛擬環境CentOS
- ASP.NET Core微服務如何在雲環境中跨平臺服務?ASP.NET微服務
- 使用webpack搭建react開發環境WebReact開發環境
- 使用 Rainbond 搭建本地開發環境AI開發環境
- 使用 Docker 搭建本地開發環境!Docker開發環境
- 使用 PhpStorm + Docker 搭建開發環境PHPORMDocker開發環境
- 如何在Java程式碼中使用SAP雲平臺CloudFoundry環境的環境變數JavaCloud變數
- 移動端跨平臺開發的深度解析