Ansible权威指南-读书笔记
2 Ansible基础元素介绍
2.1 ansible 目录结构介绍
2.2 ansible 配置文件解析
配置文件解析顺序:当前命令执行目录-->
用户家目录下的.ansible.cfg-->
/etc/ansible.cfg
2.3 ansible 命令用法详解
2.4 ansible系列命令用法详解
- ansible
- ansible-galaxy
- ansile-galaxy的功能可以裂解为Github或Pip的功能,通过该命令,可以根据下载量和关注量查找和安装优秀的roles
- ansible-doc
- ansible-pull
- ansible-playbook
- ansible-vault
- ansible-console
2.5 ansible Inventory配置详解
2.5.1 定义主机和组
2.5.2 定义主机变量
2.5.3 定义组变量
2.5.4 定义组嵌套及组变量
2.5.5 多重变量定义
2.5.6 其他Inventory参数列表
3 ansible Ad-Hoc命令集
3.1 ad-hoc试用场景
3.2 ad-hoc命令集介绍
3.2.1 ad-hoc命令集用法简介
3.2.2 通过ad-hoc查看系统设置
3.2.3 通过ad-hoc研究ansible并发特性
3.2.4 通过ad-hoc研究ansible模块使用
3.3 ad-hoc组管理和特定主机变更
3.3.1 ad-hoc组定义
3.3.2 ad-hoc配置管理:配置Proxy与web servers实践
3.3.3 ad-hoc配置后端:配置NOSQL与DataBase实践
3.3.4 ad-hoc特定主机变更
3.4 ad-hoc用户管理
3.4.1 window用户管理
3.4.2 linux用户管理
3.4.3 应用层用户管理
4 playbook快速入门
4.1 playbook语法简介
4.1.1 多行缩进
4.1.2 单行缩进
4.2 playbook案例分析
4.3 playbook与shell脚本差异对比
4.4 ansible-playbook实战小技巧
4.4.1 限定执行范围
4.4.2 用户与权限设置
4.4.3 ansible-playbook:其他选项技巧
5 ansible playbook扩展
5.1 Handlers
5.2 环境变量
5.3 变量
5.3.1 playbook变量
5.3.2 在Inventory文件中定义变量
5.3.3 注册变量
5.3.4 试用高阶变量
5.3.5 主机变量与组变量
5.3.6 Facts(收集系统信息)
5.3.6.1 facts信息
playbook文件中如果定义了gather_facts: no
运行该脚本时,就不会在执行的远程主机上收集系统性信息
---
- hosts: node
gather_facts: no
5.3.6.1 本地fact变量
[root@server ~]# ansible node -m setup -a "filter=ansible_local"
172.17.0.32 | SUCCESS => {
"ansible_facts": {},
"changed": false
}
172.17.0.31 | SUCCESS => {
"ansible_facts": {
"ansible_local": {
"setting": {
"user": {
"admin": "jane,jou",
"normal": "zhansgan"
}
}
}
},
"changed": false
}
172.17.0.33 | SUCCESS => {
"ansible_facts": {},
"changed": false
}
[root@server ~]# ansible 172.17.0.31 -m command -a "cat /etc/ansible/facts.d/setting.fact"
172.17.0.31 | SUCCESS | rc=0 >>
[user]
admin=jane,jou
normal=zhansgan
5.3.7 ansible加密模块Vault
一些常用的选项
- edit
- rekey:重新修改已被加密文件密码
- create: 创建一个新的文件,并直接对其进行加密
- view:查看经过加密的文件
- decrypt: 解密文件
ansible-vault encrypt sample.yml
ansible-playbook test.yml --vault-password-file /PATH/TO/PASSWD.txt
注意 :python的cryptography
模块会加速vault的速度
5.3.8 变量优先级(由高到低)
- 在命令刚中定义的变量(即使用-e定义的变量)
- 在Inventory中定义的连接变量(例如:ansible_ssh_user)
- 大多数的其他变量(命令行转换,play中的变量,included变量,role中的变量等)
- 在Inventory定义的其他变量
- 由系统通过gather_facts方法发现的变量
- role默认变量,这是一个默认值,很容易丧失优先权
5.4 if/then/when---流程控制
5.4.1 Jinja2正则表达,python内置函数和逻辑判断
可以借助python的一些内置方法,大大增强了ansible的功能
5.4.1.1 jinja2数据类型
- 字符串型
string
- 整数型
45
- 浮点数型
42.33
- 列表
[1,2,3]
- 元组
(1,2,3)
- 字典
{key:value}
- 布尔型
true
和false
5.4.1.2 jinja2支持的数据运算
- 基本数据运算
加减乘除,比较运算==,!=,>=
- 逻辑运算
and,or,not
defined,undefined,equalto,even,iterable
5.4.2 变量注册器register
注册变量的四种类型
- changed 任务是否对远程主机造成的变更
- delta 任务运行所用的时间
- stdout 正常的输出时间
- stderr 错误信息
使用的方式
- shell: my_command_here
register: my_command_result
调用结果的方式:my_command_result.stdout
5.4.3 when条件判断
5.4.4 changed_when,failed_when条件判断
5.4.5 ignore_errors条件判断
5.5 任务键流程控制
5.5.1 任务委托
---
- hosts: node
gather_facts: no
tasks:
- name: "install git"
delegate_to: 172.17.0.3
yum: name=git state=present
#表示在指定的主机上运行该任务
5.5.2 任务暂停
5.6 交互式提示
---
- hosts: node
vars_prompt:
- name: share_user
prompt: "what is your network username"
- name: share_pass
prompt: "what is your network password"
private: yes
default: admin
confirm: yes
5.7 Tags标签
5.8 Block块
Ansible权威指南-读书笔记的更多相关文章
- 《Ansible权威指南》笔记(1)——安装,ssh密钥登陆,命令
2016-12-23 读这本<Ansible权威指南>学习ansible,根据本书内容和网上的各种文档,以及经过自己测试,写出以下笔记.另,这本书内容很好,但印刷错误比较多,作者说第二版会 ...
- 《Ansible权威指南》笔记(3)——Ad-Hoc命令集,常用模块
五.Ad-Hoc命令集1.Ad-Hoc命令集通过/usr/bin/ansible命令实现:ansible <host-pattern> [options] -v,--verbose ...
- HTTP权威指南读书笔记
HTTP权威指南笔记 读书有两种境界,第一种境界是将书读薄,另一种是读厚.本篇文章就是HTTP权威指南的读书笔记,算是读书的第一重境界,将厚书读薄.文章对HTTP的一些关键概念做了比较详细的概述,通读 ...
- css权威指南读书笔记
今天翻手机,翻到了许久之前看css权威指南时的笔记,遂移到博客中来. 1.属性选择器p.one class名为one的p元素p[class][name] 含有class和name属性的p元素p[cla ...
- 经典的性能优化最佳实践 web性能权威指南 读书笔记
web性能权威指南 page 203 经典的性能优化最佳实践 无论什么网络,也不管所用网络协议是什么版本,所有应用都应该致力于消除或减 少不必要的网络延迟,将需要传输的数据压缩至最少.这两条标准是经典 ...
- css权威指南读书笔记-第10章浮动和定位
这一章看了之后真是豁然开朗,之前虽然写了圣杯布局和双飞翼布局,有些地方也是模糊的,现在打算总结之后再写一遍. 以下都是从<css权威指南>中摘抄的我认为很有用的说明. 浮动元素 一个元素浮 ...
- 《Ansible权威指南》笔记(2)——Inventory配置
四.Inventory配置ansible通过Inventory来定义主机和组,使用时通过-i指定读取,默认/etc/ansible/hosts.可以存在多个Inventory,支持动态生成.1.定义主 ...
- 《Ansible权威指南》笔记(4)——Playbook
七.Playbook1.语法特性如下:(1)"---"首行顶格开始(2)#号注释(3)缩进统一,不同的缩进代表不同的级别,缩进要对齐,空格和tab不能混用(4)区别大小写,键值对k ...
- Hadoop权威指南读书笔记
本书中提到的Hadoop项目简述 Common:一组分布式文件系统和通用I/O的组件与接口(序列化.javaRPC和持久化数据结构). Avro:一种支持高效.跨语言的RPC以及永久存储数据的序列化系 ...
随机推荐
- Google Play来华 象征意义 跳板而已
Play来华 象征意义 跳板而已" title="Google Play来华 象征意义 跳板而已"> 每当有大事发生,伴随的就是接连不断的小道消息传出来.就像苹 ...
- The entity "nbsp" was referenced, but not declared
翻译 实体""被引用,但没有声明 问题 使用xhtmlrenderer将网页转成PDF时报The entity "nbsp" was referenced, b ...
- TesterHome创始人思寒:如何从手工测试进阶自动化测试?十余年经验分享
做测试十多年,有不少人问过我下面问题: 现在的手工测试真的不行了吗? 测试工程师,三年多快四年的经验,入门自动化测试需要多久? 自学自动化测试到底需要学哪些东西? 不得不说,随着行业的竞争加剧,互 ...
- Python 异常处理中的 esle
前言 我们知道,在Python中,我们是用try- -excetp- - 来做异常处理的,但Python 有别于其他语法的是在异常处理中还提供了else的处理场景,是的,你没看错,就是在条件判断if- ...
- 【5min+】保持程序健康的秘诀!AspNetCore的HealthCheck
系列介绍 [五分钟的dotnet]是一个利用您的碎片化时间来学习和丰富.net知识的博文系列.它所包含了.net体系中可能会涉及到的方方面面,比如C#的小细节,AspnetCore,微服务中的.net ...
- [转帖]RSYNC 的核心算法
RSYNC 的核心算法 https://coolshell.cn/articles/7425.html rsync是unix/linux下同步文件的一个高效算法,它能同步更新两处计算机的文件与目录,并 ...
- VGG16等keras预训练权重文件的下载及本地存放
VGG16等keras预训练权重文件的下载: https://github.com/fchollet/deep-learning-models/releases/ .h5文件本地存放目录: Linux ...
- Java——JDBC
今天给大家更新一篇我自己学习Java——JDBC的经验 Java中JDBC是(Java DataBase Connectivity)的简称,由java语言编写的类和接口组成,可为多种关系型数据库提供了 ...
- spring boot Shiro JWT整合
一个api要支持H5, PC和APP三个前端,如果使用session的话对app不是很友好,而且session有跨域攻击的问题,所以选择了JWT 1.导入依赖包 <dependency> ...
- 面试总被问分布式ID怎么办? 滴滴(Tinyid)甩给他
整理了一些Java方面的架构.面试资料(微服务.集群.分布式.中间件等),有需要的小伙伴可以关注公众号[程序员内点事],无套路自行领取 一口气说出 9种 分布式ID生成方式,面试官有点懵了 面试总被问 ...