自动化运维ansible、playbook

 

任务列表:
24.15 ansible介绍
24.16 ansible安装
24.17 ansible远程执行命令
24.18 ansible拷贝文件或目录
24.19 ansible远程执行脚本
24.20 ansible管理任务计划
24.21 ansible安装包和管理服务
24.22 使用ansible playbook
24.23 playbook里的变量
24.24 playbook里的循环
24.25 playbook里的条件判断
24.26 playbook中的handlers
24.27/24.28 playbook安装nginx
24.29/24.30  playbook管理配置文件

https://www.cnblogs.com/amosli/p/6122908.html


以下是几个示例,帮助你巩固playbook的用法
示例: https://blog.51cto.com/215687833/1888534
示例:https://www.cnblogs.com/xuyingzhong/p/8466976.html
示例:http://www.yfshare.vip/2017/03/16/Ansible-Playbooks%E4%B9%8B%E5%AE%89%E8%A3%85Mysql/

 

一、Ansible介绍

不需要安装客户端,通过sshd去通信,通过秘钥认证
基于模块工作,模块可以由任何语言开发
不仅支持命令行使用模块,也支持编写yaml格式的playbook,易于编写和阅读
安装十分简单,centos上可直接yum安装
有提供UI(浏览器图形化)www.ansible.com/tower,收费的
官方文档 http://docs.ansible.com/ansible/latest/index.html
ansible已经被redhat公司收购,它在github上是一个非常受欢迎的开源软件,github地址https://github.com/ansible/ansible
一本不错的入门电子书 https://ansible-book.gitbooks.io/ansible-first-book/

Ansible文档的使用
ansible-doc -l   列出所有的模块
ansible-doc cron  查看指定模块的文档

二、Ansible安装

准备两台机器,前面我们做实验的两台机器001,002
001上安装ansible

yum list |grep ansible 可以看到自带源里就有2.8版本的ansible

153b3a0998b5914a9a0eb502aa13e04db76.jpg

yum install -y ansible ansible-doc

001上生成密钥对:

ssh-keygen -t rsa  -t rsa生成rsa类型
如果 ls /root/.ssh/目录下存在id_rsa和id_rsa.pub就不用生成了

把公钥复制到002上vim .ssh/authorized_keys 此文件中,设置密钥认证

5b6eeee548e62983cd069fe8c79bff8f407.jpg

127.0.0.1也要做认证,把公钥复制到001上vim .ssh/authorized_keys 此文件中

eb6d46b6569b0b726d28e502ad1b2f0cad9.jpg
vim /etc/ansible/hosts //配置主机组,增加内容如下

[testhost]
127.0.0.1
192.168.183.33  #002的地址

说明: testhost为主机组名字,自定义的。 下面两个ip为组内的机器ip。

d19e29046219828b282cc6d2dc01c88741e.jpg

三、Ansible远程执行命令

ansible testhost -m command -a 'w'

这样就可以批量执行命令了。这里的testhost 为主机组名,在这里/etc/ansible/hosts定义的,-m后边是模块名字,-a后面是命令。当然我们也可以直接写一个ip,针对某一台机器来执行命令。

834ae0e48b9ddeea6164fb09a3059781e7a.jpg

指定一台机器:

ansible 127.0.0.1 -m  command -a 'hostname'      指定一台机器

5d929ab863af79fdbb0670a68dc7702e407.jpg

如果报错:

错误: "msg": "Aborting, target uses selinux but python bindings (libselinux-python) aren't installed!"
解决: yum install -y libselinux-python   安装此模块

还有一个模块就是shell同样也可以实现 ,远程执行shell脚本使用

ansible testhost -m shell -a 'w'

ansible 192.168.183.33 -m shell -a 'w'

b441de54ac978cd9a76bbc4010d7ee4f91d.jpg

添加目标节点的SSH认证信息

ssh-copy-id root@目标节点IP

这里root是在目标节点上登录的用户,@符号后面接目标节点IP即可,之后会提示输入目标节点root用户密码,输入即可。
添加认证信息后,目标节点主机的~/.ssh/目录下将会出现一个authorized_keys文件,里面包含了ansible管理节点的公钥信息,可以检查一下是否存在。

四、Ansible拷贝文件或者目录

针对目录操作:

