自动化运维之playbook

****前言****
前段时间总结了ansible的基本配置与使用,那么说到了ansible的话呢,playbook是必不可少的,playbook在我看来就是一个花花公子-playboy!


****playbook的介绍****
Playbooks are a completely different way to use ansible than in adhoc task execution mode, and are particularly powerful.
顾名思义,playbooks是一个"剧本",不同于ansible的使用方式,它是按照编排的任务智能地执行,并且非常强大!
Simply put, playbooks are the basis for a really simple configuration management and multi-machine deployment system, unlike any that already exist, and one that is very well suited to deploying complex applications.
简单地来说呢,playbooks适合简单的配置管理以及多服务器机器的管理,同时还可以处理部署复杂的应用。
要是服务器不仅仅复杂,数量上还是成千上万的呢,还是推荐使用重量级又古老文明的saltstack。
传送ansible文档详解
自动化运维之ansible


****playbook基础语法****
playbook使用了YAML格式的语法,该语法还是相当简单的,可以体验出程序构造或执行的过程。那么还是具体查看简单的一个实例!
在docker服务器组使用root用户执行更新源命令,如下:

- hosts: docker
  remote_user: root
  gather_facts: True
  tasks:
   - name: "初始化更新源列表"
     command: apt-get update

语法注意:"-"以及":"后面都需要一个空格。
语法已经主意了吧~~~该注意该注意的内容了,从上面的实例额可以看出有两个必须的属性,那就是服务器主机hosts以及远程用户remote_user,有了它们就可以干点其它事了tasks,自然而然在playbook执行任务是需要通过模块的来操控的。
使用命令检查yaml的语法

ansible-playbook main.yml --syntax-check
Alic_yml_check

****playbook模块化task****
(⊙v⊙)嗯~~~模块化的理论就不一一说明了,实践通过时间来领悟理论精华。该是动手的时候了!

  • command
# 在docker服务器组执行一条命令
- hosts: docker
  remote_user: root
  gather_facts: True
  tasks:
   - name: "初始化更新源列表"
     command: apt-get update

说明:name的属性就是一个任务的昵称,自定义。

  • shell
# 在docker服务器组执行shell命令
- hosts: docker
  remote_user: root
  gather_facts: True
  tasks:
   - name: "删除/home/alic/demo.sh"
     shell: rm -f /home/alic/demo.sh
  • script
# 在docker服务器组执行控制节点本地的shell脚本
- hosts: docker
  remote_user: root
  gather_facts: True
  tasks:
   - name: "被控节点执行控制节点的shell脚本"
     script: ../scripts/alic.sh
Alic_demo_dir_tree
  • copy
# 将控制节点的文件上传到docker服务器【被控节点】上
- hosts: docker
  remote_user: root
  gather_facts: True
  tasks:
   - name: "控节点文件cp到被控制节点服务器"
     copy:
       src=/etc/ansible/hosts 
       dest=/etc/ansible/hosts 
       owner=root 
       group=root 
       mode=0644

注意:src代表控制节点路径,dest代表被控节点路径,其它的为可选项目,顾名思义。

  • yum
# 在docker用户组以root用户安装vim编辑器
- hosts: docker
  remote_user: root
  gather_facts: True
  tasks:
   - name: "我正在在centOS安装vim呢~~~"
     yum: name=vim state=latest

说明:name为安装某某的名称,state则为安装的版本,yum该模块仅仅适合contOS相似的发行版,对于ubuntu呢,还是推荐使用原生的bash咯~~~

  • service
# 在docker用户组以root用户重启apache2
- hosts: docker
  remote_user: root
  gather_facts: True
  tasks:
   - name: "我正在启动apache2服务器~~~"
     service: name=apache2 state=restarted

说明:service的状态与我们平常使用的多了-ed stsrted stoped restarted

  • notify 与 handlers
    使用一句英文更好地阐述两者的关系
    The things listed in the notify
    section of a task are called handlers.
    还是说一下中文吧~~~
    notify是一个通知,实质上也是一个任务,不同的是使用handlers定义的任务,handlers里面定义的任务相当于定义方法,提高复用性!
- hosts: docker
  remote_user: root
  tasks:
    - name: "test notify"
      shell: ls
      notify: 
        - restart apache2
  handlers:
    - name: restart apache2
      service: name=apache2 state=restarted
  • vars
    先说明一下,很明显vars模块用户声明变量
# vars 变量的定义与使用
- hosts: docker
  remote_user: root
  vars: 
     config_path: "/root/application/sise.conf"
  tasks:
    - name: "test notify"
      command: touch {{config_path}}

然而说到变量还可以这样使用:在yml使用变量,在执行playbook命令是额外赋值,注意记得加上引号 "{{var}}"
ansible-playbook main.yml --extra-vars hosts=docker

 hosts: "{{hosts}}"
  remote_user: root
  vars: 
  - dir_name: "public"
  tasks: 
  - name: create dir
    shell: mkdir {{dir_name}}
Alic_--extra-vars
  • when
    (⊙o⊙)嗯~~~,when在运维时是一个重点,不同Linux的发行版呢,有些命令就不一样,但都是了解到了条件即可switch地处理。好比如yum只有centOS,RedHat等发行版才具有的包管理命令工具
    重点:when主要用于处理不同的操作系统与处理逻辑上。
- hosts: docker
  remote_user: root
  tasks:
   - name: "我正在红帽子安装vim呢~~~"
     yum: name=vim state=latest
     when: ansible_os_family == "RedHat"
  • with_items
# 便利迭代 + when
- hosts: docker
  remote_user: root
  tasks:
    - command: echo {{ item }}
      with_items: [ 0, 2, 4, 6, 8, 10 ]
      when: item > 5
便利迭代 + when

****Tips and Tricks For Ansible-book Command****
1 查看任务所指定的host列表

$ ansible-playbook main.yml --list-hosts
Alic-查看任务所指定的host列表

2 If you need to specify a password to sudo, run ansible-playbook
with --ask-pass
or when using the old sudo syntax --ask-sudo-pass
即当你使用普通用户执行命令需要输入密码时可使用

$ ansible-playbook main.ym --ask-sudo-pass --ask-pass
Alic_密码交互

3 获取docker server-group主机的所有基本信息
既然可以获取主机信息 当时用when的时候,该命令就其很大作用了!

$ ansible docker -m setup
Alic_还有很多message没有截取

4 直接通过ansible-playbook命令来指定主机

$ ansible-playbook playbook.yml --limit docker

嘿嘿~~~这个野蛮好的( ⊙o⊙ )哇,有时候我想在某台服务器搭建nginx的话,task只写好模板,需要的服务器就在执行命令指定host或服务器组即可!

****Demo实践目录树****

Demo实践目录树

自动化运维之ansible


****价值源于技术,贡献源于分享****

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 194,390评论 5 459
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 81,821评论 2 371
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 141,632评论 0 319
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 52,170评论 1 263
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 61,033评论 4 355
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 46,098评论 1 272
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 36,511评论 3 381
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 35,204评论 0 253
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 39,479评论 1 290
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 34,572评论 2 309
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 36,341评论 1 326
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 32,213评论 3 312
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 37,576评论 3 298
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 28,893评论 0 17
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,171评论 1 250
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 41,486评论 2 341
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 40,676评论 2 335

推荐阅读更多精彩内容