关于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 ...
随机推荐
- Jumpserver1.4.1安装
第1章 CentOS环境准备 Jumpserver官网: http://docs.jumpserver.org/zh/docs/step_by_step.html 测试推荐硬件 CPU: 64位双核处 ...
- LNMP安装与配置之CentOS7的安装。
LNMP与LAMP是我们常见的两种网站服务器架构.LNMP代表的就是Linux系统下Nginx+MySQL+PHP/Python,LAMP代表的则是Linux系统下Apache+MySQL+PHP/P ...
- 线上MYSQL同步报错故障处理总结(转)
前言 在发生故障切换后,经常遇到的问题就是同步报错,数据库很小的时候,dump完再导入很简单就处理好了,但线上的数据库都150G-200G,如果用单纯的这种方法,成本太高,故经过一段时间的摸索,总结了 ...
- chrome插件开发-notification API注意事项
1.win10系统,在系统设置里面,设置开启Google Chrome通知 2.iconUrl必须设置,且图片为ico格式
- +new Date是什么意思?
转载自:http://blog.csdn.net/abxn2002/article/details/53420816 JavaScript中可以在某个元素前使用 ‘+’ 号,这个操作是将该元素转换成N ...
- 如何阻止<a>标签默认行为和表单提交
阻止<a>标签默认行为 方式一 (通过return false) <!DOCTYPE html> <html> <head> <meta char ...
- java.sql.SQLException: Unknown column 'user0_.user_name' in 'field list' 报错问题
报错信息: java.sql.SQLException: Unknown column 'user0_.user_name' in 'field list'Query is: select user0 ...
- spark 三种数据集的关系(二)
一个Dataset是一个分布式的数据集,而且它是一个新的接口,这个新的接口是在Spark1.6版本里面才被添加进来的,所以要注意DataFrame是先出来的,然后在1.6版本才出现的Dataset,提 ...
- 【GDKOI2018】总结
前言 车祸现场... day1 T1:其实就是对于每个点的有用的时间点建一个点,然后连边,对于询问(x,y),从点(y,inf),往回走,能走到的最早的x的时间点就是答案. 比赛上用最后的一个多小时来 ...
- css实现翻面效果
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...