ansible 192.168.183.33 -m copy -a "src=/etc/ansible  dest=/tmp/ansibletest owner=root group=root mode=0755"
owner属主,group属组,mode权限

84741f8f5f54584af6e40de3e49b9eb731a.jpg

c4f9367beff56d509abfcab12d4f9f9c037.jpg
注意:源目录会放到目标目录下面去,如果目标指定的目录不存在,它会自动创建。如果拷贝的是文件,dest指定的名字和源如果不同,并且它不是已经存在的目录,相当于拷贝过去后又重命名。但相反,如果desc是目标机器上已经存在的目录,则会直接把文件拷贝到该目录下面。

针对文件操作:

ansible 192.168.183.33 -m copy -a "src=/etc/passwd dest=/tmp"    放到tmp目录下,名字不变
ansible 192.168.183.33 -m copy -a "src=/etc/passwd dest=/tmp/ansibletest/p.txt"    放到/tmp/ansibletest目录下名字叫p.txt,内容与passwd一致

这里的/tmp/123和源机器上的/etc/passwd是一致的,但如果目标机器上已经有/tmp/ansibletest目录,则会再/tmp/ansibletest目录下面建立passwd文件

743a4e63176099ce9fe203f39bc2a07f718.jpg

77b5a324b7b01b40023883b0c361017e2b6.jpg

五、Ansible远程执行脚本

首先创建一个shell脚本
vim  /tmp/test.sh  //加入内容

#!/bin/bash
echo `date` > /tmp/ansible_test.txt  #把系统时间写入到该文件

然后把该脚本分发到各个机器上

ansible testhost -m copy -a "src=/tmp/test.sh dest=/tmp/test.sh mode=0755"

d9f23001004ac5956bff10219720f88d825.jpg

16faff59c35414f8693c7d78bcd21ea8748.jpg

最后是批量执行该shell脚本,脚本需要由执行权限

ansible testhost -m shell -a "/tmp/test.sh"

2683a097b4ea15ace3b2cac45e8e8a75430.jpg

dcd387cab7e51eb5aa0d275bf9918607e45.jpg

shell模块,还支持远程执行命令并且带管道,command不支持管道符
ansible testhost -m shell -a "cat /etc/passwd|wc -l"

六、Ansible管理任务计划

ansible testhost -m cron -a "name='test cron' job='/bin/touch /tmp/1212.txt'  weekday=6"

name指定任务计划的名字,job指定执行命令,最后是分时日月

其他的时间表示:分钟 minute 小时 hour 日期 day 月份 month
 

09376c84b7d4588143f33e5f70d3eb9278a.jpg

在002上会有name为test cron的标记

0b8b376d8bfd66dcd94c5454820da281aee.jpg

若要删除该cron 只需要加一个字段 state=absent 

ansible testhost -m cron -a "name='test cron' state=absent"

65ff343911f31b29ec03a86e3aab019eab0.jpg

fe2771d82ca2668d68b9fea0f53f84f64a9.jpg

七、Ansible安装rpm包和管理服务

ansible 192.168.183.33 -m yum -a "name=httpd state=removed"    卸载

在name后面还可以加上state=installed/removed  安装或移除

14b8b3b4ccb2dae5aaff030bed4f3db2189.jpg

ansible 192.168.183.33 -m yum -a "name=httpd"     安装

63945e2aa474fc93fe855b3d1f70f4a9f79.jpg

第一次卸载后和第二次安装后

bcd89910858ffe838b40a806ef609f51f97.jpg

ansible 192.168.183.33 -m service -a "name=httpd state=started enabled=no"  启动服务,并开机不启动

这里的name是centos系统里的服务名,可以通过chkconfig --list查到

834b4b937c700ac10bec4c162ecd06f883d.jpg

002上的服务启动,并且开机启动项也没有httpd

df7adf72d0d17daa834ba7142c9e62dffe7.jpg

4bdfac42ee1e27aeeb141a33a7ecdec9402.jpg

八、使用ansible playbook

相当于把模块和所有的配置文件写入到配置文件里面,例:

vim /etc/ansible/test.yml //加入如下内容,注意格式
---
- hosts: 192.168.183.33 或主机名
  remote_user: root
  tasks:
    - name: test_playbook
      shell: touch /tmp/tobe.txt        shell模块

执行:ansible-playbook test.yml

 说明: 第一行需要有三个杠,hosts参数指定了对哪些主机进行参作,如果是多台机器可以用逗号作为分隔,也可以使用主机组,在/etc/ansible/hosts里定义;
 user参数指定了使用什么用户登录远程主机操作;
 tasks指定了一个任务,其下面的name参数同样是对任务的描述,在执行过程中会打印出来,shell是ansible模块名字

d9329d7a3f19a08f58bac4ea6144660a579.jpg

77c0f636db74e68785e83c57177e9926590.jpg

九、playbook里的变量

再来一个创建用户的例子:

vim /etc/ansible/create_user.yml //加入如下内容
---
- name: create_user1
  hosts: 192.168.183.33
  user: root
  gather_facts: false
  vars:
    - user: "test"
  tasks:
    - name: create user
      user: name="{{ user }}"
      
执行:    ansible-playbook create_user.yml

说明:name参数对该playbook实现的功能做一个概述,后面执行过程中,会打印 name变量的值 ,可以省略;gather_facts参数指定了在以下任务部分执行前,是否先执行setup模块获取主机相关信息,这在后面的task会使用到setup获取的信息时用到;vars参数,指定了变量,这里指定一个user变量,其值为test ,需要注意的是,变量值一定要用引号引住;user指定了调用user模块,name是user模块里的一个参数,而增加的用户名字调用了上面user变量的值。

4bd2773017322e5439703d15d2e37f9aa59.jpg

此时Gathering Facts没有收集,因为 gather_facts: false

4b576e7b7ec8d73b849c9131bbb492d9667.jpg

09d918aed4b008a4c7c74720e58931ba9a6.jpg

十、Ansible playbook中的循环

 vim /etc/ansible/while.yml //加入如下内容

---
- hosts: 192.168.183.33
  user: root
  tasks:
    - name: change mode for files
      file: path=/tmp/{{ item }} state=touch mode=600        #变量
      with_items:                #循环
        - 1.txt    
        - 2.txt
        - 3.txt

执行 ansible-playbook while.yml

说明: 

把/tmp/目录下的1.txt,2.txt,3.txt的权限改为600,state=touch如果文件不存在,会创建该文件
item可以理解成变量,即1.txt,2.txt,3.txt
with_items为循环的对象
file模块:针对路径

十一、Ansible playbook中的条件判断

 vim /etc/ansible/when.yml //加入如下内容

---
- hosts: testhost  指定所有机器
  user: root
  gather_facts: True  收集信息,默认收集,此处需要收集
  tasks:
    - name: use when
      shell: touch /tmp/when.txt
      when: ansible_ens33.ipv4.address == "192.168.183.33"  表示ansible_ens33的下一级ipv4的下一级address地址为192.168.183.33时,分级显示的,下两图所示
      
 说明:ansible 192.168.183.33 -m setup 可以查看到所有的facter收集到的信息,即分级的数据
 
执行   ansible-playbook when.yml

0772a612b88116597bdd1348000a5afc00f.jpg

skipping: [127.0.0.1] 表示条件不成立

510ffb1ea331f8638c2955a94350edf4afb.jpg

十二、playbook中的handlers

 执行task之后,服务器发生变化之后要执行的一些操作,比如我们修改了配置文件后,需要重启一下服务 


vim /etc/ansible/handlers.yml        //加入如下内容

---
- name: handlers test
  hosts: 192.168.183.33
  user: root
  tasks:
    - name: copy file
      copy: src=/etc/passwd dest=/tmp/aaab.txt 此命令执行成功后,在执行下面的notify
      notify: test handlers        对应下面handlers,可以定义多个
  handlers:            前面的命令执行成功后,才会执行这条命令
    - name: test handlers
      shell: echo "111111" >> /tmp/aaab.txt

执行:    ansible-playbook handlers.yml

 说明,只有copy模块真正执行后,才会去调用下面的handlers相关的操作。也就是说如果1.txt和2.txt内容是一样的,并不会去执行handlers里面的shell相关命令。 这种比较适合配置文件发生更改后,重启服务的操作。
cc8370b5660ab2b0ddc71f58c34bff0339e.jpg

70389f1bb39e814bab463deb9ab2042c3bf.jpg

十三、playbook安装nginx

