Vagrant 手册之 Multi-machine 多机器
Vagrant 可以在一个 Vagrantfile 中定义并控制多个虚拟机。这就是“multi-machine”环境。
这些机器可以协同工作或互相关联。multi-machine 的常见用例有:
- 准确建模多服务器生产拓扑,例如分离 Web 和数据库服务器。
- 建模分布式系统,以及它们如何相互交互。
- 测试接口,比如一个到服务组件的 API。
- 灾难情况测试:机器正在死亡,网络分区,网络速度慢,不一致(inconsistent world views)等。
注意,这只是生产环境的不准确模型,其行为可能有很大不同。
使用 Vagrant 的多机功能,可以在单个 Vagrant 环境中对这些环境进行建模。
定义多个机器
通过 config.vm.define 方法调用可以在一个 Vagrantfile 中定义多个机器,这个指令可以在配置中创建 Vagrant 配置:
Vagrant.configure("2") do |config|
config.vm.provision "shell", inline: "echo Hello"
config.vm.define "web" do |web|
web.vm.box = "apache"
end
config.vm.define "db" do |db|
db.vm.box = "mysql"
end
end
正如你所看到的,config.vm.define 带有另一个变量的块。这个变量,比如上面的 web,与 config 变量完全相同,除了内部变量的任何配置只适用于被定义的机器。因此,web 上的任何配置只会影响 web 机器。
重要的是,可以继续使用 config 对象。config 对象在特定于机器的配置之前加载并合并,就像 Vagrantfile 加载顺序中的其他 Vagrantfile 一样。
这类似语言如何具有不同的变量作用域。
在使用时,provisioner 等的执行顺序变得重要。Vagrant 按照 Vagrantfile 中列出的顺序根据作用域由外而内执行。例如,使用下面的 Vagrantfile:
Vagrant.configure("2") do |config|
config.vm.provision :shell, inline: "echo A"
config.vm.define :testing do |test|
test.vm.provision :shell, inline: "echo B"
end
config.vm.provision :shell, inline: "echo C"
end
provisioner 的输出是“A”,然后“C”,然后是“B”。注意,最后才是“B”。这是因为执行顺序是由外而内。
如果需要在多个机器上使用略有不同的配置,参考 这个知识点。
控制多个机器
在 Vagrantfile 中定义了多台机器时,各种命令的用法稍有变化。
只有作用在单个机器上(如 vagrant ssh)才有意义的命令现在需要机器的名称来控制。对于上面的例子,需要 vagrant ssh web 或 vagrant ssh db。
其他命令(如 vagrant up)默认在每台机器上运行。所以如果运行 vagrant up,Vagrant 会启动 web 和 db 两个机器。也可以通过 vagrant up web 或 vagrant up db 启动特定机器。
此外,可以指定一个正则表达式来仅匹配某些机器。这在指定很多类似机器的情况下很有用。例如,如果正在测试一个分布式服务,可能有一个 leader 机器,follower0,follower1,follower2 等等。如果想启动所有的 follower,但是不启动 leader,则可以执行 vagrant up /follower[0-9]/。如果 Vagrant 在正斜杠内看到机器名称,则会认为正在使用正则表达式。
机器之间通信
为了促进多机设置中机器间的通信,应使用各种网络选项。特别是,private 网络可用于在多台机器和主机之间建立 private 网络。
指定主机器
可以指定一台主机器。当未指定多机环境中的特定机器时,主机器将成为默认机器。
要指定默认机器,只需在定义它时通过 primary: true 将其标记为主。只能指定一台主机器。
config.vm.define "web", primary: true do |web|
# ...
end
自动启动机器
默认情况下,在多机器环境中,vagrant up 将启动所有定义的机器。autostart 选项可以告诉 Vagrant 不启动特定机器。例:
config.vm.define "web"
config.vm.define "db"
config.vm.define "db_follower", autostart: false
使用上面的设置运行 vagrant up 时,Vagrant 会自动启动 web 和 db 两个机器,但是不会启动 db_follower。可以通过 running vagrant up db_follower 手动启动。
Vagrant 手册之 Multi-machine 多机器的更多相关文章
- Vagrant 手册之多个虚拟机 multi-machine
原文地址 Vagrant 可以通过一个 Vagrantfile 定义并控制多个客户机.这就是所谓的"multi-machine"多虚拟机环境. 这些机器通常可以协同工作,或者互相关 ...
- Vagrant 手册之 Vagrantfile - 机器设置 config.vm
原文地址 配置的命名空间:config.vm config.vm 中的设置修改 Vagrant 管理的机器的配置. 1. 可用的设置项 config.vm.boot_timeout Vagrant 等 ...
- Vagrant 手册之网络 - 端口转发
原文地址 Vagrantfile 配置文件中端口转发的网络标识符:forwarded_port,例如: config.vm.network "forwarded_port", gu ...
- 【Poj1325】Machine Schedule机器调度
目录 List Description Input Output Sample Input Sample Output HINT Solution Code Position: http://poj. ...
- Vagrant 手册之 Provisioning - 基本用法
原文地址 虽然 Vagrant 提供了用于配置虚拟机的多个选项,但是有标准用法,好多知识点对这个 provisioner 是通用的. 配置 首先,Vagrantfile 中配置的每个 provisio ...
- Vagrant 手册之 Provisioning - 概述
原文地址 通过 Vagrant 中的 provisioner 配置程序,可以在使用 vagrant up 启动虚拟机时,在虚拟机上执行安装软件.更改配置等操作. box 通常是通用的,而每个项目总有自 ...
- Vagrant 手册之 Provisioning - Shell 配置程序
原文地址 Provisioner 命令:"shell" 示例: node.vm.provision "shell" do |s| s.inline = < ...
- Vagrant 手册之 Vagrantfile - SSH 设置 config.ssh
原文地址 配置的命名空间:config.ssh config.ssh 中的设置与配置 Vagrant 如何通过 SSH 访问您的计算机相关. 大多数 Vagrant 设置一样,一般使用默认设置即可,但 ...
- Vagrant 手册之 Vagrantfile - 提示及技巧
原文地址 Vagrantfile 是一种非常灵活的配置格式.语法基于 Ruby,可以用它做很多事情.在本页使用一些提示和技巧时,请注意正确使用它们. 1. 使用循环定义虚拟机 如果你想对多机器应用稍微 ...
随机推荐
- JAVA总结--泛型
泛型 :程序设计语言的一种特性:将类型参数化: 特征:凡是涉及到强制类型转化的地方,使用泛型均会编译出现问题:泛型仅仅在编译时进行校验,使用泛型的对象,其本质的类型依然不变: ps:不存在泛型数组 一 ...
- Java中获取大小:length、length()、size()
1. java 中的 length 属性是针对数组说的,比如说你声明了一个数组,想知道这个数组的长度则用到了 length 这个属性. 2. java 中的 length() 方法是针对字符串说的,如 ...
- java基础常问面试题
1.面向对象和面向过程的区别 面向过程 :面向过程性能比面向对象高. 因为类调用时需要实例化,开销比较大,比较消耗资源,所以当性能是最重要的考量因素的时候,比如单片机.嵌入式开发.Linux/Unix ...
- Consul集群Server+Client模式
Consul集群Server+Client模式 架构示意图 只使用Consul的Server模式有以下2个问题: 因为Consul Server数量受到控制所以压力承载(扩展性)是个问题. Serve ...
- Mybatis-基本步骤
1.1Mybatis框架概述 Mybatis是基于Java的持久层框架,内部封装了jdbc,使开发者只需关注sql语句本身,而不需要花费精力去处理加载驱动.创建连接.创建Statement等繁杂的过程 ...
- 初学css 行内元素与块级元素
行内元素与块级元素直观上的区别 1.行内元素会在一条直线上排列,都是同一行的,水平方向排列块级元素各占据一行,垂直方向排列.块级元素从新行开始结束接着一个断行. 2.块级元素可以包含行内元素和块级元素 ...
- C# DataTable 去重复数据方法
//获取dt中Id,Value 2个字段不重复的数据 newDt = dt.DefaultView.ToTable(true, "Id","Value" );
- 模块之re模块
八.正则表达式 1.1首先我们先了解re模块与正则表达式的关系: re模块与正则表达式之间的关系 正则表达式不是python独有的 它是一门独立的技术所有的编程语言都可以使用正则,但是如果你想在pyt ...
- STM32之红外遥控信号自学习实现
一.序言 很早前就想实现这个红外遥控自学习的这个实验,用于来自己控制房子里如空调等红外遥控设备的自动化,NEC的标准到具体的产品上可能就被厂家定义为不一样了,所以自学习就应该是接收到什么就发送什么,不 ...
- 安装Erlang使用RabbitMQ
首先登陆官网进行下载:https://www.erlang.org/downloads/20.3 本次下载的版本是20.3,rabbitmq准备使用3.7.17版本 现在开始安装 因为是使用c#语言, ...