ansible1.7.2源碼安裝教程

ansible1.7.2源碼安裝教程


==========================================================================================

一、基礎介紹

==========================================================================================

1、簡介

ansible是新出現的自動化運維工具,基於Python開發,集合了衆多運維工具(puppetcfenginecheffuncfabric)的優點,實現了批量系統配置、批量程序部署、批量運行命令等功能。ansible是基於模塊工作的,本身沒有批量部署的能力。真正具有批量部署的是ansible所運行的模塊,ansible只是提供一種框架。主要包括:

(1)、連接插件connection plugins:負責和被監控端實現通信;

(2)host inventory:指定操作的主機,是一個配置文件裏面定義監控的主機;

(3)、各種模塊核心模塊、command模塊、自定義模塊;

(4)、藉助於插件完成記錄日誌郵件等功能;

(5)playbook:劇本執行多個任務時,非必需可以讓節點一次性運行多個任務。


2、總體架構

wKiom1Rsxz3ToUCAAAGROYAM3EI989.jpg


3、特性

(1)no agents:不需要在被管控主機上安裝任何客戶端;

(2)no server:無服務器端,使用時直接運行命令即可;

(3)modules in any languages:基於模塊工作,可使用任意語言開發模塊;

(4)yamlnot code:使用yaml語言定製劇本playbook

(5)ssh by default:基於SSH工作;

(6)strong multi-tier solution:可實現多級指揮。


4、優點
(1)
、輕量級,無需在客戶端安裝agent,更新時,只需在操作機上進行一次更新即可;
(2)
、批量任務執行可以寫成腳本,而且不用分發到遠程就可以執行;
(3)
、使用python編寫,維護更簡單,ruby語法過於複雜;
(4)
、支持sudo


5、任務執行流程

wKiom1Rsx2uQYJZ5AAJplY08vOQ976.jpg


說明:

(1)、以上內容大多是基於他人分享的基礎上總結而來,學習借鑑之用;

(2)、本次安裝基於 CentOS 6.7 系統環境。


==========================================================================================

二、Ansible基礎安裝與配置

==========================================================================================

1Ansible基礎安裝

(1)python2.7安裝

https://www.python.org/ftp/python/2.7.8/Python-2.7.8.tgz

# tar xvzf Python-2.7.8.tgz

# cd Python-2.7.8

# ./configure --prefix=/usr/local

# make --jobs=`grep processor /proc/cpuinfo | wc -l`

# make install


## python頭文件拷貝到標準目錄,以避免編譯ansible時,找不到所需的頭文件

# cd /usr/local/include/python2.7

# cp -a ./* /usr/local/include/


## 備份舊版本的python,並符號鏈接新版本的python

# cd /usr/bin

# mv python python2.6

# ln -s /usr/local/bin/python .


## 修改yum腳本,使其指向舊版本的python,已避免其無法運行

# vim /usr/bin/yum

#!/usr/bin/python  更改爲  #!/usr/bin/python2.6


(2)setuptools模塊安裝

https://pypi.python.org/packages/source/s/setuptools/setuptools-7.0.tar.gz

# tar xvzf setuptools-7.0.tar.gz

# cd setuptools-7.0

# python setup.py install


(3)pycrypto模塊安裝

https://pypi.python.org/packages/source/p/pycrypto/pycrypto-2.6.1.tar.gz

# tar xvzf pycrypto-2.6.1.tar.gz

# cd pycrypto-2.6.1

# python setup.py install


(4)PyYAML模塊安裝

http://pyyaml.org/download/libyaml/yaml-0.1.5.tar.gz

# tar xvzf yaml-0.1.5.tar.gz

# cd yaml-0.1.5

# ./configure --prefix=/usr/local

# make --jobs=`grep processor /proc/cpuinfo | wc -l`

# make install


https://pypi.python.org/packages/source/P/PyYAML/PyYAML-3.11.tar.gz

# tar xvzf PyYAML-3.11.tar.gz

# cd PyYAML-3.11

# python setup.py install


(5)Jinja2模塊安裝

https://pypi.python.org/packages/source/M/MarkupSafe/MarkupSafe-0.9.3.tar.gz

# tar xvzf MarkupSafe-0.9.3.tar.gz

# cd MarkupSafe-0.9.3

