zoukankan      html  css  js  c++  java
  • Ansible常用模块基本操作

    Ansible是一个系列文章,我会尽量以通俗易懂、诙谐幽默的总结方式给大家呈现这些枯燥的知识点,让学习变的有趣一些。

    前言

    对于任何一个框架,一个应用,为了更便于推广,便于使用,便于商业化,都会顺便提供很多常用的模块,这样让大家也很容易使用起来。Ansible也是一样的,所以这些常用的模块,就好比基本功,基本招式一样,我们需要掌握这些基本功,掌握这些基本招式。这篇文章,就对这些常用的模块进行一个比较全面的总结。

    ping模块

    ping是测试远程节点的SSH连接是否就绪的常用模块,但是它并不像Linux命令那样简单地ping一下远程节点,而是先检查能否通过SSH登陆远程节点,再检查其Python版本能否满足要求,如果都满足则会返回pong,表示成功。使用方式如下:

    ansible web -m ping
    

    ping无须任何参数。上述命令输出结果如下所示:

    192.168.1.2 | SUCCESS => {
        "changed": false,
        "ping": "pong"
    }
    192.168.1.4 | SUCCESS => {
        "changed": false,
        "ping": "pong"
    }
    

    debug模块

    打印输出信息,类似Linux上的echo命令。在后续的学习过程中,我们会经常用这个命令来调试我们写的playbook。

    对于debug模块有两种用法。下面就对这两种用法都进行详细的总结。

    • 通过参数msg定义打印的字符串
      msg中可以嵌入变量,比如我先定义了以下的一个playbook。

      ---
      
      - hosts: web
        vars:
          name: jellythink
        tasks:
          - name: display
            debug: msg="I am {{name}}"
      
    • 通过参数var定义需要打印的变量
      变量可以是系统变量,也可以是动态的执行结果,通过关键字register注入变量中。对于变量,我们可以这样玩:

    ---
    
    - hosts: web
      vars:
        name: jellythink
      tasks:
        - name: display
          debug:
            var: name
    

    对于注入变量,可以这样玩:

    ---
    
    - hosts: web
      tasks:
        - name: register var
          shell: hostname
          register: result
        - name: display
          debug:
            var: result
    

    copy模块

    从当前的机器上复制静态文件到远程节点上,并且设置合理的文件权限。copy模块在复制文件的时候,会先比较一下文件的checksum,如果相同则不会复制,返回状态为OK;如果不同才会复制,返回状态为changed。

    一般情况的使用,就是这样的:

    ---
    
    - hosts: server1
      tasks:
        - name: copyDemo
          copy:
            src: /home/jelly/nameList.txt 
            dest: /home/test1/nameList.txt
    

    在实际的工作中,一般会在进行文件分发时,需要备份原文件,这个时候就需要我们加上backup选项:

    ---
    
    - hosts: server1
      tasks:
        - name: copyDemo
          copy:
            src: /home/jelly/nameList.txt 
            dest: /home/test1/nameList.txt
            backup: yes
    

    加上backup: yes后,在目标主机上,就会对原来的文件进行备份,比如这样子的备份文件:

    nameList.txt.8648.2019-09-28@06:27:18~
    

    template模块

    如果只是复制静态文件,使用copy模块就可以了;但是如果在复制的同时需要根据实际情况修改部分内容,那么就需要用到template模块了。

    比如我们在分发配置文件时,每个配置文件需要根据远程主机的一些属性不同而配置不同的值,对于需要替换的部分,我们就可以使用template模块来进行替换。template模块使用的是Python中的Jinja2模板引擎,这里我们不需要过多的去关注这个模板引擎,只需要知道变量的表示法是{{}}就可以了。比如这里就有一个http.conf.j2的模板文件,文件内容如下:

    Listen {{ansible_default_ipv4.address}}
    Port {{http_port}}
    

    其中{{ansible_default_ipv4.address}}就是需要根据不同的主机,动态变化的。接下来,我们就可以这样使用template模块来完成变量的替换。

    ---
    
    - hosts: server1
      vars:
        http_port: 8080
    
      tasks:
      - name: Write Config File
        template:
          src: http.conf.j2
          dest: /home/test1/http.conf
    

    在目的主机上,文件内容如下:

    Listen 192.168.1.3
    Port 8080
    

    copy模块一样,template模块也可以进行权限设置和文件备份等功能。

    file模块

    file模块可以用来设置远程主机上的文件、软链接和文件夹的权限,也可以用来创建和删除它们。

    我们可以使用mode参数进行权限修改,可以直接赋值数字权限(必须以0开头)。

    ---
    
    - hosts: server1
      tasks:
      - name: Modify Mode
        file:
          path: /home/test1/http.conf
          mode: 0777
    

    我们还可以根据state参数的不同,实现不同的行为,比如创建软链接:

    ---
    
    - hosts: server1
      tasks:
        - name: Create Soft Link
          file:
            src: /home/test1/http.conf
            dest: /home/test1/conf
            state: link
    

    也可以设置state: touch创建一个新文件,比如这样:

    ---
    
    - hosts: server1
      tasks:
        - name: Create a new file
          file:
            path: /home/test1/touchfile
            state: touch 
            mode: 0700
    

    还可以设置state: directory新建一个文件夹,比如这样:

    ---
    
    - hosts: server1
      tasks:
        - name: Create directory
          file: 
            path: /home/test1/testDir
            state: directory
            mode: 0755
    

    user模块

    user模块可以对用户进行管理,实现增、删、改Linux远程节点的用户账户。比如增加用户:

    ---
    
    - hosts: server1
      tasks:
        - name: Add user
          user:
            name: test3
    

    删除用户:

    ---
    
    - hosts: server1
      tasks:
        - name: Add user
          user:
            name: test3
            state: absent
            remove: yes
    

    但是在使用这个user模块时,需要注意权限问题。

    shell模块

    在远程节点上通过/bin/sh执行命令。如果一个命令可以通过模块yumcopy模块实现时,那么建议不要使用shell或者command这样通用的命令模块。因为通用的命令模块不会根据具体操作的特点进行状态判断,所以当没有必要再重新执行的时候,它还是会重新执行一遍。

    • 支持<>|;&

      --- 
      - hosts: server1
        tasks:
          - name: Test shell
            shell: echo "test1" > ~/testDir/test1 && echo "test2" > ~/testDir/test2
      
    • 调用脚本

      ---
      
      - hosts: server1
        tasks:
          - shell: ~/test.sh >> somelog.txt
      

      在执行命令之前,我们可以改变工作目录,并且仅在文件somelog.txt不存在时执行命令,除此之外,还可以指定用bash运行命令:

      ---
      
      - hosts: server1
        tasks:
          - shell: ~/test.sh >> somelog.txt
            args:
              chdir: ~/testDir
              creates: somelog.txt
              executable: /bin/bash
      

    command模块

    在远程节点上执行命令。和shell模块类似,但不支持<>|;&等操作,其它的大抵都是相似的。

    总结

    Ansible提供了非常多的常用模块,我们可以使用ansible-doc -l命令查看这些模块。这篇文章只是总结了几个用的频率更高一点的,对于这里总结的常用模块,我们需要做到“手到擒来”,熟练到上手就能写的地步,大家需要在理解的基础上,多上手写,多练习。在今后的工作中多用这些常用的模块来提升自己的工作效率。

    夜,又静了!

    2019年9月29日,于内蒙古呼和浩特。

  • 相关阅读:
    [翻译]理解offsetWidth,clientWidth,scrollWidth以及Height
    [翻译]Chrome控制台API参考
    前端最新面试题
    前端面试题HTML+CSS
    css代码优化的12个技巧
    重构、标准、布局
    跨域的场景及跨域方式
    ajax
    那些我们该知道的数组操作
    全国最新行政区划省市区三级数据表(2018年9月),可直接用Python处理后导入数据库
  • 原文地址:https://www.cnblogs.com/vipygd/p/11625142.html
Copyright © 2011-2022 走看看