自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

自動化運維工具之a(chǎn)nsible

運維 系統(tǒng)運維 自動化
ansible是新出現(xiàn)的運維工具是基于Python研發(fā)的糅合了眾多老牌運維工具的優(yōu)點實現(xiàn)了批量操作系統(tǒng)配置、批量程序的部署、批量運行命令等功能。

一、什么樣的情形需要批量部署

1、操作系統(tǒng)的安裝

常見的有collber,red hat satelite(redhat)系統(tǒng)專用。

2、操作系統(tǒng)的配置

常見的有cfengine,puppet,chef,func。其中puppet***

3、批量程序的部署

4、批量命令的運行查看狀態(tài)信息

二、ansible介紹

ansible的架構大致如下

1

ansible是新出現(xiàn)的運維工具是基于Python研發(fā)的糅合了眾多老牌運維工具的優(yōu)點實現(xiàn)了批量操作系統(tǒng)配置、批量程序的部署、批量運行命令等功能。

  1. 運維工具常見的工作模式  
  2. 1、agent模式: 基于ssl實現(xiàn)。代理工作在被監(jiān)控端。像puppet。  
  3. 2、agentless模式: 基于ssh服務實現(xiàn)工作在被監(jiān)控端。監(jiān)控端是ssh的客戶端。 

ansible是工作在agentless模式下具有冪等性。ansible在控制端只需要告訴監(jiān)控端的期望狀態(tài)就可以實現(xiàn)批量部署。

  1. 名詞解釋  
  2. 冪等性不會重復執(zhí)行相同的指令。例如不會重復安裝軟件  
  3. 期望狀態(tài)只需要告訴被監(jiān)控端的期望狀態(tài) 

ansible是基于模塊工作的ansible本身沒有批量部署的能力。真正具有批量部署的是ansible所運行的模塊ansible只是提供一種框架。架構包括

  • 連接插件connection plugins負責和被監(jiān)控端實現(xiàn)通信。

  • Host Inventory:指定操作的主機,是一個配置文件里面定義監(jiān)控的主機

  • 各種模塊核心模塊command模塊自定義模塊

  • 借助于插件完成記錄日志郵件等功能

  • PlayBooks:劇本執(zhí)行多個任務時。并非必需可以讓節(jié)點一次性運行多個任務

三、ansible的基本使用

  1. 安裝軟件yum install ansible -y # 對應的軟件在 epel 倉庫中也可自己手動編譯  
  2. #源碼地址 https://pypi.python.org/packages/source/a/ansible/ansible-1.5.tar.gz 

2 

  1. 2、定義Host Inventory  
  2. # vim /etc/ansible/hosts  
  3. [webhosts]  
  4. 172.16.10.22 ansible_ssh_user=root ansible_ssh_pass=guoting 
  5. 172.16.10.33 ansible_ssh_user=root ansible_ssh_pass=guoting 
  6. 解釋  
  7. #ansible_ssh_user=root 是ssh登陸用戶  
  8. #ansible_ssh_pass=guoting 是ssh登陸密碼3、測試各個模塊  
  9. # 注意每個模塊的用法可以使用 ansible-doc MOD 來查看例如ansible-doc copy  
  10.    
  11. ansible命令最常用的用法  
  12. ansible <Host-partten> -m MOE -a 'MOD_ARV'所支持的模塊可以使用ansible-doc -l來查看 

ansible示例

1、查看時間信息。command、shell模塊

3

2、在控制端添加添加用戶。user模塊

4

3、實現(xiàn)ssh秘鑰認證。shell、copy模塊

6

#p#

此時就可以實現(xiàn)基于ssh秘鑰通信了此時/etc/ansible/hosts可以修改如下

  1. ###### /etc/ansible/hosts  
  2. [webhosts]  
  3. 172.16.10.22  
  4. 172.16.10.33 

7

4、安裝軟件和啟動服務。yum、service模塊

8

9

5、支持管道的命令。raw模塊,類似于shell模塊

wKioL1QaeV6QK9YUAACu77PB1cY454.jpg

四、YAML語言介紹

