计算机教程

当前位置:3522.com > 计算机教程 > ansible实践3-playbook条件判断

ansible实践3-playbook条件判断

来源:http://www.4sports-uk.com 作者:3522.com 时间:2019-10-30 17:48

192.168.147.138

    - common

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

  • name: Start NginxService

   - name: create user

cd nginx_install;

yum insall -y openssh-clients

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

 user: root

Ansible playbook中的handlers

3522.com,客户端:


   - name: use when

  • include: copy.yml

  • include: install.yml

      - 1.txt

mkdir  nginx_install   创建一个nginx_install的目录,方便管理

   - { src: vhosts, dest: conf/ }

需要事先准备好安装用到的文件,具体如下:

vim /etc/ansible/nginx_config/rollback.yml

    - pcre-devel

不仅支持命令行使用模块,也支持编写yaml格式的playbook

 

其他的时间表示:

      copy: src=/etc/passwd dest=/tmp/aaa.txt

如果更新失败,可以执行回滚:ansible-playbook /etc/ansible/nginx_config/rollback.yml

  with_items:

4.定义handlers:

 

 tasks:

  handlers:

 

  tasks:

先把nginx.conf和vhosts目录放到files目录下面

      shell: touch /tmp/when.txt

周:weekday

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


 

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

    - install

 roles:

  • name: Install initializtion require software

- hosts: testhost

    - name: copy file

   - name: test_playbook

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

下面关于Ansible的文章您也可能喜欢,不妨参考下:

  template: src=nginx dest=/etc/init.d/nginx owner=root group=root mode=0755

在两台机器的/etc/hosts文件里加入:

 

          - openssl-devel

 

 gather_facts: True

    - name: test handlers

- name: create_user

 

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

git命令,需要yum先安装一下: yum install -y git

查看上述三个包是否已经安装成功:rpm -qa | egrep 'pcre|openssl|zlib'

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

user参数制定了使用什么用户登录远程主机操作;

 

ansible特点:

      shell: echo "111111" >> /tmp/aaa.txt

vim /etc/ansible/nginx_install/roles/install/tasks/copy.yml

 

16.执行:ansible-playbook /etc/ansible/nginx_install/install.yml

nginx_user: www

nginx_basedir: /usr/local/nginx

cd  /etc/ansible/nginx_install/roles

1.编译安装Nginx可以参考LNMP部分

  • name: Create NginxUser

ansible-doc -l 查看所有的模块

git clone git://github.com/dl528888/ansible-examples.git

ansible testhost -m shell -a 'cat /etc/passwd | grep root'

      when: facter_ipaddress == "172.7.15.106"

 shell: tar zxf /tmp/nginx.tar.gz -C /usr/local/

在一台机器上事先编译安装好nginx,配置好启动脚本,配置好配置文件

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

  • name: Copy NginxSoftware   

- hosts:  192.168.147.138

    - zlib-devel

客户端:

 

收集客户端的信息:

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

6.定义一个update程序的入口文件:

执行: ansible-playbook /etc/ansible/nginx_install/install.yml

ansible 127.0.0.1 -m command -a 'hostname'

 

vim /etc/ansible/nginx_install/roles/install/vars/main.yml

    - name: use when

12.编写install/tasks的copy配置文件:

 

ansible文档的使用:

 

 

 

#!/bin/bash

  • name: Uncompression Nginx Software

Ansible入门notify和handlers  http://www.linuxidc.com/Linux/2017-02/140871.htm

 

 

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

开启httpd服务,并设为开机启动:

再创建main.yml并且把copy和install调用

ansible testhost -m shell -a "cat /etc/passwd | wc -l"

  shell: chkconfig --level 345 nginx on

vim /etc/ansible/create_user.yml

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

git clone git://github.com/dl528888/ansible-examples.git

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

CentOS 6.5安装自动化工具Ansible和图形化工具Tower  http://www.linuxidc.com/Linux/2017-03/141422.htm

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

解决:yum install -y libselinux-python

  shell: tar zxf /tmp/nginx.tar.gz -C /usr/local/

 

nginx_basedir: /usr/local/nginx

vim /etc/ansible/when.yml

  • name: Add Boot Start NginxService

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

  • hosts: testhost

开源UI http://github.com/alaxli/ansible_ui

 

ansible也是有Python开发的。

nginx_port: 80

11.编写install/vars的总入口配置文件:

  yum: name={{ item }} state=installed

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

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

touch /tmp/when.txt:

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

     copy: src=/etc/passwd dest=/tmp/aaa.txt

  gather_facts: True

支持sudo

  • name: Copy NginxStart Script

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

 

cp -r /usr/local/nginx/conf/vhosts /etc/ansible/nginx_config/roles/new/files/

下载整个样例库   

