设为首页 收藏本站
查看: 1230|回复: 0

[经验分享] Ansible自动化运维工具介绍

[复制链接]
累计签到:1 天
连续签到:1 天
发表于 2016-12-15 09:15:28 | 显示全部楼层 |阅读模式
本帖最后由 qddf 于 2016-12-15 09:16 编辑

  • 介绍


    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。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
   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模块安装
1
2
3
4
5
6
7
   wget https://pypi.python.org/packages ... crypto-2.6.1.tar.gz
   
   tar xvzf pycrypto-2.6.1.tar.gz
   
   cd pycrypto-2.6.1
   
   python setup.py install



  (3)、PyYAML模块安装
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
   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 ... /PyYAML-3.11.tar.gz
     
   tar xvzf PyYAML-3.11.tar.gz
     
   cd PyYAML-3.11
     
   python setup.py install



  (4)、setuptools模块安装
1
2
3
4
5
6
7
   wget
   
   tar xvzf setuptools-7.0.tar.gz
   
   cd setuptools-7.0
   
   python setup.py install



  (5)、Jinja2模块安装
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
   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模块安装
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
   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模块安装
1
2
3
4
5
6
7
   wget
   
   tar xvzf simplejson-3.6.5.tar.gz
   
   cd simplejson-3.6.5
   
   python setup.py install



  (8)、ansible安装
1
2
3
4
5
6
7
   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中生成密钥
1
2
3
4
5
6
7
8
9
   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配置
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
    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)、批量使用命令
1
    ansible storm_cluster -m command -a 'date'  #  如下图



    QQ截图20161215091542.png
   # 通过这个命令可以直接将两个测试环境的时间都显示出来,success 表示成功执行了。command

    此参数表示“在远程主机上执行命令”。

    如此可以将date命令,换成/usr/local/tomcat/bin/./shutdown.sh等命令。

  (2)、copy     #  复制文件到远程文件   
1
2
3
4
      ansible storm_cluster -m copy -a "\
      src=/alidata/www/WEB-INF1214.zip\
      dest=/alidata/www/WEB-INF1214.zip\
      owner=root group=root backup=yes";     #  如下图



    QQ截图20161215091603.png

    查看测试环境192.168.1.126是否存在这个文件,如下图:
    QQ截图20161215091609.png
    src:被复制到远程主机的本地文件,可以是绝对路径,也可以是相对路径。
    owner:文件所有者
    group:文件所属用户组
    dest:复制到远程的文件。必填项
    mode:文件权限。如文件为755权限,mode="0755"即可。

  (3)、远程查看文件内容   
1
     [iyunv@localhost /]# ansible storm_cluster -m command -a "cat /1.txt"    #  如下图



    QQ截图20161215091616.png

  (4)、还有很多模块可以使用,实现批量系统配置,批量程序部署、批量运行命令。

     http://docs.ansible.com/ansible/modules_by_category.html  # 更多的模块请查看此链接


   


运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-314530-1-1.html 上篇帖子: ansible-playbook批量部署zabbix 下篇帖子: 利用ansible-playbook从测试环境获取tomcat中java项目新版本发布...
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表