ansible1.7.2源碼安裝教程
==========================================================================================
一、基礎介紹
1、簡介
ansible是新出現的自動化運維工具,基于Python開發,集合了衆多運維工具(puppet、cfengine、chef、func、fabric)的優點,實作了批量系統配置、批量程式部署、批量運作指令等功能。ansible是基于子產品工作的,本身沒有批量部署的能力。真正具有批量部署的是ansible所運作的子產品,ansible隻是提供一種架構。主要包括:
(1)、連接配接插件connection plugins:負責和被監控端實作通信;
(2)、host inventory:指定操作的主機,是一個配置檔案裡面定義監控的主機;
(3)、各種子產品核心子產品、command子產品、自定義子產品;
(4)、借助于插件完成記錄日志郵件等功能;
(5)、playbook:劇本執行多個任務時,非必需可以讓節點一次性運作多個任務。
2、總體架構
<a href="http://s3.51cto.com/wyfs02/M02/53/A7/wKiom1Rsxz3ToUCAAAGROYAM3EI989.jpg" target="_blank"></a>
3、特性
(1)、no agents:不需要在被管控主機上安裝任何用戶端;
(2)、no server:無伺服器端,使用時直接運作指令即可;
(3)、modules in any languages:基于子產品工作,可使用任意語言開發子產品;
(4)、yaml,not code:使用yaml語言定制劇本playbook;
(5)、ssh by default:基于SSH工作;
(6)、strong multi-tier solution:可實作多級指揮。
4、優點
(1)、輕量級,無需在用戶端安裝agent,更新時,隻需在操作機上進行一次更新即可;
(2)、批量任務執行可以寫成腳本,而且不用分發到遠端就可以執行;
(3)、使用python編寫,維護更簡單,ruby文法過于複雜;
(4)、支援sudo。
5、任務執行流程
<a href="http://s3.51cto.com/wyfs02/M01/53/A7/wKiom1Rsx2uQYJZ5AAJplY08vOQ976.jpg" target="_blank"></a>
說明:
(1)、以上内容大多是基于他人分享的基礎上總結而來,學習借鑒之用;
(2)、本次安裝基于 CentOS 6.7 系統環境。
二、Ansible基礎安裝與配置
1、Ansible基礎安裝
(1)、python2.7安裝
<a href="https://www.python.org/ftp/python/2.7.8/Python-2.7.8.tgz" target="_blank">https://www.python.org/ftp/python/2.7.8/Python-2.7.8.tgz</a>
# 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子產品安裝
<a href="https://pypi.python.org/packages/source/s/setuptools/setuptools-7.0.tar.gz" target="_blank">https://pypi.python.org/packages/source/s/setuptools/setuptools-7.0.tar.gz</a>
# tar xvzf setuptools-7.0.tar.gz
# cd setuptools-7.0
# python setup.py install
(3)、pycrypto子產品安裝
<a href="https://pypi.python.org/packages/source/p/pycrypto/pycrypto-2.6.1.tar.gz" target="_blank">https://pypi.python.org/packages/source/p/pycrypto/pycrypto-2.6.1.tar.gz</a>
# tar xvzf pycrypto-2.6.1.tar.gz
# cd pycrypto-2.6.1
(4)、PyYAML子產品安裝
<a href="http://pyyaml.org/download/libyaml/yaml-0.1.5.tar.gz" target="_blank">http://pyyaml.org/download/libyaml/yaml-0.1.5.tar.gz</a>
# tar xvzf yaml-0.1.5.tar.gz
# cd yaml-0.1.5
<a href="https://pypi.python.org/packages/source/P/PyYAML/PyYAML-3.11.tar.gz" target="_blank">https://pypi.python.org/packages/source/P/PyYAML/PyYAML-3.11.tar.gz</a>
# tar xvzf PyYAML-3.11.tar.gz
# cd PyYAML-3.11
(5)、Jinja2子產品安裝
<a href="https://pypi.python.org/packages/source/M/MarkupSafe/MarkupSafe-0.9.3.tar.gz" target="_blank">https://pypi.python.org/packages/source/M/MarkupSafe/MarkupSafe-0.9.3.tar.gz</a>
# tar xvzf MarkupSafe-0.9.3.tar.gz
# cd MarkupSafe-0.9.3
<a href="https://pypi.python.org/packages/source/J/Jinja2/Jinja2-2.7.3.tar.gz" target="_blank">https://pypi.python.org/packages/source/J/Jinja2/Jinja2-2.7.3.tar.gz</a>
# tar xvzf Jinja2-2.7.3.tar.gz
# cd Jinja2-2.7.3
(6)、paramiko子產品安裝
<a href="https://pypi.python.org/packages/source/e/ecdsa/ecdsa-0.11.tar.gz" target="_blank">https://pypi.python.org/packages/source/e/ecdsa/ecdsa-0.11.tar.gz</a>
# tar xvzf ecdsa-0.11.tar.gz
# cd ecdsa-0.11
<a href="https://pypi.python.org/packages/source/p/paramiko/paramiko-1.15.1.tar.gz" target="_blank">https://pypi.python.org/packages/source/p/paramiko/paramiko-1.15.1.tar.gz</a>
# tar xvzf paramiko-1.15.1.tar.gz
# cd paramiko-1.15.1
(7)、simplejson子產品安裝
<a href="https://pypi.python.org/packages/source/s/simplejson/simplejson-3.6.5.tar.gz" target="_blank">https://pypi.python.org/packages/source/s/simplejson/simplejson-3.6.5.tar.gz</a>
# tar xvzf simplejson-3.6.5.tar.gz
# cd simplejson-3.6.5
(8)、ansible安裝
<a href="https://github.com/ansible/ansible/archive/v1.7.2.tar.gz" target="_blank">https://github.com/ansible/ansible/archive/v1.7.2.tar.gz</a>
# tar xvzf ansible-1.7.2.tar.gz
# cd ansible-1.7.2
2、Ansible配置
(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
如果使用 ansible -h 出現報錯,如下:
<a href="https://s5.51cto.com/wyfs02/M02/A7/77/wKioL1nnArqB1o85AAPchTiQFRM980.png" target="_blank"></a>
解決方法:
這種問題一般是python在做完更新之後,沒在yum配置檔案中重新指定python!
如:
(3)、ansible指令測試
[wutengfei@iZ2547mxdm8Z ~]$ ansible test -m shell -a 'hostname' -o
出現報錯,内容如下:
<a href="https://s5.51cto.com/wyfs02/M00/A7/77/wKioL1nnBIiB5NpvAAZ3M9xCRQc995.png" target="_blank"></a>
[wutengfei@iZ2547mxdm8Z ~]$ sudo vim /etc/ansible/hosts
修改:
10.51.65.82 ansible_ssh_pass=被管理機密碼 ansible_ssh_user=被管理機賬戶
再次測試:
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”【進行公鑰驗證】,後續無需再次輸入。
本文轉自品鑒初心51CTO部落格,原文連結:http://blog.51cto.com/wutengfei/1973792,如需轉載請自行聯系原作者