思路:先在一台机器上编译安装好nginx、打包,然后再用ansible去下发

cd /etc/ansible   进入ansible配置文件目录
mkdir  nginx_install   创建一个nginx_install的目录,方便管理
cd nginx_install
mkdir -p roles/{common,install}/{handlers,files,meta,tasks,templates,vars}

把已经存在的编译好nginx搞过去

说明:roles目录下有两个角色,common为一些准备操作,install为安装nginx的操作。每个角色下面又有几个目录,handlers下面是当发生改变时要执行的操作,通常用在配置文件发生改变,重启服务。files为安装时用到的一些文件,meta为说明信息,说明角色依赖等信息,tasks里面是核心的配置文件,templates通常存一些配置文件,启动脚本等模板文件,vars下为定义的变量,可以自动到目录查找

nginx的安装路径、启动脚本路径、配置文件路径

2da0e2816dbd25964c21fa0268fd43b1323.jpg

需要事先准备好安装用到的文件,具体如下:
在一台机器上事先编译安装好nginx,配置好启动脚本,配置好配置文件

打包:    tar czvf nginx.tar.gz --exclude "nginx.conf" --exclude "vhost" nginx/        --exclude 过滤掉nginx.conf,vhost

安装好nginx,或有之前的包,我们需要把nginx目录打包,并放到/etc/ansible/nginx_install/roles/install/files/下面,名字为nginx.tar.gz

mv nginx.tar.gz /etc/ansible/nginx_install/roles/install/files/

启动脚本、配置文件都要放到/etc/ansible/nginx_install/roles/install/templates下面

cp nginx/conf/nginx.conf /etc/ansible/nginx_install/roles/install/templates/

cp /etc/init.d/nginx /etc/ansible/nginx_install/roles/install/templates/

cd  /etc/ansible/nginx_install/roles/common/tasks

定义common的tasks,nginx是需要一些依赖包的

vim  /tasks/main.yml //内容如下

- name: Install initializtion require software
  yum: name={{ item }} state=installed
  with_items:
    - zlib-devel
    - pcre-devel

定义变量

vim /etc/ansible/nginx_install/roles/install/vars/main.yml //主配置文件,内容如下

nginx_user: www
nginx_port: 80
nginx_basedir: /usr/local/nginx

首先要把所有用到的文档拷贝到目标机器
vim /etc/ansible/nginx_install/roles/install/tasks/copy.yml //子配置文件,内容如下

- name: Copy Nginx Software
  copy: src=nginx.tar.gz dest=/tmp/nginx.tar.gz owner=root group=root
- name: Uncompression Nginx Software
  shell: tar zxf /tmp/nginx.tar.gz -C /usr/local/
- name: Copy Nginx Start Script
  template: src=nginx dest=/etc/init.d/nginx owner=root group=root mode=0755
- name: Copy Nginx Config
  template: src=nginx.conf dest={{ nginx_basedir }}/conf/ owner=root group=root mode=0644

接下来会建立用户,启动服务,删除压缩包

vim /etc/ansible/nginx_install/roles/install/tasks/install.yml     //内容如下

- name: Create Nginx User
  user: name={{ nginx_user }} state=present createhome=no shell=/sbin/nologin           nginx_user是vars目录中的main.yml定义的 , createhome是否创建用户家目录
- name: Start Nginx Service
  shell: /etc/init.d/nginx start
- name: Add Boot Start Nginx Service        添加到开机启动
  shell: chkconfig --level 345 nginx on
- name: Delete Nginx compression files        删除文件
  shell: rm -rf /tmp/nginx.tar.gz

再到tasks目录下创建总的main.yml并且把copy和install调用


vim /etc/ansible/nginx_install/roles/install/tasks/main.yml //内容如下

- include: copy.yml
- include: install.yml

到此两个roles:common和install就定义完成了,接下来要定义一个入口配置文件

vim /etc/ansible/nginx_install/install.yml  //总入口文件,内容如下

---
- hosts: 192.168.183.33
  remote_user: root
  gather_facts: True
  roles:
    - common
    - install

执行: ansible-playbook /etc/ansible/nginx_install/install.yml           执行前需要把系统自带的nginx卸载掉:    yum remove nginx   卸载掉自带的Nginx

启动nginx服务失败,根据提示到002机器上查看

