关于ansbile
YAML语法规则
规则一:缩进(一个缩进两空格,注意一定不用tab)
规则二:冒号(每个冒号后一定要有空格)
规则三:短横线 - (短横线后面要空格)
编写案例
ansible-playbook --syntax-check cron.yml #剧本检查语法方法
ansible-playbook -C cron.yml #-C模拟执行剧本
ansible-playbook cron.yml #执行剧本
ansible基于密钥管理
vim /etc/ansible/hosts
... 在文件最后添加 ...
[opop]
172.16.1.5 ansible_ssh_user=root ansible_ssh_pass=123456
172.16.1.6 ansible_ssh_user=root ansible_ssh_pass=123456
172.16.1.7 ansible_ssh_user=root ansible_ssh_pass=123456
ansible语法

注:该脚本中的变量不是标准的,请注意.....
该文档中是2台机器做的实验(都是CensOS7.4.1708)
192.168.1.201
192.168.1.202
vim ~/ansible.sh
#!/bin/bash
read -p "对端用户名(尽可能为同一个用户): " User
read -p "对端IP(多个以空格隔开): " D_IP
yum -y install https://dl.fedoraproject.org/pub/epel/epel-release-latest-7.noarch.rpm
yum -y install ansible python-pip expect
ssh-keygen -t rsa -P '' -f ~/.ssh/id_rsa
for i in $D_IP;do
/usr/bin/expect <<-EOF
set timeout 10
spawn ssh-copy-id $User@$i
expect {
"\(yes/no\)" { send "yes\r"; exp_continue }
"*password:" { send "aaaaaa\r" }
}
expect eof
EOF
done
注:实验中的6个a是所有机器的root对应的密码
执行脚本:
sh ~/ansible.sh

测试:



简单的Playbook:


卸载:
[root@kvm2 ~]# ansible all -m shell -a "yum -y remove tree"
第二种传公钥的方式(适合批量)
#!/bin/bash
read -p "对端用户名(尽可能为同一个用户): " User
read -p "对端IP(多个以空格隔开): " D_IP
yum -y install sshpass
for i in $D_IP;do
sshpass -p "aaaaaa" ssh-copy-id -o StrictHostKeyChecking=no $User@$i #批量发送公钥
# sshpass -p "aaaaaa" scp /etc/passwd $User@$i:~ #上传文件
# sshpass -p "aaaaaa" ssh $Usert@$i 'df -h' #远程执行命令
# sshpass -p "aaaaaa" scp $User@$i:~/opopop.jpg /tmp #下载文件
done
注:sshpass也支持以文件的形式读取密码具体的操作后期会跟上
关于ansbile的更多相关文章
- ansbile Tags && Block
Tags 官网示例:https://docs.ansible.com/ansible/2.6/user_guide/playbooks_tags.html 编写执行playbook的时候,每次修改完y ...
- 关于ansbile工具的shell、command、script、raw模块的区别和使用场景
command模块 [执行远程命令] [root@node1 ansible]# ansible testservers -m command -a 'uname -n' script模块 [在远程主 ...
- 让ansbile和docker愉快的在一起
引自: http://cloud.51cto.com/art/201510/494328.htm
- Ansbile实战经验
一.相关用法: 1.执行shell 获取web组里得eth0接口信息 ansible web -a "ifconfig eth0" 2.执行ifconfig eth0 命令,ans ...
- ansible 自动化(3)
批量执行playbooks 远程批量命令执行的另外一种方式是用playbooks:这里是playbooks的官方文档:http://docs.ansible.com/playbooks.html这里有 ...
- 拿到新机器,进行初始化和部署Nginx的过程
1. 在/etc/ansbile/hosts中添加主机init 2. 在sysinit.yml中修改要初始化的机器: hosts: init 3. 设置不检查key export ANS ...
- 使用ansible批量管理远程服务器
使用ansible批量管理远程服务器 背景 本地需要管理远程的一批服务器,主要执行以下任务: 1) 将本地的文件复制到远端所有服务器: 2) 需要在远程服务器中执行一个个命令: 远端服务器路径并非完全 ...
- Ansible学习总结(1)
---恢复内容开始--- 1. Ansible概述 ansible是新出现的自动化运维工具,基于Python开发,集合了众多运维工具(puppet.cfengine.chef.func.fabric) ...
- 服务器批量管理软件ansible安装以及配置
1.yum安装(管理主机以及被管理主机都需要安装) yum install epel-release yum install ansible 2.配置管理主机 vim /etc/ansible/hos ...
随机推荐
- Asp.Net MVC4 使用Unity 实现依赖注入
项目创建参考 上一篇 <<Asp.Net MVC5 使用Unity 实现依赖注入>>, 不同的是这里是 Unity.MVC4 装好后会出现 然后示例说在这里写对应关系 ...
- git 清除所有历史记录
有些时候,git 仓库累积了太多无用的历史更改,导致 clone 文件过大.如果确定历史更改没有意义,可以采用下述方法清空历史, 1) 先 clone 项目到本地目录 (以名为 mylearning ...
- Some ArcGIS Tools
在矢量叠加,即将同一区域.同一比例尺的两组或两组以上的多边形要素的数据文件进行叠加产生一个新的数据层,其结果综合了原来图层所具有的属性.矢量叠加操作分为:交集(Intersect).擦除(Erase) ...
- emplace_back() 和 push_back 的区别
在引入右值引用,转移构造函数,转移复制运算符之前,通常使用push_back()向容器中加入一个右值元素(临时对象)的时候,首先会调用构造函数构造这个临时对象,然后需要调用拷贝构造函数将这个临时对象放 ...
- php的lareval框架配置出错
前两天,在学习php的 lareval 框架时,从官网上下载完lareval的安装包后,按照网上的配置教程一点一点的配置完后,当点击public 文件运行时就出现一个让我很头痛的问题,我自己外加两个大 ...
- python 示例代码1
第一章 python基础一 在此不再赘述为什么学习python这门编程,网上搜索一箩筐.我在此仅说一句python的好,用了你就会爱上它. 本python示例代码1000+带你由浅入深的了解pyth ...
- socket 测试工具java
SocketTest.jar http://sockettest.sourceforge.net/
- Java nio 理解
Java nio 称为Java new IO ,对Java io而言的.他有两个主要的概念:缓存.通道. 在程序中,数据的来源或写入,要么网络.要么硬盘.所有通道分为:文件通道.TCP通道.UDP通道 ...
- BZOJ2330 糖果[差分约束方案+spfa?/tarjan]
以往对于差分约束理解不是太深,导致这题屡次被坑,在此记录一下细节的理解. 差分约束实际上就是利用了spfa的一个特性:只要有$dis_y>dis_x+w_{x,y}$就松弛,直到所有边关系都满足 ...
- keil中使用Astyle格式化你的代码的方法-keil4 keil5通用
简介:在给RTT 提交代码,需要符合RT-Thread 的代码规范,本文简单介绍如何使用Astyle 格式化为符合RTT要求的代码风格. 关于Astyle Astyle 的全称是Artistic St ...