# python setup.py install


https://pypi.python.org/packages/source/J/Jinja2/Jinja2-2.7.3.tar.gz

# tar xvzf Jinja2-2.7.3.tar.gz 

# cd Jinja2-2.7.3

# python setup.py install


(6)paramiko模塊安裝

https://pypi.python.org/packages/source/e/ecdsa/ecdsa-0.11.tar.gz

# tar xvzf ecdsa-0.11.tar.gz

# cd ecdsa-0.11

# python setup.py install


https://pypi.python.org/packages/source/p/paramiko/paramiko-1.15.1.tar.gz

# tar xvzf paramiko-1.15.1.tar.gz

# cd paramiko-1.15.1

# python setup.py install


(7)simplejson模塊安裝

https://pypi.python.org/packages/source/s/simplejson/simplejson-3.6.5.tar.gz

# tar xvzf simplejson-3.6.5.tar.gz

# cd simplejson-3.6.5

# python setup.py install


(8)ansible安裝

https://github.com/ansible/ansible/archive/v1.7.2.tar.gz

# tar xvzf ansible-1.7.2.tar.gz

# cd ansible-1.7.2

# python setup.py install


2Ansible配置

(1)SSH免密鑰登錄設置

ansilbe採用ssh的方式管理節點,爲了方便管理,使用密鑰方式面密碼登陸被管理節點。
1、生成rsa格式密鑰(ansible主機上)
ssh-keygen -t rsa
2、把公鑰寫入到遠端主機(被管理機)的~/.ssh/authorized_keys,命令如下:
ssh-copy-id [email protected](遠程主機ip)
3、管理機設置默認遠程用戶
vim /etc/ansible/ansible.cfg
remote_user = username


(2)ansible配置

[wutengfei@iZ2547mxdm8Z examples]$ sudo mkdir -p /etc/ansible

[wutengfei@iZ2547mxdm8Z ~]$ cd /usr/local/ansible/ansible-1.7.2/examples/

[wutengfei@iZ2547mxdm8Z examples]$ sudo cp -rvf hosts /etc/ansible/

[wutengfei@iZ2547mxdm8Z examples]$ sudo cp -rvf ansible.cfg /etc/ansible/


## 主機組定義

# vim /etc/ansible/hosts

[test]

10.51.65.82


(3)、簡單測試

可以查看下ansible的版本,如果有正常的版本輸出,說明ansible安裝成功,如:

[wutengfei@iZ2547mxdm8Z ~]$ ansible --version

ansible 1.7.2

或者使用 ansible -h 也是可以判斷ansible是否安裝成功!如:

[wutengfei@iZ2547mxdm8Z ~]$ ansible -h|more

wKiom1nnBRvyvn6qAAJxjEK19Y8322.png  

如果使用 ansible -h 出現報錯,如下:

wKioL1nnArqB1o85AAPchTiQFRM980.png

解決方法:

這種問題一般是python在做完升級之後,沒在yum配置文件中重新指定python!

如:

## 修改yum腳本,使其指向舊版本的python,已避免其無法運行

# vim /usr/bin/yum

#!/usr/bin/python  更改爲  #!/usr/bin/python2.6


(3)、ansible命令測試


[wutengfei@iZ2547mxdm8Z ~]$ ansible test -m shell -a 'hostname' -o

出現報錯,內容如下:

wKioL1nnBIiB5NpvAAZ3M9xCRQc995.png

解決方法:

參考:http://www.it1352.com/544764.html

[wutengfei@iZ2547mxdm8Z ~]$ sudo vim /etc/ansible/hosts

修改:

[test]

 10.51.65.82 ansible_ssh_pass=被管理機密碼 ansible_ssh_user=被管理機賬戶

再次測試:

[wutengfei@iZ2547mxdm8Z ~]$ ansible test -m shell -a 'hostname' -o

10.51.65.82 | success | rc=0 | (stdout) iZkeo60dfag6bzZ

ok!可以啦!

[wutengfei@iZ2547mxdm8Z ~]$ ansible test -m ping

10.51.65.82 | success >> {

    "changed": false, 

    "ping": "pong"

}



說明:第一次運行時,需要輸入一下“yes”【進行公鑰驗證】,後續無需再次輸入。


發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章