a892bf79dac7f9ef1a861d1636e6be954bc.jpg

systemctl status nginx   经排查httpd占用80端口导致

systemctl stop httpd.service   停掉httpd

72eb76ecd374f4e8cf53fc19efb23fec968.jpg

再次执行ansible-playbook /etc/ansible/nginx_install/install.yml

此时执行成功

fe09530e297139758284e08108df0e4a8d5.jpg

002上查看,此时服务已经启动

252b6ba19eb019be98fe1f78587d27a24b0.jpg

总结:

roles即对应的角色,即子目录,子的playbook脚本,roles对应目录common和install
到common目录中找tasks目录下的main.yml,安装扩展包
common/tasks/main.yml执行完成后执行install
install/tasks/main.yml,调用同一个目录下的copy.yml和install.yml

十四、playbook管理配置文件

 生产环境中大多时候是需要管理配置文件的,安装软件包只是在初始化环境的时候用一下。下面我们来写个管理nginx配置文件的playbook

mkdir -p /etc/ansible/nginx_config/roles/{new,old}/{files,handlers,vars,tasks}  创建目录

其中new为更新时用到的,old为回滚时用到的,files下面为nginx.conf和vhosts目录,handlers为重启nginx服务的命令
关于回滚,需要在执行playbook之前先备份一下旧的配置,所以对于老配置文件的管理一定要严格,千万不能随便去修改线上机器的配置,并且要保证new/files下面的配置和线上的配置一致。
 先把nginx.conf和vhosts目录放到files目录下面:

cd /usr/local/nginx/conf/
 cp -r nginx.conf vhost  /etc/ansible/nginx_config/roles/new/files/  把nginx.conf和vhost拷贝到roles/new/files目录中

定义变量:

vim /etc/ansible/nginx_config/roles/new/vars/main.yml   内容如下:

nginx_basedir: /usr/local/nginx

vim /etc/ansible/nginx_config/roles/new/handlers/main.yml      //定义重新加载nginx服务

- name: restart nginx
  shell: /etc/init.d/nginx reload     重新加载配置文件

vim /etc/ansible/nginx_config/roles/new/tasks/main.yml     //这是核心的任务

- name: copy conf file
  copy: src={{ item.src }} dest={{ nginx_basedir }}/{{ item.dest }} backup=yes owner=root group=root mode=0644    
  with_items:
    - { src: nginx.conf, dest: conf/nginx.conf }  循环对象中有两个子对象用逗号做分隔符
    - { src: vhost, dest: conf/ }
  notify: restart nginx

vim /etc/ansible/nginx_config/update.yml // 最后是定义总入口配置

---
- hosts: 192.168.183.33
  user: root
  roles:
  - new

 执行: ansible-playbook /etc/ansible/nginx_config/update.yml

ccd1e336bb14a3114005db56f24df4fdb53.jpg

针对001上的nginx.conf文件做修改,然后在执行ansible-playbook /etc/ansible/nginx_config/update.yml

23465338de82a21018b6ca90a7ade9d13f0.jpg6b83a3d213773c1dcf2b9d83591429f01dd.jpg

f9f6c290d595b323c7752ee5bb1fd01539b.jpg

回到002上查看,002上的nginx.conf配置文件也更改了

e05dd7151a3521bd734aba9cc9bcfa4b13e.jpg

 而回滚的backup.yml对应的roles为old,把new下的所有文件拷贝到old下

rsync -av /etc/ansible/nginx_config/roles/new/ /etc/ansible/nginx_config/roles/old/

 回滚操作就是把旧的配置覆盖,然后重新加载nginx服务, 每次改动nginx配置文件之前先备份到old里,对应目录为/etc/ansible/nginx_config/roles/old/files 


 vim /etc/ansible/nginx_config/rollback.yml // 最后是定义总入口配置

---
- hosts: 192.168.183.33
  user: root
  roles:
  - old 
执行:  ansible-playbook /etc/ansible/nginx_config/rollback.yml

在002机器上修改nginx.conf文件,执行ansible-playbook /etc/ansible/nginx_config/rollback.yml完成后,002上的配置文件会把001机器上roles/old/files目录下的备份文件恢复

663fe3602a7d6208b1077b63c33f915a1bc.jpg

 

转载于:https://my.oschina.net/u/4093217/blog/3079282

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值