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 是什么东西?

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

目录
相关文章
|
Cloud Native 虚拟化 云计算
《Docker基础知识解析:容器与虚拟化的区别与优势,选择最佳方案优化云计算应用》
《Docker基础知识解析:容器与虚拟化的区别与优势,选择最佳方案优化云计算应用》
448 0
|
中间件 Unix 应用服务中间件
|
5月前
|
弹性计算 Kubernetes Linux
主流容器工具对比以及重点推荐学习的企业级工具
主流容器工具对比以及重点推荐学习的企业级工具
|
7月前
|
存储 测试技术 开发者
Docker的基本概念和优势,以及实际应用场景
Docker的基本概念和优势,以及实际应用场景
|
SQL 运维 Kubernetes
环境管理的应用场景 | 学习笔记
快速学习环境管理的应用场景
环境管理的应用场景 | 学习笔记
|
NoSQL 大数据 Redis
|
数据采集 算法 应用服务中间件
彻底透彻Docker常用网络模式及应用场景
彻底透彻Docker常用网络模式及应用场景
526 0
彻底透彻Docker常用网络模式及应用场景
|
分布式计算 Hadoop Java
Hadoop集群搭建记录 | 云计算[CentOS7] | 伪分布式集群 Hadoop安装配置
写在前面 step1. Hadoop下载 step2. Hadoop解压安装 step3. 配置环境变量 step4. 查看时候配置成功 step5. 其他节点的配置 step6. 修改六个配置文件 6.1 hadoop-env.sh修改 | master节点 6.2 core-site.xml修改 | master节点 6.3 hdfs-site.xml修改 | master节点 6.4 yarn-site.xml修改 | master节点 6.5 mapred-site.xml修改 | master节点 6.6 workers 修改 | master节点
236 0
Hadoop集群搭建记录 | 云计算[CentOS7] | 伪分布式集群 Hadoop安装配置
|
分布式计算 Hadoop Java
Hadoop集群搭建记录 | 云计算[CentOS7] | 伪分布式集群 Master运行WordCount
写在前面 step1 eclipse访问hadoop step2 重启并配置eclipse step3 新建Map/Reduce项目 step4 复制粘贴代码 step5 配置运行参数 整个hadoop就到此结束啦
182 0
Hadoop集群搭建记录 | 云计算[CentOS7] | 伪分布式集群 Master运行WordCount