ansible testhost -m service -a "name=httpd state=started enabled=yes"

      notify: test handlers

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

定义变量

yum install -y epel-release

 

Linux下源码编译安装Ansible及排错记录  http://www.linuxidc.com/Linux/2017-03/141427.htm

  shell: rm -rf /tmp/nginx.tar.gz

创建一个任务计划:

  user: root

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

 

 

  service: name=nginx state=restarted

6.ansible安装rpm包和管理服务

 

      - 2.txt

- name: handlers test

对这组主机执行w命令:

mkdir -p roles/{common,install}/{handlers,files,meta,tasks,templates,vars}

 handlers:

  roles:

服务端:

  remote_user: root

 template: src=nginx dest=/etc/init.d/nginx owner=root group=root mode=0755

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

     notify: test handlers

首先要把所有用到的文档拷贝到目标机器

服务端:192.168.147.137

  gather_facts: True

 shell: /etc/init.d/nginx reload

  hosts: web10.aming.com

Ansible 的详细介绍请点这里
Ansible 的下载地址请点这里


 user: root

- hosts: testhost

   - name: test handlers

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

chmod 600 /root/.ssh/authorized_keys

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

这里的name是CentOS系统里的服务名,可以通过chkconfig --list查看。

  • name: Copy NginxConfig

执行:


3.定义vars:

cd /etc/ansible   进入ansible配置文件目录

echo `date` > /tmp/ansible_test.txt

 

 with_items:

 

执行:ansible-playbook /etc/ansible/create_user.yml

  template: src=nginx.conf dest={{ nginx_basedir }}/conf/ owner=root group=root mode=0644

只需要在服务端上安装ansible即可

 

安装httpd:

  copy: src=nginx.tar.gz dest=/tmp/nginx.tar.gz owner=root group=root

5.定义tasks:

  • name: Delete Nginxcompression files

     user: name="{{ user }}"

Ansible 安装nginx

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

 

15.编写整个程序的总入口配置文件:

  user: name={{ nginx_user }} state=present createhome=no shell=/sbin/nologin

其中new为更新时用到的,old为回滚时用到的,files下面为nginx.conf和vhosts目录,handlers为重启Nginx服务的命令

  user: root

编辑一个when.yml脚本:

  tasks:

 

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

7.进入该目录:cd nginx_install

ansible-doc cron 查看指定的模块


本文永久更新链接地址http://www.linuxidc.com/Linux/2017-03/142191.htm

CentOS 7上搭建Jenkins Ansible服务  http://www.linuxidc.com/Linux/2016-12/138737.htm

ansible样例库:

     shell: echo "111111" >> /tmp/aaa.txt

3.ansible拷贝目录或者文件

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

ansible client -m setup

如果ssh命令不存在,安装一下:

最后是批量执行该shell脚本

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

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

     file: path=/tmp/{{ item }} mode=600 owner=root group=root

 roles:

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

- hosts: 192.168.147.138

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

cd /usr/local/nginx/conf/

5.ansible实现任务计划


vim /etc/ansible/nginx_config/update.yml

nginx_user: www

setenforce0

        with_items:

3522.com 1

 copy: src=nginx.tar.gz dest=/tmp/nginx.tar.gz owner=root group=root

时:hour

- hosts: testhost

 vars:

- name: handlers test

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

   - name: copy file

执行:ansible-playbook /etc/ansinle/handlers.yml

mkdir -p roles/{common,install}/{handlers,files,meta,tasks,templates,vars}

把公钥(id_rsa.pub)内容放到客户端(192.168.147.138)的/root/.ssh/authorized_keys里面:scp /root/.ssh/id_rsa.pub 192.168.147.138:/root/.ssh/authorized_keys

 user: name={{ nginx_user }} state=present createhome=no shell=/sbin/nologin

        yum: name={{ item }} state=installed


 shell: rm -rf /tmp/nginx.tar.gz

vim /etc/ansinle/handlers.yml

192.168.147.137 server

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

关于回滚,需要在执行playbook之前备份一下旧的配置,所以对于老配置文件的管理一定要严格,千万不要随便去修改线上机器的配置,并且要保证new/files下面的配置和线上的配置一致

cp -r nginx.conf vhosts /etc/ansible/nginx_config/roles/new/files

 notify: restart nginx

shell模块,还支持远程执行命令并且带管道:

说明:testhost为主机组名字,自定义的。下面两个IP为组内的机器IP,也可以写主机名,前提是能解析为IP。

vim /etc/ansible/loop.yml

- name: Delete Nginx compression files

 tasks:

执行:ansible-playbook /etc/ansible/when.yml

本文由3522.com发布于计算机教程,转载请注明出处:ansible实践3-playbook条件判断

关键词: 3522.com