1、YAML簡介

  1. YAML是一個可讀性高的用來表達資料序列的格式。YAML參考了其他多種語言包括XML、C語言、Python、Perl以及電子郵件格式RFC2822等。Clark Evans在2001年在***發(fā)表了這種語言另外Ingy dtNet與Oren Ben-Kiki也是這語言的共同設計者。  
  2. YAML Ain't Markup Language即YAML不是XML。不過在開發(fā)的這種語言時YAML的意思其實是"Yet Another Markup Language"仍是一種標記語言。其特性  
  3. YAML的可讀性好  
  4. YAML和腳本語言的交互性好  
  5. YAML使用實現(xiàn)語言的數(shù)據(jù)類型  
  6. YAML有一個一致的信息模型  
  7. YAML易于實現(xiàn)  
  8. YAML可以基于流來處理  
  9. YAML表達能力強擴展性好  
  10.    
  11. 更多的內容及規(guī)范參見http://www.yaml.org。  
  12.    
  13. ##########################YAML語法  
  14.    
  15. YAML的語法和其他高階語言類似并且可以簡單表達清單、散列表、標量等數(shù)據(jù)結構。其結構Structure通過空格來展示序列Sequence里的項用"-"來代表  
  16. Map里的鍵值對用":"分隔。YAML文件擴展名通常為.yaml或者.yml。下面是一個示例。  
  17.    
  18. name: John Smith  
  19. age: 41gender: Male  
  20. spouse:  
  21. name: Jane Smith  
  22. age: 37  
  23. gender: Female  
  24. children:  
  25. - name: Jimmy Smith  
  26. age: 17  
  27. gender: Male  
  28. - name: Jenny Smith  
  29. age 13  
  30. gender: Female  
  31.    
  32. YAML 2 個重要的結構組成部分list和directory  
  33. ################################# list  
  34.    
  35. 列表的所有元素均使用“-”打頭例如  
  36. # A list of tasty fruits  
  37. - Apple  
  38. - Orange  
  39. - Strawberry  
  40. - Mango  
  41.    
  42. ##############################dictionary  
  43.    
  44. 字典通過key與valuef進行標識例如  
  45. ---  
  46. # An employee record  
  47. name: Example Developer  
  48. job: Developer  
  49. skill: Elite  
  50.    
  51. 也可以將key:value放置于{}中進行表示例如  
  52. ---  
  53. # An employee record  
  54. {name: Example Developer, job: Developer, skill: Elite}  
  55.    
  56. 多個映射關系組成一個字典一個列表可以包含多個字典。 

2、ymal中的變量

  1. ################################## 變量命名  
  2. 變量名僅能由字母、數(shù)字和下劃線組成且只能以字母開頭。  
  3.    
  4. ################################## facts  
  5. facts是由正在通信的遠程目標主機發(fā)回的信息這些信息被保存在ansible變量中。要獲取指定的遠程主機所支持的所有facts可使用如下命令進行  
  6. # ansible hostname -m setup 這個命令可以獲得被監(jiān)控端主機的各種信息將這些信息得到后保存到變量中。  
  7.    
  8. ################################ 自定義變量  
  9. 在 yaml 中可以使用vars關鍵字來定義變量  
  10. vars:  
  11. var_name: value  
  12.    
  13. ############################# 變量的引用  
  14. {{ var_name }}  
  15.    
  16.    
  17. ########################### 特殊的變量迭代  
  18. 當有需要重復性執(zhí)行的任務時可以使用迭代機制。其使用格式為將需要迭代的內容定義為item變量引用并通過with_items語句來指明迭代的元素列表即可。  
  19.    
  20. #######################################示例  
  21. 例如在被控端添加 2 個用戶  
  22.    
  23. 方式1一般做法  
  24. - name: add user testuser1  
  25. user: name=testuser1 state=present groups=wheel 
  26. - name: add user testuser2  
  27. user: name=testuser2 state=present groups=wheel 
  28.    
  29. 方式2使用變量方式  
  30. - name: add several users  
  31. vars:  
  32. user1: testuser1  
  33. user2: testuser2  
  34. user: name={{ user1 }} state=present groups=wheel 
  35. user: name={{ user2 }} state=present groups=wheel 
  36.    
  37. 方式3使用迭代方式  
  38. - name: add several users  
  39. user: name={{ item }} state=present groups=wheel 
  40. with_items:   
  41. - testuser1   
  42. - testuser2  
  43. 事實上with_items中可以使用元素還可為hashes例如  
  44. - name: add several users  
  45. user: name={{ item.name }} state=present groups={{ item.groups }}  
  46. with_items:  
  47. - { name: 'testuser1', groups: 'wheel' }  
  48. - { name: 'testuser2', groups: 'root' } 

