zoukankan      html  css  js  c++  java
  • day36-20180705笔记

    笔记:Python3 Ansible

    一、Ansible

    Ansible特点:
    不需要安装客户端,通过sshd去通信
    基于模块工作,模块可以任何语言开发
    不仅支持命令行使用模块,也支持编写yaml格式的playbook
    支持sudo
    有提供UI(浏览器图形化)www.ansible.com/tower 10台主机以内免费
    开源UI https://github.com/alaxli/ansible_ni
    文档 http://download.csdn.net/detail/liyang23456/7741185


    Ansible安装:
    两台机器 172.7.15.106 172.7.15.111
    只需要在106机器上安装ansible即可
    yum install –y epel-release
    yum install –y ansible


    Ansible配置密钥
    106上操作,生成密钥
    ssh-keygen –t rsa 直接回车即可,不用设置密钥密码
    把公钥(id_rsa.pub)内容放到对方机器(111)的/root/.ssh/authorized_keys里面
    scp .ssh/id_rsa.pub 172.7.15.111:/root/.ssh/authorized_keys
    本机也要操作
    cat /root/.ssh/id_rsa.pub >> /root/.ssh/authorized_keys
    106和111上操作
    chmod 600 /root/.ssh/authorized_keys
    关闭selinux和iptables,并保存
    setenforce 0
    iptables –F; /etc/init.d/iptables save



    Ansible 更改配置文件
    vim /etc/ansible/hosts //增加
    [testhost]
    127.0.0.1
    172.7.15.111

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



    Ansible 远程执行命令
    ansible testhost –m command –a ‘w’
    这样就可以批量执行命令了。这里的testhost为主机组名,-m后边是模块名字,-a后面是命令。当然我们也可以直接写一个ip,针对某一台机器来执行命令。
    ansible 127.0.0.1 –m command –a ‘hostname’
    错误:”msg”: Aborting, target uses selinux but python bindings (libselinux-python) aren’t installed!”
    解决: yum install –y libselinux-python
    还有一个模块就是shell同样也可以实现
    ansible testhost –m shell –a ‘w

    command模块不支持管道过滤,而shell模块支持管道过滤
    command模块能实现的功能,shell模块也能实现,而shell模块能实现的功能,command模块不一定能实现


    Ansible 拷贝文件或目录
    ansible slave.localdomain -m copy -a "src=/etc/ansible dest=/tmp/ansibletest owner=root group=root mode=0755"

    注意: 源目录会放到目标目录下面去,如果目标指定的目录不存在,它会自动创建。如果拷贝的是文件,dest指定的名字和源如果不同,并且它不是已经存在的目录,相当于拷贝过去后又重命名。但相反,如果dest是目标机器上已经存在的目录,则会直接把文件拷贝到该目录下面。
    ansible slave.localdomain -m copy -a "src=/etc/passwd dest=/tmp/123"

    这里的/tmp/123和源机器上的/etc/passwd是一致的,但如果目标机器上已经有/tmp/123目录,则会再/tmp/123目录下建立passwd文件
    
    
    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"
    最后是批量执行该shell脚本
    ansible testhost -m shell -a "/bin/sh /tmp/test.sh"

    远程执行命令,查看shell脚本执行后输出的结果

    shell模块,还支持远程执行命令并且带管道
    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=0"

    若要删除该cron只需要加一个字段state=absent
    ansible testhost -m cron -a "name='test cron' state=absent"

    其他的时间表示:分钟minute 小时hour 日期day 月份month
    
    
    
    
    Ansible 安装rpm包/管理服务
    ansible server2.localdomain -m yum -a "name=httpd"
    在name后面还可以加上state=installed
    ansible server2.localdomain -m service -a "name=httpd state=started enabled=yes"

    这里的name是centos系统里的服务名,可以通过chkconfig –list查看到。
    Ansible文件的使用
    ansible-doc –l 列出所有的模块
    ansible-doc cron 查看指定的模块的文档


    Ansible playbook的使用
    相当于把模块写入到配置文件里面,例:
    vim /etc/ansible/test.yml
    ---
    - hosts: slave.localdomain //可以指定主机组testhost
    remote_user: root
    tasks:
    - name: test_playbook
    shell: touch /tmp/lishiming.txt
    说明: hosts参数指定了对哪些主机进行操作;
    user参数指定了使用什么用户登录远程主机操作;
    tasks指定了一个任务,其下面的name参数同样是对任务的描述,在执行过程中会打印出来。
    执行: ansible-playbook test.yml

    
    
    再来一个创建用户的例子:
    vim /etc/ansible/create_user.yml
    ---
    - name: create_user
    hosts: slave.localdomain
    user: root
    gather_facts: false
    vars:
    - user: "test"
    tasks:
    - name: create user
    user: name="{{user}}"
    说明: name参数对该playbook实现的功能做一个概述,后面执行过程中,会打印name变量的值,可以省略;gather_facts参数指定了在以下任务部分执行前,是否先执行setup模块获取主机相关信息,这在后面的tasks会使用到setup获取的信息时用到;vars参数,指定了变量,这里指定一个user变量,其值为test,需要注意的是,变量值一定要用引号引住;user提定了调用user模块,name是user模块里的一个参数,而增加的用户名字调用了上面user变量的值。


    ansible-playbook create_user.yml

    Ansible playbook 中的循环
    vim /etc/ansible/loop.yml
    ---
    - hosts: testhost
    user: root
    tasks:
    - name: change mode for files
    file: path=/tmp/{{item}} mode=600 owner=root group=root
    with_items:
    - 1.txt
    - 2.txt
    - 3.txt

    批量远程执行更改权限,注意:客户机要保证有1.txt,2.txt,3.txt文件存在

    
    
    
    Ansible playbook条件判断
    vim /etc/ansible/when.yml
    ---
    - hosts: testhost
    remote_user: root
    gather_facts: True
    tasks:
    - name: use when
    shell: touch /tmp/when.txt
    when: facter_ipaddress == "10.211.55.15"

    
    
    Ansible playbook 中的handlers
    执行task之后,服务器发生变化之后要执行一些操作,比如我们修改了配置文件后,需要重启一下服务
    vim /etc/ansible/handlers.yml
    ---
    - hosts: testhost
    name: handlers test
    user: root
    tasks:
    - name: copy file
    copy: src=/etc/passwd dest=/tmp/aaa.txt
    notify: test handlers

    handlers:
    - name: test handlers
    shell: echo "11111" >> /tmp/aaa.txt

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

    通过rsync将服务端上的passwd文件同步到客户端aaa.txt文件,目标文件aaa.txt与服务端的passwd文件内容是一致的

    服务端执行ansible-playbook命令同步,客户端文件aaa.txt文件内容不会更改,因为task执行不成功,所以不会执行handlers下面的操作

    
    
  • 相关阅读:
    解决 minwidth 在 IE6 中无效的方法
    SmallSlider 图片轮播插件
    css li中a的高端与li的高端不一致,解决方案
    为什么height:5px在IE6里显示不正常?
    命令提示符下不能输入中文
    Sql中日期差 Sql中 DateDiff Sql 中时间差
    20100420 18:17 HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Services\aspnet_state\Parameters
    多个表结果的并列显示
    linux系统下载地址
    VMware中Shared Folders(共享文件夹)的配置
  • 原文地址:https://www.cnblogs.com/ivan-yang/p/9276580.html
Copyright © 2011-2022 走看看