Vagrant 是一个可创建轻便、可复用的虚拟开发环境的跨平台工具,通过打包分可使所有开发成员使用统一的开发环境。

下面是我自己记录配置 Vagrant 的过程。

1、安装 VirtualBox

略。(Vagrant 也支持 VMware,不过需要收费)

2、安装 Vagrant

略。安装完成后在 CMD 输入 vagrant --version 可输出版本。

* 更改 Vagrant Box 镜像存储位置

当镜像文件较多或C盘空间较少时,就需要更改它的存放位置。默认存放在 C:\User\%USERNAME%\.vagrant.d

将 .vagrant.d 移到新位置,打开 CMD,输入

setx VAGRANT_HOME "X:/your/path/to/.vagrant.d"

将 VAGRANT_HOME 添加到用户环境变量。如果要对所有用户生效,那么可以添加到系统环境变量,在末尾加 /M 参数。

重新打开 CMD,输入 echo %VAGRANT_HOME%,将输出设置好的路径。

另外 VirtualBox 虚拟机文件默认也保存在系统盘,可以在 VirtualBox 设置中更改路径。

这里要区分两个概念:Box(镜像) 和 Machine(虚拟机)。他们的关系如同类与对象之间的关系,前者是模板,后者是实例。

3、下载 Box 镜像

我们需要一个基础 Box 镜像来构建 Vagrant 开发环境。

在这里查找你需要的系统镜像:https://atlas.hashicorp.com/boxes/search

我选择的是 ubuntu/trusty64,在 CMD 输入 vagrant box add ubuntu/trusty64 即可下载。

