制作支持OS::Heat::SoftwareConfig以及ansible组件的自定义centos7镜像

本文主要是介绍制作支持OS::Heat::SoftwareConfig以及ansible组件的自定义centos7镜像,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

更多资料请参考官方档:http://docs.openstack.org/developer/heat/template_guide/software_deployment.html#custom-image-script

Heat 和配置管理工具集成

随着 DevOps 的流行,大量配置管理的工具应运而生,比如 Chef、Puppet 和 Ansible,利用这些工具,用户可以轻松通过简单的配置来部署复杂的中间件或者软件应用。Heat 在基于 OS::Heat::SoftwareConfig 和 OS::Heat::SoftwareDeployment 的协同使用上,提供了对这些配置管理工具的支持。首先,对于 OS::Heat::SoftwareConfig 而言,需要其 group 定义为对应的类型。比如有 ansible、puppet、chef 和 salt 等。

1. 先将官方提供的需要的组件和包下载到本地

yum install -y git qemu-img
git clone https://git.openstack.org/openstack/diskimage-builder.git
git clone https://git.openstack.org/openstack/tripleo-image-elements.git
git clone https://git.openstack.org/openstack/heat-templates.git


我们先来看看这些文件下面有什么东西,都分别起什么作用。

先进到diskimage-builder/elements下面能看到我们常见的熟悉的一些系统文件如centos、fedora、ubuntu、debian等。我们在后面将选择centos7


进入到heat-templates/hot/software-config/elements下面能看到heat所支持的DevOps工具的组件,例如heat-config-ansible、heat-config-script等。后面制作镜像时我们会选择工具ansible,当然还有一些其他的基本部署组件如heat-config-script和heat-config。


进入到heat-templates/hot/software-config/elements下面能看到我们所需要的一些agents,例如os-apply-config,os-cloud-config,os-collect-config等。在虚拟机中的Agents会定时与Heat通信,发送脚本执行结果,方便Heat进行流程控制。要使用heat的安装配置软件和应用的框架,需要先创建出一个包含了os-*-config agents的镜像,我们这里选择使用diskimage-builder。


2. 制作镜像

然后回到这三个文件的父目录下,即/root/createimg下,先将上面三个文件下的elements放到环境变量ELEMENTS_PATH下

export ELEMENTS_PATH=tripleo-image-elements/elements:heat-templates/hot/software-config/elements:diskimage-builder/elements

然后使用diskimg-create命令:

diskimage-builder/bin/disk-image-create vm centos7 os-collect-config os-refresh-config os-apply-config heat-config heat-config-script heat-config-ansible -o centos7-software-config.qcow2


大概需要等待一段时间,稍微有点漫长。镜像创建好后如下:


然后使用glance命令上传该镜像:

glance image-create --name centos7-software-config --disk-format qcow2 --container-format bare --file centos7-software-config.qcow2 --visibility public


这就是我们制作好的镜像啦:


在下一章节我们将演示如何使用这个镜像,利用openstack heat组件来创建虚拟机,并利用OS::Heat::SoftwareConfig以及ansible为虚拟机做一些简单的配置。下一章节:使用Heat的OS::Heat::SoftwareConfig以及ansible组件对虚拟机进行安装配置






这篇关于制作支持OS::Heat::SoftwareConfig以及ansible组件的自定义centos7镜像的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/983272

相关文章

Python使用国内镜像加速pip安装的方法讲解

《Python使用国内镜像加速pip安装的方法讲解》在Python开发中,pip是一个非常重要的工具,用于安装和管理Python的第三方库,然而,在国内使用pip安装依赖时,往往会因为网络问题而导致速... 目录一、pip 工具简介1. 什么是 pip?2. 什么是 -i 参数?二、国内镜像源的选择三、如何

定价129元!支持双频 Wi-Fi 5的华为AX1路由器发布

《定价129元!支持双频Wi-Fi5的华为AX1路由器发布》华为上周推出了其最新的入门级Wi-Fi5路由器——华为路由AX1,建议零售价129元,这款路由器配置如何?详细请看下文介... 华为 Wi-Fi 5 路由 AX1 已正式开售,新品支持双频 1200 兆、配有四个千兆网口、提供可视化智能诊断功能,建

docker如何删除悬空镜像

《docker如何删除悬空镜像》文章介绍了如何使用Docker命令删除悬空镜像,以提高服务器空间利用率,通过使用dockerimage命令结合filter和awk工具,可以过滤出没有Tag的镜像,并将... 目录docChina编程ker删除悬空镜像前言悬空镜像docker官方提供的方式自定义方式总结docker

CSS自定义浏览器滚动条样式完整代码

《CSS自定义浏览器滚动条样式完整代码》:本文主要介绍了如何使用CSS自定义浏览器滚动条的样式,包括隐藏滚动条的角落、设置滚动条的基本样式、轨道样式和滑块样式,并提供了完整的CSS代码示例,通过这些技巧,你可以为你的网站添加个性化的滚动条样式,从而提升用户体验,详细内容请阅读本文,希望能对你有所帮助...

四种Flutter子页面向父组件传递数据的方法介绍

《四种Flutter子页面向父组件传递数据的方法介绍》在Flutter中,如果父组件需要调用子组件的方法,可以通过常用的四种方式实现,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录方法 1:使用 GlobalKey 和 State 调用子组件方法方法 2:通过回调函数(Callb

Vue项目中Element UI组件未注册的问题原因及解决方法

《Vue项目中ElementUI组件未注册的问题原因及解决方法》在Vue项目中使用ElementUI组件库时,开发者可能会遇到一些常见问题,例如组件未正确注册导致的警告或错误,本文将详细探讨这些问题... 目录引言一、问题背景1.1 错误信息分析1.2 问题原因二、解决方法2.1 全局引入 Element

龙蜥操作系统Anolis OS-23.x安装配置图解教程(保姆级)

《龙蜥操作系统AnolisOS-23.x安装配置图解教程(保姆级)》:本文主要介绍了安装和配置AnolisOS23.2系统,包括分区、软件选择、设置root密码、网络配置、主机名设置和禁用SELinux的步骤,详细内容请阅读本文,希望能对你有所帮助... ‌AnolisOS‌是由阿里云推出的开源操作系统,旨

python中os.stat().st_size、os.path.getsize()获取文件大小

《python中os.stat().st_size、os.path.getsize()获取文件大小》本文介绍了使用os.stat()和os.path.getsize()函数获取文件大小,文中通过示例代... 目录一、os.stat().st_size二、os.path.getsize()三、函数封装一、os

vue解决子组件样式覆盖问题scoped deep

《vue解决子组件样式覆盖问题scopeddeep》文章主要介绍了在Vue项目中处理全局样式和局部样式的方法,包括使用scoped属性和深度选择器(/deep/)来覆盖子组件的样式,作者建议所有组件... 目录前言scoped分析deep分析使用总结所有组件必须加scoped父组件覆盖子组件使用deep前言

基于Qt Qml实现时间轴组件

《基于QtQml实现时间轴组件》时间轴组件是现代用户界面中常见的元素,用于按时间顺序展示事件,本文主要为大家详细介绍了如何使用Qml实现一个简单的时间轴组件,需要的可以参考下... 目录写在前面效果图组件概述实现细节1. 组件结构2. 属性定义3. 数据模型4. 事件项的添加和排序5. 事件项的渲染如何使用