• ansible一些基本操作


    一、介绍

    特性

    (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:可实现多级指挥。

    优点

    (1)、轻量级,无需在客户端安装agent,更新时,只需在操作机上进行一次更新即可;

    (2)、批量任务执行可以写成脚本,而且不用分发到远程就可以执行;

    (3)、使用python编写,维护更简单,ruby语法过于复杂;

    (4)、支持sudo。

    二、安装

    因为ansible已经被redhat收购,所以可以直接用yum安装,先通过yum list |grep ansible看一下yum源,然后安装

    yum install ansible ansible-doc -y

    安装好之后,通过ssh-keygen来创建密钥,把生成的公钥放到对应目标机器对应的用户下面。

    修改ansible配置文件,vim /etc/ansible/hosts,添加一个组(相当于是进行分组操作,如web、db组),组下面为对应机器ip或者主机名(需在/etc/hosts里面配置)

    三、ansible远程执行命令

    ansible testhost -m command -a "hostname" 

    PS:testhost 为定义的一个组(这个组下面所有机器都会执行),-m command 通过command这个模块来操作,-a "hostname"为操作的命令,也可以用shell来代替command

    shell模块,还支持远程执行命令并且带管道

    ansible testhost -m shell -a "cat /etc/passwd |wc -l"

    四、ansible拷贝文件或目录

    ansible testhost -m copy -a "src=/etc/passwd dest=/tmp/ansible/1.txt owner=root group=root mode=0755"

    PS:把文件分发到目标机器上面,如果目标机器不存在/tmp/ansible这个目录,则分发失败,如果存在则把passwd重命名为1.txt,如果dest=/tmp/ansible,则分发之后,文件名不变

    ansible testhost -m copy -a "src=/etc/ansible dest=/tmp/ansible owner=root group=root mode=0755"

    PS:把目录分发到目标机器上面,不管dest里面定义的ansible目录是否存在,都会把原目录放在该目录下面,相当于/tmp/ansible/ansible

    五、ansible远程执行脚本

    1.把脚本分发到各个机器上面去

    ansible testhost -m copy -a "src=/tmp/test.sh dest=/tmp/test.sh mode=0755"

    2.批量执行该shell脚本

    ansible testhost -m shell -a "/tmp/test.sh"

    六、ansible管理任务计划

    1.添加cron计划

    ansible testhost -m cron -a "name='test cron' job='/bin/touch /tmp/1.txt' minute=10 month=12"

    PS: 表示在crontab里面添加一条记录为:

    #Ansible:test cron
    10 * * 12 * /bin/touch /tmp/1.txt

    minute表示分钟,hour表示小时,day表示日期,month表示月份,weekday表示周,如果没写则默认为 *

    2.删除cron计划

    ansible testhost -m cron -a "name='test cron' state=absent"

    PS: 只能删除该crontab,不能修改,也不能自己crontab -e去修改,不然ansible会操作不了该crontab

    七、ansible安装、删除rpm包等管理

    ansible testhost -m yum -a "name=nginx state=installed"

    PS: 相当于yum intall nginx -y,state默认为installed,如果state=removed表示卸载该rpm包

    ansible testhost -m service -a "name=nginx state=started enabled=yes"

    PS:启动nginx服务,state可以为started/restarted/stopped/reloaded,enabled为yes表示开机启动

    8、ansible-doc

    1. 列出所有的模块

    ansible-doc -l

    2.查看指定模块的文档

    ansible-doc modulename
  • 相关阅读:
    UIStoryBoard 中修改控件borderColor
    iOS自定义AlertView 与 ActionSheet 遮罩提示+弹出动画
    iOS开发 UIWebView+JavaScript 交互总结
    【注入攻击】SQL注入(不完整总结)
    [内存溢出]栈溢出基础版
    [Windows驱动开发]之内存管理
    [找工作]程序员面试宝典【笔记】(part 1)
    [Windows安装]安装程序无法创建新的系统分区,也无法定位现有系统分区
    M1卡分析
    [逆向/壳]脱壳方法
  • 原文地址:https://www.cnblogs.com/654wangzai321/p/8045968.html
Copyright © 2020-2023  润新知