自动化工具ansible基本命令和使用方式学习笔记

    xiaoxiao2021-04-18  54

    一、ansible简介

    ansible是新出现的自动化运维工具基于Python研发通过ssh 控制客户端。

    二、ubuntu上安装ansible

    sudo apt-get install software-properties-common

    sudo apt-add-repository ppa:ansible/ansible

    sudo apt-get update

    sudo apt-get install ansible

    三、ansible的主要配置文件

           (1)ansible应用程序的主配置文件:/etc/ansible/ansible.cfg

          (2) Host Inventory定义管控主机/etc/ansible/hosts

      默认是以root用户执行,但是基于ssh连接操作要多次输入密码,为方便可以使用基于ssh密钥方式进行认证。

    ansible应用程序命令

      1.ansible-doc命令:获取模块列表,及模块使用格式;

    ansible-doc -l:获取列表

    ansible-doc -s  module_name:获取指定模块的使用信息

     2.ansible命令格式

    ansible  <host-pattern>  [-f forks] [-m module_name]  [-a args]

    <host-pattern>

    指明管控主机,以模式形式表示或者直接给定IP,必须事先定义在文件中;all设置所有

     

     [-f forks]

    指明每批管控多少主机,默认为5个主机一批次

     

    [-m module_name]

    使用何种模块管理操作,所有的操作都需要通过模块来指定

     

    [-a args]

    指明模块专用参数;args一般为key=value格式

    注意:command模块的参数非为kv格式,而是直接给出要执行的命令即可;

     

         用于解压文件,模块包含如下选项:     copy:在解压文件之前,是否先将文件复制到远程主机,默认为yes。若为no,则要求目标主机上压缩包必须存在。     creates:指定一个文件名,当该文件存在时,则解压指令不执行     dest:远程主机上的一个路径,即文件解压的路径      grop:解压后的目录或文件的属组     list_files:如果为yes,则会列出压缩包里的文件,默认为no2.0版本新增的选项     mode:解决后文件的权限     src:如果copyyes,则需要指定压缩文件的源路径      owner:解压后文件或目录的属主 示例如下:     - unarchive: src=foo.tgz dest=/var/lib/foo     - unarchive: src=/tmp/foo.zip dest=/usr/local/bin copy=no     - unarchive: src=https://example.com/example.zip dest=/usr/local/bin copy=no

           注意:<host-pattern>默认读取/etc/ansible/hosts,也可以指明自定义文件路径

      -iPATH, inventory=PATH:指明使用的host inventory文件路径;

    常用模块(module_name):

    1)command:默认模块,可省略。在远程主机上进行操作命令

    -a  'COMMAND'

    注意:comand模块的参数非key=value格式,直接给出要执行的命令

    2)user:

    -a 'name=  state={present(创建)|absent(删除)}  force=(是否强制操作删除家目录)  system=  uid=  shell= home='

    [root@localhost ~]# ansible all -m user -a 'name=ansible state=present'

    3)group:

    -a 'name= state={present|absent}  gid=  system=(系统组)'

    [root@localhost ~]# ansible all -m group -a 'name=mygroup state=presentsystem=true'

    4)cron:

    -a  'name= state=  minute=  hour= day=  month=  weekday= job='

    [root@localhost ~]# ansible all -m cron -a 'name='Time' state=presentminute='*/5' job='/usr/sbin/ntpdate 172.168.0.1 &> /dev/null''

    5)ping:

    无参数

    [root@localhost ~]# ansible all -m ping

    6)file对文件的创建,修改和删除等

    -a 'path=  mode=  owner= group= state={file|directory|link|hard|touch|absent}  src=(link,链接至何处)'

    [root@localhost ~]# ansible all -m file -a 'path=/tmp/test.txt state=touchmod=600 owner=user1'

    7)copy

    -a 'dest=(远程主机上路径)  src=(本地主机路径)  content=(直接指明内容) owner=  group=  mode='

    [root@localhosttmp]# ansible web -m copy -a 'src=/etc/yum.repos.d/aliyun.repo  dest=/etc/yum.repos.d/'

    8)template

    -a  'dest= src=\'#\'" content=  owner= group=  mode='

    9)yum

    -a 'name=  conf_file=(指明配置文件) state={present|latest|absent} enablerepo= disablerepo='        

    [root@localhost ~]# ansible all -m yum 'name=httpd state=present'                

    10)service

    -a 'name= state={started|stopped|restarted} enabled=(是否开机自动启动)  runlevel='

    [root@localhost ~]# ansible all -m service -a 'name=httpd state=started'

    11)shell

    -a 'COMMAND'   运行shell命令

    [root@localhost ~]# ansible all -m shell -a echo "123456789" |passwd stdin user1'

    12)script

    -a '/PATH/TO/SCRIPT'运行脚本

    [root@localhost ~]# ansible all -m script -a '/tmp/a.sh'

    13)setup:获取指定主机的facts变量

    14) unarchive模块

     2,playbook的一些概念和用法

    playbook— 变量

          (1)变量命名:字母、数字和下划线组成,仅能以字母开头;

          (2)变量种类:

     1)facts:由远程主机发回的主机特有的属性信息,这些信息被保存在ansible变量中;无须声明,可直接调用;

      2)自定义变量:

       通过命令行传递:ansible-playbook  test.yml  –extra-vars "host=www user=test"

       通过roles传递

     3)主机变量:定义在inventory中的主机之后的变量;直接传递给单个主机的变量

    实例:

    [root@localhost ~]# vim /etc/ansible/hosts中直接定义在主机之后

    [web]

    192.168.0.101    host=mail

    192.168.0.102

    192.168.0.103

     4)组变量:定义在inventory中的组上的变量(例如在默认的文件/etc/ansible/hosts上编辑)

    [group_name:vars]

    var1=value

    var2=value

    注意:组名要事先存在,实例如下:

    [websrvs]

    192.168.0.101

    192.168.0.102

    [websrvs:vars]

    host=mail

      变量使用示例:

          [root@localhost~]# vim useradd.yml

    –     hosts: websrvs

           remote_user: root

           vars:

    username: testuser

    password: xuding

            tasks:

    -name: add user

       user: name={{ username }} state=present

    -name: set password

      shell: /bin/echo {{ password }} |/usr/bin/passwd –stdin {{ username }}

    注释:

        1) {{ }} 调用变量

        2) #ansible-playbook /PATH/TO/SOME_YAML_FILE  { -eVARS|–extra-vars=VARS}     变量的重新赋值调用方法

                     [root@localhost ~]# ansible-playbookuseradd.yml –extra-vars "username=ubuntu"

     

     5.playbook—  tasks

          (1)条件测试:

                  在某task后面添加when子句即可实现条件测试功能;when语句支持Jinja2语法;

         实例当时RedHat系列系统时候调用yum安装

    tasks:

    -name: install web server package

      yum: name=httpd state=present

      when: ansible_os_family == "RedHat"

          (2)迭代:item

        在task中调用内置的item变量;在某task后面使用with_items语句来定义元素列表;

    tasks:

    -name: add four users

      user: name={{ item }}  state=present

      with_items:

    -testuser1

    -testuser2

    -testuser3

    -testuser4

       注意:迭代中,列表中的每个元素可以为字典格式;

           实例:

    -name: add two users

      user: name={{ item.name }}  state=present groups={{ item.groups }}

      with_items:

      – { name: 'testuser5', groups: 'wheel' }

      – { name: 'testuser6', groups: 'root' }

     

     6.playbook— handlers处理器;触发器

           只有其关注的条件满足时,才会被触发执行的任务;

    实例:配置文件发生改变触发重启服务

    -hosts: websrvs

      remote_user: root

      tasks:

    -name: install httpd

    yum:name=httpd state=present

    -name: install config file

      copy: src=/root/httpd.confdest=/etc/httpd/conf/httpd.conf

              notify: restart httpd

    -name: start httpd service

              service: name=httpd state=started

    handlers:

    -name: restart httpd

       service: name=httpd state=restarted

     

     7.playbook模板

         templates:

                 用于生成文本文件(配置文件);模板文件中可使用jinja2表达式,表达式要定义在{{}},也可以简单地仅执行变量替换;

          roles:

      roles用于实现“代码复用”;

      roles以特定的层次型格式组织起来的playbook元素(variables,tasks, templates, handlers);

      可被playbook以role的名字直接进行调用;

          用法:在roles/下建立[group_name]子目录,并非全部都要创建;例如:

    /etc/ansible/roles/(在/etc/ansible/ansible.cfg定义roles目录)

    webserver/

    files/:此角色中用到的所有文件均放置于此目录中;

    templates/Jinja2模板文件存放位置;

    tasks/:任务列表文件;可以有多个,但至少有一个叫做main.yml的文件;

    handlers/:处理器列表文件;可以有多个,但至少有一个叫做main.yml的文件;

    vars/:变量字典文件;可以有多个,但至少有一个叫做main.yml的文件;

    meta/:此角色的特殊设定及依赖关系;

     参考链接:http://www.178linux.com/15724

                         http://www.ansible.com.cn/

     

     

    转载请注明原文地址: https://ju.6miu.com/read-674734.html

    最新回复(0)