Python利用ansible分发处理任务
其实对python熟悉的人都可以自己用paramiko来写任务的分发系统,再结合gevent的协程就能实现异步的处理。
如果只想用工具的朋友可以使用一些工具,类似{puppet,saltstack,fabric,ansible,chef}等,其实这些工具的都是很好用的,不过于学习的成本,我建议大家使用ansible,这个模块封装的不错,功能也很齐全。
我们首先先安装ansible把
pipinstallansible #其实我建议大家用ubuntu的系统,ubuntu的系统对开源的东西都支持的很好,而且apt的功能要比yum强不少。
mkdir-p/etc/ansible/ #给ansible创建一个配置文件的目录
morehosts [Web] 192.168.6.210:22ansible_ssh_user=rootansible_ssh_pass=123 [Dubbo+Zookeeper] 192.168.6.212:22ansible_ssh_user=rootansible_ssh_pass=123 [Mysql] 192.168.6.213:22ansible_ssh_user=rootansible_ssh_pass=123
如果你的机器没有做无密码访问,那么就在后面加上密码吧,如果你的SSH端口做过改动,那么请在IP后面加上端口号。如果有报错的话,你先安装一下apt-getinstallsshpass
做完上面这些准备工作,我们的ansible就可以运行了
ansibleBoss+Merchant+Web-mshell-a"hostname;ipa"这里的Boss+Merchant+Web是我在hosts文件中定义的主机组-m后面是接的模块-a就、后面是索要执行的命令 192.168.6.210|success|rc=0>> Pay-Boss+Merchant+Web 1:lo:<LOOPBACK,UP,LOWER_UP>mtu16436qdiscnoqueue link/loopback00:00:00:00:00:00brd00:00:00:00:00:00 inet127.0.0.1/8scopehostlo 2:eth0:<BROADCAST,MULTICAST,UP,LOWER_UP>mtu1500qdiscpfifo_fastqlen1000 link/ether00:0c:29:96:06:4ebrdff:ff:ff:ff:ff:ff inet192.168.6.210/24brd192.168.6.255scopeglobaleth0
模块的信息可以从官网的教程下仔细查看,反正我一般都用shell。。。
现在来玩玩playbook,其实就是把命令保存到文件中,再执行,也就是一回事,不必非要用这个东西,我们自己也能写代码来封装这些命令
mkdir-p/etc/ansible/playbooks touchboss.yml moreboss.yml -hosts:Boss+Merchant+Webhosts文件中的主机组 remote_user:root tasks: -name:update_boss任务代号 shell:source/etc/profile;whoami;uptime;cat/etc/issue模块+命令 #shell:echo"xxxxxxxxxxxxxxxxx"
执行
ansible-playbookboss.yml __________________________ <PLAY[Boss+Merchant+Web]> -------------------------- \^__^ \(oo)\_______ (__)\)\/\ ||----w| |||| _________________ <GATHERINGFACTS> ----------------- \^__^ \(oo)\_______ (__)\)\/\ ||----w| |||| ok:[192.168.6.210] ___________________ <TASK:update_boss> ------------------- \^__^ \(oo)\_______ (__)\)\/\ ||----w| |||| changed:[192.168.6.210] ____________ <PLAYRECAP> ------------ \^__^ \(oo)\_______ (__)\)\/\ ||----w| |||| 192.168.6.210:ok=2changed=1unreachable=0failed=0
这个是结果,不过这个 cowsay是怎么打印出来的,我了个去,这是什么情况?
利用-vvvv来查看具体的执行情况
ansibleBoss+Merchant+Web-mshell-a"hostname;ipa"-vvvv <192.168.6.210>ESTABLISHCONNECTIONFORUSER:root <192.168.6.210>REMOTE_MODULEcommandhostname;ipa#USE_SHELL <192.168.6.210>EXECsshpass-d6ssh-C-tt-vvv-oControlMaster=auto-oControlPersist=60s-oControlPath="/root/.ansible/cp/ansible-ssh-%h-%p-%r"-oGSSAPIAuthentication=no-oPubkeyAuthentication=no-oConnectTimeout=10192.168.6.210/bin/sh-c'mkdir-p$HOME/.ansible/tmp/ansible-tmp-1435819148.95-1730630738440&&echo$HOME/.ansible/tmp/ansible-tmp-1435819148.95-1730630738440' <192.168.6.210>PUT/tmp/tmpRfkD3RTO/root/.ansible/tmp/ansible-tmp-1435819148.95-1730630738440/command <192.168.6.210>EXECsshpass-d6ssh-C-tt-vvv-oControlMaster=auto-oControlPersist=60s-oControlPath="/root/.ansible/cp/ansible-ssh-%h-%p-%r"-oGSSAPIAuthentication=no-oPubkeyAuthentication=no-oConnectTimeout=10192.168.6.210/bin/sh-c'LANG=en_US.UTF-8LC_CTYPE=en_US.UTF-8/usr/bin/python/root/.ansible/tmp/ansible-tmp-1435819148.95-1730630738440/command;rm-rf/root/.ansible/tmp/ansible-tmp-1435819148.95-1730630738440/>/dev/null2>&1' 192.168.6.210|success|rc=0>> Pay-Boss+Merchant+Web 1:lo:<LOOPBACK,UP,LOWER_UP>mtu16436qdiscnoqueue link/loopback00:00:00:00:00:00brd00:00:00:00:00:00 inet127.0.0.1/8scopehostlo 2:eth0:<BROADCAST,MULTICAST,UP,LOWER_UP>mtu1500qdiscpfifo_fastqlen1000 link/ether00:0c:29:96:06:4ebrdff:ff:ff:ff:ff:ff inet192.168.6.210/24brd192.168.6.255scopeglobaleth0
类似于debug。
以上所述就是本文的全部内容了,希望大家能够喜欢。