当前位置:Gxlcms > Python > Python利用ansible分发处理任务

Python利用ansible分发处理任务

时间:2021-07-01 10:21:17 帮助过:75人阅读

其实对python熟悉的人都可以自己用paramiko来写任务的分发系统,再结合gevent的协程就能实现异步的处理。

如果只想用工具的朋友可以使用一些工具,类似{puppet,saltstack,fabric,ansible,chef}等,其实这些工具的都是很好用的,不过于学习的成本,我建议大家使用ansible,这个模块封装的不错,功能也很齐全。

我们首先先安装ansible把

代码如下:

pip install ansible #其实我建议大家用ubuntu的系统,ubuntu的系统对开源的东西都支持的很好,而且apt的功能要比yum强不少。

代码如下:

mkdir -p /etc/ansible/ #给ansible创建一个配置文件的目录

  1. more hosts
  2. [Web]
  3. 192.168.6.210:22 ansible_ssh_user=root ansible_ssh_pass=123
  4. [Dubbo+Zookeeper]
  5. 192.168.6.212:22 ansible_ssh_user=root ansible_ssh_pass=123
  6. [Mysql]
  7. 192.168.6.213:22 ansible_ssh_user=root ansible_ssh_pass=123

如果你的机器没有做无密码访问,那么就在后面加上密码吧,如果你的SSH端口做过改动,那么请在IP后面加上端口号。如果有报错的话,你先安装一下apt-get install sshpass

做完上面这些准备工作,我们的ansible就可以运行了

  1. ansible Boss+Merchant+Web -m shell -a "hostname;ip a" 这里的Boss+Merchant+Web是我在hosts文件中定义的主机组 -m后面是接的模块 -a 就、后面是索要执行的命令
  2. 192.168.6.210 | success | rc=0 >>
  3. Pay-Boss+Merchant+Web
  4. 1: lo: <loopback,up,lower_up> mtu 16436 qdisc noqueue
  5. link/loopback 00:00:00:00:00:00 brd 00:00:00:00:00:00
  6. inet 127.0.0.1/8 scope host lo
  7. 2: eth0: <broadcast,multicast,up,lower_up> mtu 1500 qdisc pfifo_fast qlen 1000
  8. link/ether 00:0c:29:96:06:4e brd ff:ff:ff:ff:ff:ff
  9. inet 192.168.6.210/24 brd 192.168.6.255 scope global eth0
  10. </broadcast,multicast,up,lower_up></loopback,up,lower_up>

模块的信息可以从官网的教程下仔细查看,反正我一般都用shell。。。

现在来玩玩playbook,其实就是把命令保存到文件中,再执行,也就是一回事,不必非要用这个东西,我们自己也能写代码来封装这些命令

  1. mkdir -p /etc/ansible/playbooks
  2. touch boss.yml
  3. more boss.yml
  4. - hosts : Boss+Merchant+Web hosts 文件中的主机组
  5. remote_user : root
  6. tasks :
  7. - name : update_boss 任务代号
  8. shell : source /etc/profile;whoami;uptime;cat /etc/issue 模块+命令
  9. # shell : echo "xxxxxxxxxxxxxxxxx"

执行

  1. ansible-playbook boss.yml
  2. __________________________
  3. < PLAY [Boss+Merchant+Web] >
  4. --------------------------
  5. \ ^__^
  6. \ (oo)\_______
  7. (__)\ )\/\
  8. ||----w |
  9. || ||
  10. _________________
  11. < GATHERING FACTS >
  12. -----------------
  13. \ ^__^
  14. \ (oo)\_______
  15. (__)\ )\/\
  16. ||----w |
  17. || ||
  18. ok: [192.168.6.210]
  19. ___________________
  20. < TASK: update_boss >
  21. -------------------
  22. \ ^__^
  23. \ (oo)\_______
  24. (__)\ )\/\
  25. ||----w |
  26. || ||
  27. changed: [192.168.6.210]
  28. ____________
  29. < PLAY RECAP >
  30. ------------
  31. \ ^__^
  32. \ (oo)\_______
  33. (__)\ )\/\
  34. ||----w |
  35. || ||
  36. 192.168.6.210 : ok=2 changed=1 unreachable=0 failed=0

这个是结果,不过这个 cowsay是怎么打印出来的,我了个去,这是什么情况?

利用-vvvv来查看具体的执行情况

  1. ansible Boss+Merchant+Web -m shell -a "hostname;ip a" -vvvv
  2. <192.168.6.210> ESTABLISH CONNECTION FOR USER: root
  3. <192.168.6.210> REMOTE_MODULE command hostname;ip a #USE_SHELL
  4. <192.168.6.210> EXEC sshpass -d6 ssh -C -tt -vvv -o ControlMaster=auto -o ControlPersist=60s -o ControlPath="/root/.ansible/cp/ansible-ssh-%h-%p-%r" -o GSSAPIAuthentication=no -o PubkeyAuthentication=no -o ConnectTimeout=10 192.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'
  5. <192.168.6.210> PUT /tmp/tmpRfkD3R TO /root/.ansible/tmp/ansible-tmp-1435819148.95-1730630738440/command
  6. <192.168.6.210> EXEC sshpass -d6 ssh -C -tt -vvv -o ControlMaster=auto -o ControlPersist=60s -o ControlPath="/root/.ansible/cp/ansible-ssh-%h-%p-%r" -o GSSAPIAuthentication=no -o PubkeyAuthentication=no -o ConnectTimeout=10 192.168.6.210 /bin/sh -c 'LANG=en_US.UTF-8 LC_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/null 2>&1'
  7. 192.168.6.210 | success | rc=0 >>
  8. Pay-Boss+Merchant+Web
  9. 1: lo: <loopback,up,lower_up> mtu 16436 qdisc noqueue
  10. link/loopback 00:00:00:00:00:00 brd 00:00:00:00:00:00
  11. inet 127.0.0.1/8 scope host lo
  12. 2: eth0: <broadcast,multicast,up,lower_up> mtu 1500 qdisc pfifo_fast qlen 1000
  13. link/ether 00:0c:29:96:06:4e brd ff:ff:ff:ff:ff:ff
  14. inet 192.168.6.210/24 brd 192.168.6.255 scope global eth0
  15. </broadcast,multicast,up,lower_up></loopback,up,lower_up>

类似于debug。

以上所述就是本文的全部内容了,希望大家能够喜欢。

人气教程排行