Ansible自动化运维工具介绍
[*] 介绍
Ansible自动化运维工具,是基于Python开发的,可以实现批量系统配置,批量程序部署、批量运行命令等等。
ansible是基于模块工作的,本身没有批量部署的能力。真正具有批量部署的是ansible所运行的模块,ansible只是提供一种
主要包括:
(1)、连接插件connection plugins:负责和被监控端实现通信;
(2)、host inventory:指定操作的主机,是一个配置文件里面定义监控的主机;
(3)、各种模块核心模块、command模块、自定义模块;
(4)、借助于插件完成记录日志邮件等功能;
(5)、playbook:剧本执行多个任务时,非必需可以让节点一次性运行多个任务。
2. 环境介绍
有两台测试环境,IP地址为:192.168.1.126 192.168.1.127
测试环境中WEB服务,数据库服务,目录情况均为一致。WEB服务为:tomcat。数据库服务为mysql。
现想通过Ansible实现文件的copy,更新java代码,重新启动tomcat命令,重启mysql的命令等一些其
它命令。为了配合开发对功能的测试,需要多台测试环境,使用Ansible所运行的模块,实现批量系
统配置,批量程序部署,批量运行命令等。这样可以大大减少简单和重复性的操作。
3. 安装
(1)、python安装
# https://www.python.org/ftp/python/ 地址为:python官方下载地址,这里有各种版本的py
thon。
wget https://www.python.org/ftp/python/3.0/Python-3.0.tgz
tar zxvf Python-3.0.tgz
cd Python-3.0
./configure --prefix=/usr/local
make
make install
cd /usr/local/include/python3.0
cp -a ./* /usr/local/include/
(2)、pycrypto模块安装
wget 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
(3)、PyYAML模块安装
wget 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
make install
wget 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
(4)、setuptools模块安装
wget
tar xvzf setuptools-7.0.tar.gz
cd setuptools-7.0
python setup.py install
(5)、Jinja2模块安装
wget
tar xvzf MarkupSafe-0.9.3.tar.gz
cd MarkupSafe-0.9.3
python setup.py install
wget
tar xvzf Jinja2-2.7.3.tar.gz
cd Jinja2-2.7.3
python setup.py install
(6)、paramiko模块安装
wget
tar xvzf ecdsa-0.11.tar.gz
cd ecdsa-0.11
python setup.py install
wget
tar xvzf paramiko-1.15.1.tar.gz
cd paramiko-1.15.1
python setup.py install
(7)、simplejson模块安装
wget
tar xvzf simplejson-3.6.5.tar.gz
cd simplejson-3.6.5
python setup.py install
(8)、ansible安装
wget
tar xvzf ansible-1.7.2.tar.gz
cd ansible-1.7.2
python setup.py install
4. Ansible配置
(1)、SSH免秘钥登录# linux单向信任,在测试环境192.168.1.127中生成密钥
ssh -keygen -t rsa -P "" #生成公钥和私钥
cat /root/.ssh/id_rsa.pub >> /root/.ssh/authorized_keys
#需要将id_rsa.pub文件上传到测试环境192.168.1.126中,并执行命令
chmod 600 /root/.ssh/authorized_keys
# 在测试环境192.168.1.126中,执行命令。
(2)、ansible配置
mkdir -p /etc/ansible
vim /etc/ansible/ansible.cfg
#将如下的内容添加到ansible.cfg中
remote_port = 36000
private_key_file = /root/.ssh/id_rsa
#定义主机组
vim /etc/ansible/host
#将如下内容添加到host中
192.168.1.126
5. Ansible使用
Ansible已经配置完成,下面使用ansible命令查看192.168.1.126与192.168.1.127中的‘date‘命
令
(1)、批量使用命令
ansible storm_cluster -m command -a 'date'#如下图
# 通过这个命令可以直接将两个测试环境的时间都显示出来,success 表示成功执行了。command
此参数表示“在远程主机上执行命令”。
如此可以将date命令,换成/usr/local/tomcat/bin/./shutdown.sh等命令。
(2)、copy #复制文件到远程文件
ansible storm_cluster -m copy -a "\
src=/alidata/www/WEB-INF1214.zip\
dest=/alidata/www/WEB-INF1214.zip\
owner=root group=root backup=yes"; #如下图
查看测试环境192.168.1.126是否存在这个文件,如下图:
src:被复制到远程主机的本地文件,可以是绝对路径,也可以是相对路径。
owner:文件所有者
group:文件所属用户组
dest:复制到远程的文件。必填项
mode:文件权限。如文件为755权限,mode="0755"即可。
(3)、远程查看文件内容
# ansible storm_cluster -m command -a "cat /1.txt" #如下图
(4)、还有很多模块可以使用,实现批量系统配置,批量程序部署、批量运行命令。
http://docs.ansible.com/ansible/modules_by_category.html# 更多的模块请查看此链接
关于Ansible的相关介绍以及一些简单的功能进行介绍,欢迎大家进行补充。
在此感谢 http://sofar.blog.51cto.com/353572/1579894 原文章的帮助。虽然过程中有点坎
坷,最终还是可以使用Ansible了。.
页:
[1]