自動化運維工具 Ansible


學習Ansible的系列文章

  • Ansible 介紹
  • Ansible 架構
  • Ansible 安裝
  • Ansible 配置文件及參數
  • Ansible 常用模塊
  • Ansible playbook

1. Ansible 介紹

Ansible 是一個配置管理和應用部署工具,只需要通過 ssh 訪問服務器或設備即可實現批量系統配置、程序部署、運行命令等功能。

Ansible 是基於模塊工作的,本身沒有批量部署的能力,真正具有部署能力的是 Ansible 所運行的模塊。

Ansible 的優點:

  • 模塊化: 調用特定的模塊完成特定的功能;
  • 輕量級: 無需在客戶端安裝 agent,更新時,只需在操作機上進行一次更新即可;
  • 分布式: ansible 不需要啟動服務,作為一個工具可以輕松的實現分布式擴展;
  • 支持編排: 批量任務可以寫成劇本進行編排,不用分發到遠程即可執行;

2. Ansible 架構

 

 Ansible 的基本架構:

  1.  Connection Plugins: 連接主機和被管理端;
  2.  Core Modules: Ansible 執行命令的內置核心模塊;
  3.  Custom Modules: 根據需求編寫的定制化模塊;
  4.  Plugins: 對模塊功能進行補充,如連接插件、循環插件等;
  5.  Playbooks: 任務劇本,將多個任務定義在劇本中,由 Ansible 根據順序依次執行;
  6.  Host Inventory: Ansible 管理主機的清單,inventory 一般存放在 /etc/ansible/hosts 路徑下;
  7.  Ansible: 組合 Inventory、 Inventory、 Plugins 等的工具,為核心執行命令工具;

3. Ansible 安裝

Ansible 有三種安裝方式:

1. yum 安裝: 

 yum -y install ansible wget -O /etc/yum.repos.d/epel.repo 

 

2. pip 安裝:

 pip install ansible 

 

3. github 安裝:

git clone git://github.com/ansible/ansible.git --recursive
cd ./ansible
make rpm
sudo rpm -Uvh ./rpm-build/ansible-*.noarch.rpm

 

4. Ansible 配置文件及參數

          常用配置文件或命令                                                          描述                                  
                        /etc/ansible/ansible.cfg             主配置文件,配置ansible工作特性
                           /etc/ansible/hosts             主機清單
                          /etc/ansible/roles/             存放角色的目錄
                         /usr/bin/ansible             主程序,臨時命令執行工具
                        /usr/bin/ansible-doc             查看配置文檔,模塊功能查看工具
                       /usr/bin/ansible-playbook             定制自動化任務,編排劇本工具
                      /usr/bin/ansible-pull             遠程執行命令的工具

ansible 常用參數說明

  • ansible_ssh_host: 連接的遠程主機名;
  • ansible_ssh_port: ssh 端口號,如果不是默認的端口號,則通過此變量設置;
  • ansible_ssh_user: 默認的 ssh 用戶名;
  • ansible_ssh_private_key_file: ssh 使用的密鑰文件,適用於通過密鑰登陸,而不通過 ssh 代理登陸的情況;
  • inventory_dir: 存放 Ansible inventory host 文件的目錄路徑名;
  • playbook_dir : 含有 playbook 基礎目錄的路徑名;

 

5. Ansible 常用模塊

ping

功能: 嘗試連接到主機,ping 通則返回 pong 。

command

功能: 遠程執行命令,如果 ansible 不指定模塊時,默認使用 command 模塊。

shell

功能: 遠程執行命令,類似於 command 。

copy

功能: 復制文件或目錄到遠程節點,默認覆蓋目標文件,源地址為 src , 目的地址為 dest 。

file

功能: 設置遠程節點文件的文件屬性。其中, mode 參數定義文件或目錄的權限。 path 定義文件或目錄的路徑,為必選項。

setup

功能: 收集遠程主機的信息,playbook 中的參數 gather_facts 就與該模塊有關,后續 playbook 做介紹。

fail

功能: 自定義消息失敗,在 playbook 中一般與 參數 when 結合使用。

script

功能: script 模塊使得我們可以在遠程主機上執行 ansible 管理主機的腳本,而腳本一直存在於 ansible 管理主機本地,不需要手動拷貝到遠程主機后再執行。 

6. Ansible playbook

Ansible playbook 采用 yaml 語言編寫, playbook 的第一行 “---” 符號表示這是一個 yaml 文件。

playbook 的工作流程如下圖所示:

playbook 參數

hosts: hosts 行的內容是一個或多個組主機的 patterns ;

remote_user: 遠程執行任務的賬戶名;

tasks: 任務集,由多個 task 組成;

until: until 是一個條件表達式,如果滿足條件循環結束;

retry:retry 是重試的次數;

delay:延遲時間;

local_action: Ansible 默認只會對控制機器執行操作,local_action 參數使得 ansible 對本機執行操作;

ansible playbook 變量
  1.  ansible setup facts  遠程主機的所有變量都可直接調用, setup 模塊就是用來獲取遠程主機的相關信息的,要使用被管理主機的 ansible 元數據信息即 facts ,需要在playbook 中將gather_facts參數設為 yes 。facts 信息包括 主機名、遠端主機發行版、IP地址、CPU 數等等信息,該信息可作為變量供后續的 task 使用。

  2.  ansible hosts 中定義的變量,分為普通變量和公共變量,普通變量在主機組中主機單獨定義,優先級高於公共變量。

  3. 通過命令行指定變量,優先級最高。

  4. 在 playbook 中定義變量:

  5. vars_file 指定變量文件。

  6. 在 role 中定義。

  7. 通過 {{ variable_name }} 調用變量,且變量名前后必須有空格。例如,  file_contents: "{{ lookup('file', 'configuration.json') }}"  將 configuration.json 文件的內容讀入到變量file_contents中。 node_type_prefix: "{{ vnf_name|lower }} 將變量 vnf_name 通過過濾器 lower 裝換為小寫存入變量 node_type_prefix 中。

  8. register 注冊變量,把某一條任務執行的結果保存下來,在接下來的任務中調用該變量或者用該變量做判斷:

    將 task execute script at local host 的執行結果存入變量 host_data_json 中,在任務 fail ansible 中使用該變量中的 stderr 進行判斷該任務會不會出錯。

    host_data_json 變量如下圖 localhost => 右邊的結構體所示,注意使用該結構體的 rc 參數進行判斷也是可以的,即 host_data_json.rc == 0:

 

簡單的 playbook 例子:

---
- hosts: [any]
  remote_user: "root"
  gather_facts: yes
  vars:
    number: "1"
  tasks:
  - name: ping the OAM
    ping:
  - name: ping the local host
    local_action: ping
  - name: change the mode of file
    local_action: file path=/tmp/test_mode.sh mode=0777
  - name: execute script at local host
    local_action: command /bin/bash /tmp/test_mode.sh 1 2
    register: host_data_json
  - name: fail ansible
    local_action: fail msg="can't run ansible playbook"
    when: host_data_json.stderr != ""

 

  

(完)

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM