一步到位玩透Ansible(原51cto专栏)
这些是我之前写在51cto专栏的Ansible文章,是从0到1玩透性质的,循序渐进且非常系统性,大概39W字,转成pdf有430多页,现在免费分享出来(已请求51cto下架专栏)。
各位读者,请您:由于Ansible使用Jinja2模板,它的模板语法 {{}} 和 {%%} 和我博客系统hexo的模板使用的符号一样,在渲染时会产生冲突,尽管我尽我努力地花了大量时间做了调整,但无法保证已经全部都调整。因此,如果各位阅读时发现一些明显的诡异的错误(比如像这样的空的
行内代码),请一定要回复我修正这些渲染错误。
《一步到位玩透Ansible》大纲:
完整内容列表:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 258 259 260 261 262 263 264 265 266 267 268 269 270 271 272 273 274 275 276 277 278 279 280 281 282 283 284 285 286 287 288 289 290 291 292 293 294 295 296 297 298 299
| 1.学习不迷茫:Ansible要如何学至精通 1.1 三分钟内我要Ansible的所有资料 1.2 如何学习并学好Ansible 2.初入Ansible世界:用法概览和初体验 2.1 测试环境并配置ssh主机互信 2.1.1 安装最新版的Ansible 2.1.2 Ansible参数补全功能 2.1.3 配置主机互信 2.2 Ansible初体验 2.3 Ansible配置文件 3.制定演员表:inventory 3.1 inventory文件路径 3.2 配置inventory 3.2.1 一行一主机的定义方式 3.2.2 inventory中的普通变量 3.2.3 主机分组 3.2.4 主机组变量 3.2.5 组嵌套 3.2.6 多个inventory文件 3.3 动态inventory和临时添加主机 3.4 本文使用的inventory文件 4.嘿,瞧瞧Ansible的灵魂:playbook 4.1 playbook、play和task的关系 4.2 playbook的语法:YAML 4.2.1 对象 4.2.2 数组 4.2.3 字典 4.2.4 复合结构 4.2.5 字符串续行 4.2.6 空值 4.2.7 YAML中的单双引号和转义 4.3 playbook的写法 4.4 playbook模块参数的传递方式 4.5 指定执行play的目标主机 4.6 默认的任务执行策略 5.Ansible力量初显:批量初始化服务器 5.1 批量初始化服务器案例 5.2 Ansible配置SSH密钥认证 5.2.1 方案一:命令行改写为playbook command、shell、raw和script模块 connection和delegate_to指令 5.2.2 方案二:使用authorized_key模块 lookup()或query()读取外部数据 5.3 配置主机名 5.3.1 vars设置变量 5.3.2 when条件判断 5.3.3 loop循环 5.4 互相添加DNS解析记录 5.4.1 lineinfile模块 5.4.2 play_hosts和hostvars变量 5.5 配置yum镜像源并安装软件 5.6 时间同步 5.7 关闭Selinux 5.8 配置防火墙 5.9 远程修改sshd配置文件并重启 5.9.1 notify和handlers 5.10 整合所有任务到单个playbook中 6.更大的舞台(1):组织多个文件以及Role 6.1 使用include还是import? 6.2 组织task 6.2.1 在循环中include文件 6.3 组织handler 6.4 组织变量 6.4.1 vars_files 6.4.2 include_vars 6.4.3 --extra-vars选项 6.5 组织playbook文件 6.6 更为规范的组织方式:Role 6.6.1 Role文件结构一览 6.6.2 定义Role的task 6.6.3 定义Role的handler 6.6.4 定义Role的变量 6.6.5 Role用到的外部文件和模板文件 6.6.6 Role中定义的模块和插件 6.6.7 定义Role的依赖关系 6.6.8 动手写一个Role 6.7 使用Role:roles、include_role和import_role 6.8 查看任务和打标签tags 6.9 Ansible Galaxy和Collection Ansible Collection 6.10 playbook的执行顺序 6.10.1 playbook解析、动态加载和静态加载 7.更大的舞台(2):利用Role部署LNMP案例 7.1 实验环境说明 7.2 创建Role并提供inventory 7.3 配置yum镜像源 7.4 安装并配置Nginx 7.5 整理nginx的众多任务 7.6 安装并配置PHP 7.7 安装并配置MySQL 7.8 任务分离到多个Role中 7.8.1 common Role 7.8.2 Nginx Role 7.8.3 PHP Role 7.8.4 MySQL Role 7.9 为每个Role提供一个playbook 8.回归Ansible并进阶:变量、条件、循环、异常处理及其它 8.1 inventory的进阶 8.1.1 inventory解析 8.1.2 inventory变量文件:host_vars和group_vars 8.1.3 动态inventory 8.1.4 临时添加节点:add_host模块 8.1.5 group_by运行时临时设置主机组 8.1.6 --limit再次限制目标主机 8.2 收集目标节点的信息:Facts 8.2.1 如何收集Facts信息? 8.2.2 如何访问Facts信息? 8.2.3 local Facts 8.2.4 委托Facts 8.2.5 set_fact模块 8.2.6 Facts缓存 8.3 Ansible变量的进阶 8.3.1 访问列表、字典变量的两种方式 8.3.2 --extra-vars选项定义额外变量 8.3.3 inventory变量 8.3.4 Role变量 8.3.5 play变量 8.3.6 task变量 8.3.7 block变量 8.3.8 Facts信息变量 8.3.9 预定义特殊变量 8.3.10 变量作用域 8.4 YAML纯文本裸字符串 8.5 handler的进阶 8.6 when条件判断 8.6.1 同时满足多个条件 8.6.2 按条件导入文件 8.6.3 when和循环 8.7 循环迭代的进阶 8.7.1 with_list 8.7.2 with_items和with_flattened 8.7.3 with_indexed_items 8.7.4 with_dict 8.7.5 with_together 8.7.6 with_sequence 8.7.7 with_subelements 8.7.8 with_nested 8.7.9 with_random_choice 8.7.10 with_fileglob 8.7.11 with_lines 8.7.12 循环和when 8.7.13 循环和register 8.7.14 循环的控制:loop_control 1.label参数 2.pause参数 3.index_var参数 4.loop_var参数 5.extended参数 8.8 异常和错误处理 8.8.1 人为制造失败:fail模块 8.8.2 断言:assert模块 8.8.3 ignore_errors 8.8.4 failed_when 8.8.5 rescue和always 8.8.6 any_errors_fatal 8.8.7 max_fail_percentage 8.8.8 处理连接失败(unreachable)的异常 8.8.9 任务失败导致handler未执行 8.9 其它Ansible流程控制逻辑的进阶 8.9.1 until和retry 8.9.2 pause模块暂停、休眠 8.9.3 wait_for模块和wait_for_connection模块 9.如虎添翼的力量:解锁强大的Jinja2模板 9.1 Jinja2是什么?模板是什么? 9.2 Ansible哪里使用了Jinja2 9.3 Jinja2访问元素的两种方式 9.4 Jinja2条件判断 9.4.1 if语句块 9.4.2 行内if表达式 9.5 for循环 9.5.1 for迭代列表 9.5.2 for迭代字典 9.5.3 for的特殊控制变量 9.6 Macro 9.7 block 9.8 变量赋值和作用域 9.8.1 如何跨作用域 9.9 Jinja2的空白处理 9.10 真实案例:完全自定义的nginx虚拟主机配置 9.11 基本运算符 9.12 Jinja2内置的is测试 9.13 Ansible扩展的测试函数 9.13.1 测试字符串 9.13.2 版本号大小比较 9.13.3 子集、父集测试 9.13.4 成员测试 9.13.5 测试文件 9.13.6 测试任务的执行状态 9.14 Jinja2内置Filter 9.15 Ansible扩展的Filter 9.15.1 类型转换类筛选器 9.15.2 获取当前时间点 9.15.3 YAML、JSON格式化 9.15.4 参数忽略 9.15.5 列表元素连接 9.15.6 列表压平 9.15.7 并集、交集、差集 9.15.8 dict和list转换 9.15.9 zip和zip_longest 9.15.10 子元素subelements 9.15.11 random生成随机数 9.15.12 shuffle打乱顺序 9.15.13 json_query 9.15.14 ip地址筛选 9.15.15 正则表达式筛选器 9.15.16 URL处理筛选器 9.15.17 编写注释的筛选器 9.15.18 extract提取元素 9.15.19 dict合并 9.15.20 hash值计算 9.15.21 base64编解码筛选器 9.15.22 文件名处理 9.15.23 日期时间类处理 9.15.24 human_to_bytes和human_readable 9.15.25 其它筛选器 9.16 Python对象自身的方法 9.16.1 Python字符串对象方法 9.16.2 list对象方法 10.服务0 downtime的追求:Haproxy+Nginx集群服务的滚动发布和节点伸缩 10.1 环境说明 10.2 安装配置HAProxy Role 10.3 安装配置Nginx Role 10.4 滚动发布:Load Balance后端节点升降级 10.5 理解Ansible执行策略 10.5.1 Ansible的默认执行策略 10.5.2 serial将节点分批执行play 10.5.3 strategy指定执行策略 10.5.4 throttle限制最大并发任务数 10.6 Ansible完成滚动发布 10.7 集群后端节点的伸缩 10.8 处理Ansible部署、维护过程中的异常 11.Ansible你快点:Ansible执行过程分析、异步、效率优化 11.1 测量任务执行速度:profile_tasks插件 11.2 Ansible执行流程分析 11.3 回顾Ansible的执行策略 11.4 加大forks的值 11.5 修改执行策略 11.6 使Ansible异步执行任务 11.6.1 async和poll指令 11.6.2 等待异步任务 11.6.3 何时使用异步任务 11.7 开启ssh长连接 11.7.1 开启ssh长连接后的注意事项 11.8 开启Pipelining 11.8.1 开启Pipelining后的注意事项 11.8.2 开启Pipelining后的执行流程 11.8.3 开启和不开启Pipelining的效率比较 11.9 修改facts收集行为 11.10 Shell层次上的优化:将任务分开执行 11.11 第三方策略插件:Mitogen for Ansible 12.让Ansible更安全:使用Vault进行加密 12.1 一个入门示例:创建一个加密文件 12.2 Vault ID和凭据密码提供方式 12.3 加密已存在的文件 12.4 加密协议头的含义 12.5 解密已加密的文件 12.6 修改Vault ID和凭据密码 12.7 编辑已加密文件的内容 12.8 ansible-playbook任务中使用Vault加密文件 12.9 加密字符串并嵌入YAML文件 12.10 加速加解密的过程 12.11 Vault加密最佳实践 13.蚂蚁多了也咬不死Ansible:Ansible Tower 13.1 使用Ansible之痛 13.2 Ansible Tower简介 13.3 安装Tower 13.3.1 安装环境配置 13.3.2 安装Tower 13.3.3 登录tower 13.4 让Ansible Tower执行playbook 13.4.1 配置Tower Credential 13.4.2 配置inventory 13.4.3 创建Project 13.4.4 创建Template并运行任务 13.5 Tower的用户和权限控制 14.Ansible管理docker和openstack 14.1 Ansible管理docker 14.1.1 Ansible构建并运行Docker镜像 14.1.2 无Dockerfile启动镜像并连接容器 14.1.3 docker inventory 14.1.4 其它Ansible容器管理工具 14.2 Ansible管理OpenStack 14.2.1 创建虚拟机 14.2.2 将新虚拟机动态添加到inventory 14.2.3 收集OpenStack虚拟机的动态inventory 15.意外之喜:Ansible管理Windows主机 15.1 Ansible如何管理Windows 15.2 Ansible管理Windows前的设置 15.3 测试能否成功管理Windows 15.4 Ansible执行PowerShell、CMD命令 15.5 创建域控制器 15.6 将主机加入域 16.成就感源于创造:自己动手写Ansible模块 16.1 自定义模块简介 16.1.1 自定义模块前须知:模块的存放路径 16.1.2 自定义模块前须知:模块的要求 16.2 Shell脚本自定义模块(一):Hello World 16.3 Shell脚本自定义模块(二):简版file模块 16.4 Python自定义模块
|