yum安装ansible
先查看一下yum库中是否有ansible,我这里已经有ansible了,可以直接安装。
[root@www.wulaoer.org ~]# yum list|grep ansible ansible.noarch 2.4.2.0-2.el7 @extras ansible-doc.noarch 2.4.2.0-2.el7 extras centos-release-ansible26.noarch 1-3.el7.centos extras [root@www.wulaoer.org ~]# yum install ansible -y
这里如果没有ansible的yum包,需要自己下载。把本地的做个备份,重新下载一份http://mirrors.aliyun.com/repo/Centos-7.repo,然后yum安装。
创建秘钥
ansible是利用秘钥和客户端进行通信的,所以需要本地生成秘钥,然后把服务端生成的秘钥对推送到客户端,这样就可以不通过密码连接客户端了。
[root@www.wulaoer.org ~]# ssh-keygen -t rsa Generating public/private rsa key pair. Enter file in which to save the key (/root/.ssh/id_rsa): Created directory '/root/.ssh'. Enter passphrase (empty for no passphrase): Enter same passphrase again: Your identification has been saved in /root/.ssh/id_rsa. Your public key has been saved in /root/.ssh/id_rsa.pub. The key fingerprint is: SHA256:XpWIaGv/9zo4yMk9yo2OwEoTTVzNHrij5b67s0HeD+w root@www.wulaoer.org The key's randomart image is: +---[RSA 2048]----+ | .+ | | . ...+. . . | | o oo... o | | o .+.. . | | . .++.S . | | o.+.= . | | o o.oo*+ . | | . o .o==*= o | | . *BE.++.+. | +----[SHA256]-----+ [root@www.wulaoer.org ~]# ssh-copy-id -i root@10.211.55.142 /usr/bin/ssh-copy-id: INFO: Source of key(s) to be installed: "/root/.ssh/id_rsa.pub" The authenticity of host '10.211.55.142 (10.211.55.142)' can't be established. ECDSA key fingerprint is SHA256:LGzrjfZw6oo3ty986cCfuxMFDwQQysxaPYUnTnjlgxo. ECDSA key fingerprint is MD5:dc:f0:53:cc:e0:7b:75:b2:33:3b:08:5c:72:5c:3b:83. Are you sure you want to continue connecting (yes/no)? yes /usr/bin/ssh-copy-id: INFO: attempting to log in with the new key(s), to filter out any that are already installed /usr/bin/ssh-copy-id: INFO: 1 key(s) remain to be installed -- if you are prompted now it is to install the new keys root@10.211.55.142's password: Number of key(s) added: 1 Now try logging into the machine, with: "ssh 'root@10.211.55.142'" and check to make sure that only the key(s) you wanted were added. [root@www.wulaoer.org ~]# ssh root@10.211.55.142 Last login: Mon Mar 23 09:27:11 2020 from 10.211.55.1 [root@wulaoer01 ~]# exit
这里把秘钥推送到wulaoer01客户端上了,我这里使用了两个客户端,另一个就不在这里说了,和上面的一样,把IP修改一下即可。
配置ansible组
我们服务集群中有很多服务,每个服务的功能不一样,我们根据服务的集群进行分组,然后根据组来操作不同的集群。在ansible的配置文件中添加组信息,以便在操作的时候利用组来实现批量操作。
[root@www.wulaoer.org ~]# vim /etc/ansible/hosts ..................................... [wulaoer] 10.211.55.142 10.211.55.141 [root@www.wulaoer.org ~]# ansible wulaoer -m ping 10.211.55.141 | SUCCESS => { "changed": false, "ping": "pong" } 10.211.55.142 | SUCCESS => { "changed": false, "ping": "pong" }
ansible使用
ansible有很多参数,我们先看看ansible的参数的注解:
ansible <host-pattern> [-m module_name] [-a args] --version 显示版本 -m module 指定模块 -v -vv -vvv 更详细的过程 --list 显示主机列表 -k 输入提示的ssh密码,默认key验证 -K 输入提示的sudo密码 -C 只检查,不执行 -T 命令超时时间,默认10秒 -u 远程用户 -b 代替旧版sudo切换 HOST-PATTERN 匹配主机模式,如all表示所有主机 -m MOD_NAME 模块名 如:ping -a MOD_ARGS 模块执行的参数 -f FORKS 生成几个子进行程执行 -c CONNection 连接方式(default smart)
验证举例
我们已经知道了参数,也安装了ansible,那么我们看看ansible有哪些命令,这里注意ansible不支持管道符,如果需要的命令比较长,我们可以写成脚本,然后下载到客户端,使用ansible执行客户端的脚本。
[root@www.wulaoer.org ~]# ansible all -m shell -a "ifconfig|grep ens33" 10.211.55.142 | SUCCESS | rc=0 >> ens33: flags=4163<UP,BROADCAST,RUNNING,MULTICAST> mtu 1500 10.211.55.141 | SUCCESS | rc=0 >> ens33: flags=4163<UP,BROADCAST,RUNNING,MULTICAST> mtu 1500
获取客户端的IP地址,这里我的网卡名时ens33,如果自己执行需要修改一下网卡名。
[root@www.wulaoer.org ~]# ansible wulaoer -m shell -a "yum -y install gcc" [WARNING]: Consider using yum module rather than running yum 10.211.55.141 | SUCCESS | rc=0 >> 已加载插件:fastestmirror Loading mirror speeds from cached hostfile * base: mirrors.tuna.tsinghua.edu.cn * epel: mirrors.tuna.tsinghua.edu.cn * extras: mirrors.cn99.com * updates: mirrors.neusoft.edu.cn 软件包 gcc-4.8.5-39.el7.x86_64 已安装并且是最新版本 无须任何处理 10.211.55.142 | SUCCESS | rc=0 >> 已加载插件:fastestmirror Loading mirror speeds from cached hostfile * base: mirrors.tuna.tsinghua.edu.cn * extras: mirrors.tuna.tsinghua.edu.cn * updates: mirrors.tuna.tsinghua.edu.cn .........................................................
在客户端批量安装gcc,这里第一个客户已经安装了gcc,不过检查后安装客户端2的gcc
如果想在某一个服务中执行一个命令,首先要确认一下,这个服务已经加入到ansible的hosts中,才能执行ansible的命令。
[root@www.wulaoer.org ~]# ansible 10.211.55.142 -a 'pwd' 10.211.55.142 | SUCCESS | rc=0 >> /root
我们切换一下目录,然后查看一下路径地址
[root@www.wulaoer.org ~]# ansible wulaoer -m shell -a "cd /usr/local/ && pwd" 10.211.55.141 | SUCCESS | rc=0 >> /usr/local 10.211.55.142 | SUCCESS | rc=0 >> /usr/local
这里注意,两个命令不能分开执行,分开执行的后果就是,不会返回切换路径后的当前路径
[root@www.wulaoer.org ~]# ansible wulaoer -m shell -a "cd /usr/local/" 10.211.55.141 | SUCCESS | rc=0 >> 10.211.55.142 | SUCCESS | rc=0 >> [root@www.wulaoer.org ~]# ansible wulaoer -m shell -a "pwd" 10.211.55.141 | SUCCESS | rc=0 >> /root 10.211.55.142 | SUCCESS | rc=0 >> /root
下面尝试写一个脚本,然后在脚本里增加一些一下echo,之后执行这个脚本,看看返回结果。
[root@www.wulaoer.org ~]# ansible wulaoer -m shell -a "touch /usr/local/wulaoer.sh" [WARNING]: Consider using file module with state=touch rather than running touch 10.211.55.141 | SUCCESS | rc=0 >> 10.211.55.142 | SUCCESS | rc=0 >> [root@www.wulaoer.org ~]# ansible wulaoer -m shell -a 'bash /usr/local/wulaoer.sh' 10.211.55.142 | SUCCESS | rc=0 >> hello word 10.211.55.141 | SUCCESS | rc=0 >> hello word
我这里没有直接使用ansible利用vim命令来直接编辑脚本,我尝试了一下,不能在ansible中使用vim命令,所以我写好了脚本放在一个服务器中直接下载到本地,然后执行,如何下载的就不说了,上面就是执行脚本的命令。
ansible也有copy模块,cpoy文件,看下面的例子
[root@www.wulaoer.org ~]# ansible wulaoer -m copy -a 'src=/etc/fstab dest=/tmp/ backup=yes mode=0644' 10.211.55.142 | SUCCESS => { "changed": true, "checksum": "0885d28f151123592586ff1424028fc3b315ccc2", "dest": "/tmp/fstab", "gid": 0, "group": "root", "md5sum": "c734a591ecd3c0bcd8fb001ef32d4380", "mode": "0644", "owner": "root", "secontext": "unconfined_u:object_r:admin_home_t:s0", "size": 465, "src": "/root/.ansible/tmp/ansible-tmp-1584934407.37-280239806899447/source", "state": "file", "uid": 0 } 10.211.55.141 | SUCCESS => { "changed": true, "checksum": "0885d28f151123592586ff1424028fc3b315ccc2", "dest": "/tmp/fstab", "gid": 0, "group": "root", "md5sum": "c734a591ecd3c0bcd8fb001ef32d4380", "mode": "0644", "owner": "root", "secontext": "unconfined_u:object_r:admin_home_t:s0", "size": 465, "src": "/root/.ansible/tmp/ansible-tmp-1584934407.37-225612021007324/source", "state": "file", "uid": 0 }
我们也可以使用ansible进行交互
[root@www.wulaoer.org ~]# ansible-console Vault password: Welcome to the ansible console. Type help or ? to list commands. root@all (2)[f:5]$ pwd 10.211.55.142 | SUCCESS | rc=0 >> /root 10.211.55.141 | SUCCESS | rc=0 >> /root root@all (2)[f:5]$ list 10.211.55.142 10.211.55.141
ansible还可以使用copy模块,用来复制文件
[root@www.wulaoer.org ~]# ansible wulaoer -m copy -a 'src=/etc/fstab dest=/tmp/ backup=yes mode=0644' 10.211.55.142 | SUCCESS => { "changed": true, "checksum": "0885d28f151123592586ff1424028fc3b315ccc2", "dest": "/tmp/fstab", "gid": 0, "group": "root", "md5sum": "c734a591ecd3c0bcd8fb001ef32d4380", "mode": "0644", "owner": "root", "secontext": "unconfined_u:object_r:admin_home_t:s0", "size": 465, "src": "/root/.ansible/tmp/ansible-tmp-1584934407.37-280239806899447/source", "state": "file", "uid": 0 } 10.211.55.141 | SUCCESS => { "changed": true, "checksum": "0885d28f151123592586ff1424028fc3b315ccc2", "dest": "/tmp/fstab", "gid": 0, "group": "root", "md5sum": "c734a591ecd3c0bcd8fb001ef32d4380", "mode": "0644", "owner": "root", "secontext": "unconfined_u:object_r:admin_home_t:s0", "size": 465, "src": "/root/.ansible/tmp/ansible-tmp-1584934407.37-225612021007324/source", "state": "file", "uid": 0 }
以上就是使用yum安装ansible的方法,和利用ansible执行批量操作的命令。这里涉及到根据单个IP和服务器组执行批量命令。利用ansible组我们可以根据不同的服务执行不同的批量命令,也可以执行所有组的批量命令。
您可以选择一种方式赞助本站
支付宝扫一扫赞助
微信钱包扫描赞助
赏