3、Inentory文件的格式

  1. inventory文件遵循INI文件風格中括號中的字符為組名??梢詫⑼粋€主機同時歸并到多個不同的組中此外當如若目標主機使用了非默認的SSH端口還可以在主機名稱之后使用冒號加端口號來標明。  
  2.    
  3. [webservers]  
  4. www1.magedu.com:2222  
  5. www2.magedu.com  
  6. [dbservers]  
  7. db1.magedu.com  
  8. db2.magedu.com  
  9. db3.magedu.com  
  10.    
  11. 如果主機名稱遵循相似的命名模式還可以使用列表的方式標識各主機例如  
  12. [webservers]  
  13. www[01:50].example.com  
  14. [databases]  
  15. db-[a:f].example.com  
  16.    
  17. #################### 主機變量  
  18. 可以在inventory中定義主機時為其添加主機變量以便于在playbook中使用。例如  
  19. [webservers]  
  20. www1.magedu.com http_port=80 maxRequestsPerChild=808 
  21. www2.magedu.com http_port=303 maxRequestsPerChild=909 
  22.    
  23. ################### 組變量  
  24. 組變量是指賦予給指定組內所有主機上的在playbook中可用的變量。例如  
  25.    
  26. [webservers]  
  27. www1.magedu.com  
  28. www2.magedu.com  
  29.    
  30. [webservers:vars]  
  31. ntpntp_server=ntp.magedu.com  
  32. nfsnfs_server=nfs.magedu.com  
  33.    
  34. ################## 組嵌套  
  35. inventory中組還可以包含其它的組并且也可以向組中的主機指定變量。不過這些變量只能在ansible-playbook中使用而ansible不支持。例如  
  36.    
  37. [apache]  
  38. httpd1.magedu.com  
  39. httpd2.magedu.com  
  40.    
  41. [nginx]  
  42. ngx1.magedu.com  
  43. ngx2.magedu.com  
  44.    
  45. [webservers:children]  
  46. apache  
  47. nginx  
  48.    
  49. [webservers:vars]  
  50. ntpntp_server=ntp.magedu.com  
  51.    
  52. ######################### inventory參數(shù)  
  53.    
  54. ansible基于ssh連接inventory中指定的遠程主機時還可以通過參數(shù)指定其交互方式常用的參數(shù)如下所示  
  55. ansible_ssh_host # 要連接的主機名  
  56. ansible_ssh_port # 端口號默認是22  
  57. ansible_ssh_user # ssh連接時默認使用的用戶名  
  58. ansible_ssh_pass # ssh連接時的密碼  
  59. ansible_sudo_pass # 使用sudo連接用戶是的密碼  
  60. ansible_ssh_private_key_file # 秘鑰文件如果不想使用ssh-agent管理時可以使用此選項  
  61. ansible_shell_type # shell的類型默認sh  
  62. #########################################################################################  
  63. ansible的循環(huán)機制還有更多的高級功能具體請參見官方文檔http://docs.ansible.com/playbooks_loops.html。 

#p#

4、playbooks

  1. playbook是由一個或多個“play”組成的列表。play的主要功能在于將事先歸并為一組的主機裝扮成事先通過ansible中的task定義好的角色。  
  2. 從根本上來講所謂task無非是調用ansible的一個module。將多個play組織在一個playbook中即可以讓它們聯(lián)同起來按事先編排的機制同唱一臺大戲。  
  3.    
  4. ###########################playbook基礎組件  
  5. 1、Hosts和Users  
  6.    
  7. playbook中的每一個play的目的都是為了讓某個或某些主機以某個指定的用戶身份執(zhí)行任務。  
  8. hosts用于指定要執(zhí)行指定任務的主機其可以是一個或多個由冒號分隔主機組。  
  9. remote_user則用于指定遠程主機上的執(zhí)行任務的用戶。  
  10.    
  11. 不過remote_user也可用于各task中。也可以通過指定其通過sudo的方式在遠程主機上執(zhí)行任務其可用于play全局或某任務。  
  12. 此外甚至可以在sudo時使用sudo_user指定sudo時切換的用戶。  
  13.    
  14. - hosts: webnodes  
  15. remote_user: mageedu  
  16. tasks:  
  17. - name: test connection ping:  
  18. remote_user: mageedu sudo: yes  
  19.    
  20. 2、任務列表和action  
  21. play的主體部分是task list。task list中的各任務按次序逐個在hosts中指定的所有主機上執(zhí)行即在所有主機上完成***個任務后再開始第二個。  
  22. 在運行自下而下某playbook時如果中途發(fā)生錯誤所有已執(zhí)行任務都將回滾因此在更正playbook后重新執(zhí)行一次即可。  
  23. task的目的是使用指定的參數(shù)執(zhí)行模塊而在模塊參數(shù)中可以使用變量。模塊執(zhí)行是冪等的這意味著多次執(zhí)行是安全的因為其結果均一致。  
  24. 每個task都應該有其name用于playbook的執(zhí)行結果輸出建議其內容盡可能清晰地描述任務執(zhí)行步驟。如果未提供name則action的結果將用于輸出。  
  25.    
  26. 定義task的可以使用“action: module options”或“module: options”的格式推薦使用后者以實現(xiàn)向后兼容。  
  27. 如果action一行的內容過多也中使用在行首使用幾個空白字符進行換行。  
  28.    
  29. tasks:  
  30. - name: make sure apache is running  
  31. service: name=httpd state=running 
  32.    
  33. 在眾多模塊中只有command和shell模塊僅需要給定一個列表而無需使用“key=value”格式例如  
  34. tasks:  
  35. - name: disable selinux  
  36. command: /sbin/setenforce 0如果命令或腳本的退出碼不為零可以使用如下方式替代  
  37. tasks:  
  38. - name: run this command and ignore the result  
  39. shell: /usr/bin/somecommand || /bin/true  
  40. 或者使用ignore_errors來忽略錯誤信息  
  41. tasks:  
  42. - name: run this command and ignore the result  
  43. shell: /usr/bin/somecommand  
  44. ignore_errors: True   
  45.    
  46. 3、handlers  
  47.    
  48. 用于當關注的資源發(fā)生變化時采取一定的操作。  
  49.    
  50. “notify”這個action可用于在每個play的***被觸發(fā)這樣可以避免多次有改變發(fā)生時每次都執(zhí)行指定的操作取而代之僅在所有的變化發(fā)生完成后一次性地執(zhí)行指定操作。在notify中列出的操作稱為handler也即notify中調用handler中定義的操作。  
  51.    
  52. - name: template configuration file  
  53. template: src=template.j2 dest=/etc/foo.conf  
  54. notify:  
  55. - restart memcached  
  56. - restart apache   
  57.    
  58. handler是task列表這些task與前述的task并沒有本質上的不同。  
  59.    
  60. handlers:  
  61. - name: restart memcached  
  62. service: name=memcached state=restarted 
  63. - name: restart apache  
  64. service: name=apache state=restarted 

