前言
现在不管干什么,都会先想着有没有现成的直接拿来用的,我想着也是一种程序员思维,这不是“拿来主义”,而是站在巨人的肩膀上思考问题的办法。就像Python,Node,Java这些一样,也都有很多现成的功能封装成的现成模块,供我们直接使用,不仅提升了我们的开发效率,也提升了我们的程序质量。同样的,在Ansible中也支持这种“拿来主义”,我们可以已经复用写好的脚本,在Ansible中,Playbook支持两种重用机制:
include语句:重用单个Playbook脚本,使用起来简单、直接;
role语句:重用实现特定功能的Playbook文件夹;role是Ansible最为推荐的重用和分享Playbook的方式。
下面就分别对这两种重用机制进行总结。
本文中涉及的试验环境信息如下:
include语句
语句是最基本的代码重用机制,主要用于重用任务。就好比我们在开发过程中一样,为了便于管理,避免主文件太过于臃肿,会建立多个文件,每个文件实现一个功能,然后再主文件中include对应文件即可。下面通过两个例子来说说语句的用法:
举例一(基本用法,不传参数):
代码内容如下:
代码内容如下:
输出结果如下:
举例二(常用用法,传递参数):
代码内容如下:
这样可以从外面向文件中传入参数;不过向中传递参数的方式有很多种,除了上面的那种,我们还可以这样传:
使用YAML字典传参数:
role语句
虽然语句用起来还不错,但是语句是比语句更强大更灵活;语句类似于编程语言中的,而语句就好比是,这样一比较,孰高孰低就一目了然了。
在Ansible中,我们只需要遵循特定的目录结构,就可以实现一个的定义。所以定义role的关键在于这个目录结构,在这里我先不详细总结role,因为在后面的文章中,我会对role进行专门的总结。
总结
这篇文章两个知识点,通过学会使用复用,让我们在今后的工作中对Ansible的使用会变的更高效,也让我们的工作更有效率,希望这篇文章对你有帮助。
领取专属 10元无门槛券
私享最新 技术干货