ansible基本使用
ansible介绍
基础概念
ansible是个配置管理工具,可以批量处理一些任务。ansible只需要依赖ssh即可使用,而不需要在受管主机上安装客户端工具。
ansible具有幂等性,即以结果为导向。比如,当我们拉取文件到本地时,如果本地有该文件则不再拉取,如果本地没有该文件则拉取。
使用ansible需要满足两个基本条件:
- ansible所在的主机可以通过ssh连接到受管主机;
- 受管主机的信息已经添加到ansible的管理清单中。
安装配置
安装
首先使用pip可以安装ansible
sudo pip install ansible
安装方法有多种,可参考: https://ansible-tran.readthedocs.io/en/latest/docs/intro_installation.html
基于密码连接配置
ansible的管理清单文件是/etc/ansible/hosts
在该文件底部加上:
192.168.0.45 ansible_port=22 ansible_user=root ansible_ssh_pass=123456
ansible_port:端口号
ansible_user:用户名
ansible_ssh_pass:密码
然后就可以使用命令了,如ansible 192.168.0.45 -m ping
使用ip地址比较麻烦,我们可以为主机指定别名
test ansible_host=192.168.0.45 ansible_port=22 ansible_user=root ansible_ssh_pass=123456
然后就可以使用别名进行连接,ansible test -m ping
基于密钥连接配置
修改配置文件为
192.168.0.45 ansible_port=22
使用别名时改为
test ansible_host=192.168.0.45 ansible_port=22
当有多个密钥时可以使用ssh-agent进行管理,也可以在配置中通过ansible_ssh_private_key_file指定连接主机使用的密钥。
清单配置详解
INI格式
以上介绍的都是对一个主机执行命令,实际上可以对多台机器同时进行
ansible all -m ping
上面的命令是对配置文件中所有的机器执行ping命令,由此得到启发,对某一部分机器执行相同的命令,所以就需要对机器进行分组。
[A]
192.168.0.45
192.168.0.46
[B]
192.168.0.47
所以可以对某一个组内的机器执行同一个命令
ansible A -m ping
当ip地址连续时也可以采用如下方式
[A]
192.168.0.[45:46]
同样的,如果是域名中某个字母是连续的也可以采用类似的方式
[A]
suraer-a.book.net
suraer-b.book.net
[A]
suraer-[a:b].book.com
当组之间有包含关系时,还可以使用子组的方式,如下
[A]
192.168.0.45
[B]
192.168.0.46
[C:children]
[A]
[B]
等价于
[A]
192.168.0.45
[B]
192.168.0.46
[C]
192.168.0.45
192.168.0.46
YAML格式
# YAML格式
all:
hosts:
192.168.0.45
192.168.0.46
# 对应的INI配置
192.168.0.45
192.168.0.46
采用YAML格式有两个要注意的地方:
- 各级之间采用一个空格递进,不能使用tab键
- 分组需要用hosts关键字
下面举两个栗子说明YAML格式与INI格式之间的转换关系:
# INI格式
192.168.0.47
[A]
192.168.0.45
[B]
192.168.0.46
# YAML格式
all:
hosts:
192.168.0.47
children:
A:
hosts:
192.168.0.45
B:
hosts:
192.168.0.46
# INI格式
[A]
192.168.0.45
[B]
192.168.0.46
[C:children]
[A]
[B]
# YAML格式
all:
children:
C:
children:
A:
hosts:
192.168.0.45
B:
hosts:
192.168.0.46
YAML格式同样可以使用别名,如下:
# INI格式
192.168.0.45
test ansible_host=192.168.0.46 ansible_port=22
192.168.0.47
# YAML格式
all:
hosts:
192.168.0.45
test:
ansible_host: 192.168.0.46
ansible_port: 22
192.168.0.47
注意,上面的冒号后面一定要有空格。
ansible模块
在前面的例子中,我们都是使用ping模块,实际上ansible有许多模块,可以使用如下命令查看那ansible有哪些模块:
ansible-doc -l
查看具体模块的详细使用方法,使用如下命令:
ansible-doc -s fetch
查看了命令就可以对照参数进行使用了,比如将A组中的所有主机的/etc/fstab文件拉取到本地:
ansible A -m fetch -a "src=/etc/fstab dest=/test/ansible"
上面命令-m表示使用那个模块,-a表示使用的参数,上面例子中使用了两个参数src和dest。
查看更多模块参考: http://docs.ansible.com/ansible/latest/modules_by_category.html
ansible基本使用的更多相关文章
- 如何利用ansible callback插件对执行结果进行解析
最近在写一个批量巡检工具,利用ansible将脚本推到各个机器上执行,然后将执行的结果以json格式返回来. 如下所示: # ansible node2 -m script -a /root/pyth ...
- 《Ansible权威指南》笔记(2)——Inventory配置
四.Inventory配置ansible通过Inventory来定义主机和组,使用时通过-i指定读取,默认/etc/ansible/hosts.可以存在多个Inventory,支持动态生成.1.定义主 ...
- useful Ansible commands
This article includes some useful Ansible commands. I will try to write blogs by English. You may wa ...
- 《Ansible权威指南》笔记(4)——Playbook
七.Playbook1.语法特性如下:(1)"---"首行顶格开始(2)#号注释(3)缩进统一,不同的缩进代表不同的级别,缩进要对齐,空格和tab不能混用(4)区别大小写,键值对k ...
- 《Ansible权威指南》笔记(3)——Ad-Hoc命令集,常用模块
五.Ad-Hoc命令集1.Ad-Hoc命令集通过/usr/bin/ansible命令实现:ansible <host-pattern> [options] -v,--verbose ...
- 《Ansible权威指南》笔记(1)——安装,ssh密钥登陆,命令
2016-12-23 读这本<Ansible权威指南>学习ansible,根据本书内容和网上的各种文档,以及经过自己测试,写出以下笔记.另,这本书内容很好,但印刷错误比较多,作者说第二版会 ...
- 自动化运维工具ansible部署以及使用
测试环境master 192.168.16.74webserver1 192.168.16.70webserver2 192.168.16.72安装ansiblerpm -Uvh http://ftp ...
- Ansible Ubuntu 安装部署
一.安装: $ sudo apt-get install ansible 二.配置: a.基本配置 $ cd /etc/ansible/ $ sudo cp hosts hosts_back 备份一个 ...
- Ansible 模块命令介绍
copy模块: 目的:把主控端/root目录下的a.sh文件拷贝到到指定节点上 命令:ansible 10.1.1.113 -m copy -a 'src=/root/a.sh dest=/tmp/' ...
- 用Vagrant和Ansible搭建持续交付平台
这是一个关于Vagrant的学习系列,包含如下文章: Vagrant入门 创建自己的Vagrant box 用Vagrant搭建Jenkins构建环境 用Vagrant和Ansible搭建持续交付平台 ...
随机推荐
- 理解字符串 Boyer-Moore 算法
作者: 阮一峰 上一篇介绍了 kmp算法 但是,它并不是效率最高的算法,实际采用并不多. 各种文本编辑器的"查找"功能(Ctrl+F),大多采用Boyer-Moore算法. Boy ...
- JavaScript遍历树结构
遍历 function parseTreeJson(treeNodes){ if(!treeNodes||!treeNodes.length)return; for(let i=0;i<tree ...
- android安装apk
* 安装apk */ private void installApk() { // 获取当前sdcard存储路径 File apkfile = new File(Environment.getE ...
- pgrep 和 pkill 使用小记
在停止指定进程时,经常使用如下命令: kill `ps aux | grep -w program_name | grep -v grep | awk '{print $2}'` 使用 pgrep 和 ...
- Python 把二进制mnist数据库转换为图片
mnist数据库可以通过caffe里的get_mnist.sh文件下载,路径是: caffe-master/data/mnist/get_mnist.sh,get_mnist.sh内容如下: #!/u ...
- 修改Sublime Text3 的侧边栏字体大小
修改Sublime Text3 的侧边栏字体大小 1. 安装”Package Control Package Control”,建议使用官方安装命令:https://sublime.wbond.net ...
- typedeifn typename
1.类型说明typedef 类型说明的格式为: typedef 类型 定义名; 类型说明只定义了一个数据类型的新名字而不是定义一种新的数据类型.定义名表示这个类型的新名字. 例如: 用下面语句定义整 ...
- Java [Leetcode 383]Ransom Note
题目描述: Given an arbitrary ransom note string and another string containing letters from al ...
- matlab 与 modelsim 联调 cic抽取滤波器
注:本设计的参数为:D=2,R=5,N=3:时钟频率为50mhz,输入信号为有符号8位,根据公式bmax=bin+N*log(2,R*D):可以得到bmax=18: 1,cic抽取滤波器原理 网上资料 ...
- C#检测应用程序重复启动----函数检测(可以在多用户登录情况下检测)
上文是在网上找的检测程序重复运行的类,但是感觉不是很好用,而且还使用了API,似乎完全没有必要,于是晚上自己写了一个函数,经过测试,在多用户下仍然可以检测到程序的多次运行.当然,如果程序改了名字还是可 ...