5、tags

  1. tags用于讓用戶選擇運行或路過playbook中的部分代碼。ansible具有冪等性因此會自動跳過沒有變化的部分即便如此有些代碼為測試其確實沒有發(fā)生變化的時間依然會非常地長。此時如果確信其沒有變化就可以通過tags跳過此些代碼片斷。  
  2.    
  3. 示例基于playbooks實現(xiàn)web服務的部署  
  4. 1、提供好Inventory文件  
  5. # /etc/ansible/hosts基于秘鑰認證  
  6. [webhosts]  
  7. 172.16.10.22  
  8. 172.16.10.33  
  9.    
  10. 2、編輯 palybooks 劇本  
  11. # vim /root/web.yaml  
  12. - name: web service  
  13. remote_user: root  
  14. hosts: webhosts  
  15. vars:  
  16. packages: httpd  
  17. tasks:  
  18. - name: install httpd yum: name={{ packages }} state=present 
  19. tags: install  
  20. - name: configuration httpd  
  21. copy: src=/root/httpd.conf dest=/etc/httpd/conf/httpd.conf  
  22. tags: conf  
  23. notify:  
  24. - restart httpd  
  25. - name: service httpd start  
  26. service: name=httpd enabled=no state=started 
  27. tags: start  
  28. - name: add centos and hadoop user  
  29. user: name={{ item }} state=absent 
  30. tags: adduser  
  31. with_items:  
  32. - centos  
  33. - hadoop  
  34. handlers:  
  35. - name: restart httpd  
  36. service: name=httpd state=restarted 
  37.    
  38. 3、準備好配置文件  
  39. 將web的配置放到指定目錄 src=/root/httpd.conf  
  40.    
  41. 4、開始部署  
  42. ansible-playbooks /root/web.yml 

結果示例

11

查看端口

12

此時如果配置文件發(fā)生變化

13

至此基本使用配置完成。

博文地址:http://guoting.blog.51cto.com/8886857/1553446

責任編輯:牛小雨 來源: 51CTO
相關推薦

2017-03-22 16:31:30

Linux運維自動化ansible

2017-03-22 18:30:44

Linux運維自動化ansible

2015-10-08 10:55:23

云服務自動化運維 ANSIBLE

2014-08-04 10:10:35

IT運維自動化運維

2013-04-16 14:55:21

自動化運維Puppet實戰(zhàn)

2022-07-29 14:39:17

Ansible運維工具

2015-03-09 11:10:14

運維

2015-10-09 13:14:10

clip自動化運維工具

2015-06-24 10:42:19

云計算運維自動化運維ANSIBLE

2012-05-05 21:48:43

puppet自動化運維

2010-08-12 17:39:07

網(wǎng)站運維自動化管理

2012-05-05 22:27:46

puppet自動化運維

2020-12-11 10:20:33

Ansible運維軟件包

2020-04-30 15:00:17

運維Ansible自動化

2012-05-05 21:28:44

2013-04-11 17:31:28

運維自動化Cobbler

2012-10-22 14:54:48

2020-07-21 15:53:18

戴爾

2025-01-03 16:47:02

Ansible自動化運維DevOps

2012-05-05 21:03:35

puppet自動化運維
點贊
收藏

51CTO技術棧公眾號