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、总体架构

ansible下载源 ansible源码安装详解_python


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、任务执行流程


ansible下载源 ansible源码安装详解_开发工具_02


说明:

(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 username@192.168.1.50(远程主机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下载源 ansible源码安装详解_运维_03

  

如果使用 ansible -h 出现报错,如下:

ansible下载源 ansible源码安装详解_开发工具_04

解决方法:

这种问题一般是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

出现报错,内容如下:

ansible下载源 ansible源码安装详解_开发工具_05

解决方法:

参考: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”【进行公钥验证】,后续无需再次输入。



转载于:https://blog.51cto.com/wutengfei/1973792