vagrant provision 典型应用场景

简介: 让虚拟机初始创建时,添加自定义的包管理器的源。准备镜像仓库的源配置文件如本例中的:我的虚拟机工作目录是 /Users/pollyduan/vm虚拟机工作目录为/Users/pollyduan/vm/ubuntu我创建了一个/Users/pollyduan/vm/data 作为保存共享所需的软件和资源。

让虚拟机初始创建时,添加自定义的包管理器的源。

准备镜像仓库的源配置文件

如本例中的:

我的虚拟机工作目录是 /Users/pollyduan/vm

虚拟机工作目录为/Users/pollyduan/vm/ubuntu

我创建了一个/Users/pollyduan/vm/data 作为保存共享所需的软件和资源。

provision中的source可以使用相对路径,因此我的用户目录/Users/pollyduan 可以省略。如:

"../data/mirrors/tsinghua/CentOS7/CentOS-Base.repo"
"../data/mirrors/tsinghua/ubuntu16.04/sources.list"

centos7:

将如下配置添加到Vagrantfile的”config.vm.synced_folder” 下面即可。

config.vm.provision "file", source: "../data/mirrors/tsinghua/CentOS7/CentOS-Base.repo", destination: "~/CentOS-Base.repo"

config.vm.provision "shell" do |s|
  s.inline = "sudo cp ~vagrant/CentOS-Base.repo /etc/yum.repos.d/CentOS-Base.repo"
end
config.vm.provision "shell" do |s|
  s.inline = "sudo yum makecache"
end

ubuntu:

同样的,ubuntu中,将如下配置添加到Vagrantfile的”config.vm.synced_folder” 下面即可。

config.vm.provision "file", source: "../data/mirrors/tsinghua/ubuntu16.04/sources.list", destination: "~/sources.list"

config.vm.provision "shell" do |s|
  s.inline = "sudo cp ~vagrant/sources.list /etc/apt/sources.list"
end
config.vm.provision "shell" do |s|
  s.inline = "sudo apt-get update"
end

这样,虚拟机一旦创建,就会自动把包管理器的源替换掉。

当然,如果你修改了源配置文件,也可以使用如下命令更新:

vagrant provision [实例名]

思考一下

为什么不直接使用file命令复制到目标目录?

为什么要在vm目录中创建一个data目录作为共享目录?

~vagrant 是什么东西?

不明白的,请参阅之前的文字。

目录
相关文章
|
11月前
|
Cloud Native 虚拟化 云计算
《Docker基础知识解析:容器与虚拟化的区别与优势,选择最佳方案优化云计算应用》
《Docker基础知识解析:容器与虚拟化的区别与优势,选择最佳方案优化云计算应用》
403 0
|
1月前
|
存储 Linux 应用服务中间件
Docker——底层实现原理及关键技术
Docker——底层实现原理及关键技术
73 0
|
2月前
|
弹性计算 Kubernetes Linux
主流容器工具对比以及重点推荐学习的企业级工具
主流容器工具对比以及重点推荐学习的企业级工具
|
4月前
|
存储 测试技术 开发者
Docker的基本概念和优势,以及实际应用场景
Docker的基本概念和优势,以及实际应用场景
|
弹性计算 专有云 应用服务中间件
nginx在云平台服务几个典型代理场景中的应用案例
在云平台服务中有多种场景需要使用到反向代理,常见的应用场景包括:内网专有云平台访问公网资源、公有云平台访问客户内网IDC机房资源、云产品通过代理访问多个不同的资源等等。笔者总结几种场景配置nginx的7层反向代理、4层反向代理,巧妙实现应用需求。
nginx在云平台服务几个典型代理场景中的应用案例
|
SQL 运维 Kubernetes
环境管理的应用场景 | 学习笔记
快速学习环境管理的应用场景
环境管理的应用场景 | 学习笔记
|
存储 运维 Kubernetes
docker 原理及在运维工作的地位和作用 | 学习笔记
快速学习docker 原理及在运维工作的地位和作用
183 0
docker 原理及在运维工作的地位和作用 | 学习笔记
|
数据采集 算法 应用服务中间件
彻底透彻Docker常用网络模式及应用场景
彻底透彻Docker常用网络模式及应用场景
496 0
彻底透彻Docker常用网络模式及应用场景
|
存储 Cloud Native 应用服务中间件
【云原生 | Docker篇】网络和存储原理(三)(下)
【云原生 | Docker篇】网络和存储原理(三)(下)
289 0
【云原生 | Docker篇】网络和存储原理(三)(下)