由于某些网络环境因素,下载速度可能很慢,可以选择搭梯子或到这里(https://github.com/chef/bento)用下载工具下载。

下载完成后,导入下载好的 Box 镜像到 Vagrant,等待一段时间。

vagrant box add ubuntu14. K:\YourPath\ubuntu-14.04.box

这里的 ubuntu14.04 是 Box 名称,配置 Vagrantfile 要用到。

输入 vagrant box list 可列出已导入的 Box 镜像。

4、初始化开发环境

新建一个虚拟开发环境的工作目录,CMD 切换到该路径(当没有切换路径时,部分 Vagrant CLI 命令需要附加虚拟机 ID 或 Name)。输入

vagrant init

将在文件夹下创建一个 Vagrantfile,是一个配置文件,用文本编辑器打开。

Vagrantfile 是用 Ruby 写的,不过我们没必要专门去了解它的语法知识,要修改的只是一些简单的变量赋值语句。

简单说明一下其中一些参数。

config.vm.box: Box 名称,必须是一个已导入的 Box 或公共 Box 镜像的简称。

config.vm.hostname: 虚拟机的主机名,注意命名规范。

config.vm.synced_folder: 主机与虚拟机的同步目录,可以共享文件。

config.vm.synced_folder "./data", "/vagrant_data"

第一个参数是主机的目录路径,这里是相对路径。第二个是虚拟机的目录路径,必须是绝对路径。

config.vm.network: 网络相关设置,主要有三种方式:端口映射(FORWARDED PORTS),私有网络(PRIVATE NETWORKS),公共网络(PUBLIC NETWORKS)。详细信息参见 Vagrant 文档。

config.vm.network "forwarded_port", guest: , host: 

表示将虚拟机的80端口映射到宿主机的8080端口。

配置完成后,用 vagrant up 启动虚拟机。

注意输出信息中有一行:

default:  (guest) =>  (host) (adapter )

表示将虚拟机的 22 端口映射到宿主机的 2222 端口,这个是 SSH 连接的端口号。这个端口号可以在 Vagrantfile 中配置。

最后找个ssh客户端连接到虚拟机:

ssh vagrant@127.0.0.1 -p 

vagrant halt 关闭虚拟机。

5、日常使用

打开 CMD,任意目录下输入 vagrant global-status 即可列出所有虚拟机。

>vagrant global-status
id name provider state directory
-------------------------------------------------------------------------
3d51pc7 default virtualbox poweroff K:/YourPath/ubuntu14.04

启动输入 vagrant up 虚拟机id

id 不必完整,但要求标识有唯一性,类似 git 的 commit id 的作用。由于我只有一个虚拟机,所以 id 部分输入 3d 即可。

>vagrant up 3d
Bringing machine 'default' up with 'virtualbox' provider...
==> default: Clearing any previously set forwarded ports...
==> default: Clearing any previously set network interfaces...
==> default: Preparing network interfaces based on configuration...
(后面省略)

日常使用时,慎用 apt-get update、yum update 等更新系统,可能会导致无法挂载共享文件夹,需重装 VirtualBox Guest Additions 。

在 Windows 下部署 Vagrant的更多相关文章

  1. windows 下部署kafka 日记 转

    windows 下部署kafka 日记 转一.下载去apache 的官网(http://kafka.apache.org/downloads.html)下载最新的二进制版的压缩包.目前的最新版本是ka ...

  2. QT程序在windows下部署发布

    转载:http://www.cnblogs.com/Fan_Fan/archive/2010/05/29/1746860.html QT程序在windows下部署发布 以下包括了部分网上收集的,以及q ...

  3. Windows下部署ElasticSearch5.0以下版本

    Windows下部署ElasticSearch分ElasticSearch5.0以上版本(包括5.0)和ElasticSearch5.0以下版本两种情况,这两种安装方式有很大不同.今天首先说Elast ...

  4. 关于在windows下部署发布QT程序的总结

    原文请看:http://www.cnblogs.com/javaexam2/archive/2011/05/18/2632916.html 关于在windows下部署发布QT程序的总结 2008-06 ...

  5. linux centos7 和 windows下 部署 .net core 2.0 web应用

    centos7 下部署asp.net core 2.0应用 安装CentOS7 配置网络[可选] 安装.Net core2.0 创建测试Asp.net Core应用程序 正式部署项目 安装VMware ...

  6. windows 下部署 .netcore 到 docker

    前面我们演示了如何将 Asp.Net Core 程序部署到 iis 和 部署到 windows 服务.其实前面的都是铺垫,如何将 Asp.Net Core 站点部署到 docker 才是这个系列文章的 ...

  7. windows 下部署 .netcore 到 windows service

    接上一篇 <windows 下部署 .netcore 到 iis>,这一篇记录一下怎么将 Asp.Net Core 以 windows 服务的方式部署. 一.修改代码 其实也很简单,只要调 ...

  8. 使用Vagrant在Windows下部署开发环境

    做Web开发少不了要在本地搭建好开发环境,虽然说目前各种脚本都有对应的Windows版,甚至是一键安装包,但很多时候和Windows环境的相性并不是那么好,各麻烦的问题是实际部署的环境通常是Linux ...

  9. Windows 下配置 Vagrant 环境

    Vagrant是一个基于 Ruby 的工具,用于创建和部署虚拟化开发环境.它使用 Oracle 的开源VirtualBox虚拟化系统. Vagrant 在快速搭建开发环境方面是很赞的,试想一个团队中, ...

随机推荐

  1. Spark机器学习示例

    1. Java代码 /* * Licensed to the Apache Software Foundation (ASF) under one or more * contributor lice ...

  2. 小游戏Talk表

    [Config]1|0|2|久远的记忆影子|你也是误入宠物王国的妹子吧,我在这里等你很久了,或许我们应该一起逃出这里,跟着我.[Config] [Config]2|3|2|久远的记忆影子|这里原本是一 ...

  3. [css3]水平垂直居中

    position:absolute; top:50%; left:50%; transform:translate(-50%,-50%);

  4. jquery 巧用json传参

    JavaScript代码,巧用JSON传参数function AddComment(content) { var comment = {}; comment.threadId = $("#s ...

  5. img图片下面出现莫名的下边距解决办法

    图片底部的空隙实际上涉及行内元素的布局模型,图片默认的垂直对齐方式是基线,而基线的位置是与字体相关的.所以在某些时候,图片底部的空隙可能是 2px,而有时可能是 4px 或更多.不同的 font-si ...

  6. zynq学习01 新建一个Helloworld工程

    1,好早买了块FPGA板,zynq 7010 .终极目标是完成相机图像采集及处理.一个Window C++程序猿才开始学FPGA,一个小菜鸟,准备转行. 2,关于这块板,卖家的官方资料学起来没劲.推荐 ...

  7. 静态绑定网关,防止ARP攻击

    Windows XP 下 写个批处理文件:内容如下,名称自取 @echo offard -darp -s 192.168.1.1 00-14-78-ef-10-45//绑定IP地址 WIN 7 下 1 ...

  8. Three.js学习(相机,场景,渲染,形状)

    相机分为透视相机和正交相机(还有第三人称相机不介绍). var camera = new THREE.PerspectiveCamera(75, window.innerWidth / window. ...

  9. 自定义cell(xib)中button点击事件不能响应的情况

    遇到这种问题真的好尴尬,之前从来没有遇到过,以为手到擒来,未曾料到还会遇到问题! 好多年没有找到尴尬的感觉,现在找到了,真的很尴尬 !  *o* 1.首先使用场景: 原本没打算用xib,后来为了快速, ...

  10. 初学者的python学习笔记1

    推荐一段时间闲的蛋疼,总觉得再堕落下去不太好,便捡起了之前一直想学而没有学的python,以此记录一下学习笔记,同时亦是督促和复习. 学习51cto上的<2016最新Python开发基础课程-2 ...