介绍
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中 [storm_cluster] 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)、远程查看文件内容
[root@localhost /]# 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了。.