Python利用ansible分發(fā)處理任務
其實對python熟悉的人都可以自己用paramiko來寫任務的分發(fā)系統(tǒng),再結合gevent的協(xié)程就能實現(xiàn)異步的處理。
如果只想用工具的朋友可以使用一些工具,類似{puppet,saltstack,fabric,ansible,chef}等,其實這些工具的都是很好用的,不過于學習的成本,我建議大家使用ansible,這個模塊封裝的不錯,功能也很齊全。
我們首先先安裝ansible把
more hosts [Web] 192.168.6.210:22 ansible_ssh_user=root ansible_ssh_pass=123 [Dubbo+Zookeeper] 192.168.6.212:22 ansible_ssh_user=root ansible_ssh_pass=123 [Mysql] 192.168.6.213:22 ansible_ssh_user=root ansible_ssh_pass=123
如果你的機器沒有做無密碼訪問,那么就在后面加上密碼吧,如果你的SSH端口做過改動,那么請在IP后面加上端口號。如果有報錯的話,你先安裝一下apt-get install sshpass
做完上面這些準備工作,我們的ansible就可以運行了
ansible Boss+Merchant+Web -m shell -a "hostname;ip a" 這里的Boss+Merchant+Web是我在hosts文件中定義的主機組 -m后面是接的模塊 -a 就、后面是索要執(zhí)行的命令 192.168.6.210 | success | rc=0 >> Pay-Boss+Merchant+Web 1: lo: <LOOPBACK,UP,LOWER_UP> mtu 16436 qdisc noqueue link/loopback 00:00:00:00:00:00 brd 00:00:00:00:00:00 inet 127.0.0.1/8 scope host lo 2: eth0: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc pfifo_fast qlen 1000 link/ether 00:0c:29:96:06:4e brd ff:ff:ff:ff:ff:ff inet 192.168.6.210/24 brd 192.168.6.255 scope global eth0
模塊的信息可以從官網(wǎng)的教程下仔細查看,反正我一般都用shell。。。
現(xiàn)在來玩玩playbook,其實就是把命令保存到文件中,再執(zhí)行,也就是一回事,不必非要用這個東西,我們自己也能寫代碼來封裝這些命令
mkdir -p /etc/ansible/playbooks touch boss.yml more boss.yml - hosts : Boss+Merchant+Web hosts 文件中的主機組 remote_user : root tasks : - name : update_boss 任務代號 shell : source /etc/profile;whoami;uptime;cat /etc/issue 模塊+命令 # shell : echo "xxxxxxxxxxxxxxxxx"
執(zhí)行
ansible-playbook boss.yml __________________________ < PLAY [Boss+Merchant+Web] > -------------------------- \ ^__^ \ (oo)\_______ (__)\ )\/\ ||----w | || || _________________ < GATHERING FACTS > ----------------- \ ^__^ \ (oo)\_______ (__)\ )\/\ ||----w | || || ok: [192.168.6.210] ___________________ < TASK: update_boss > ------------------- \ ^__^ \ (oo)\_______ (__)\ )\/\ ||----w | || || changed: [192.168.6.210] ____________ < PLAY RECAP > ------------ \ ^__^ \ (oo)\_______ (__)\ )\/\ ||----w | || || 192.168.6.210 : ok=2 changed=1 unreachable=0 failed=0
這個是結果,不過這個 cowsay是怎么打印出來的,我了個去,這是什么情況?
利用-vvvv來查看具體的執(zhí)行情況
ansible Boss+Merchant+Web -m shell -a "hostname;ip a" -vvvv <192.168.6.210> ESTABLISH CONNECTION FOR USER: root <192.168.6.210> REMOTE_MODULE command hostname;ip a #USE_SHELL <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' <192.168.6.210> PUT /tmp/tmpRfkD3R TO /root/.ansible/tmp/ansible-tmp-1435819148.95-1730630738440/command <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' 192.168.6.210 | success | rc=0 >> Pay-Boss+Merchant+Web 1: lo: <LOOPBACK,UP,LOWER_UP> mtu 16436 qdisc noqueue link/loopback 00:00:00:00:00:00 brd 00:00:00:00:00:00 inet 127.0.0.1/8 scope host lo 2: eth0: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc pfifo_fast qlen 1000 link/ether 00:0c:29:96:06:4e brd ff:ff:ff:ff:ff:ff inet 192.168.6.210/24 brd 192.168.6.255 scope global eth0
類似于debug。
以上所述就是本文的全部內(nèi)容了,希望大家能夠喜歡。
相關文章
Java中MultipartFile與File互轉的實現(xiàn)
本文主要介紹了Java中MultipartFile與File互轉的實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2023-03-03Python使用random.shuffle()打亂列表順序的方法
今天小編就為大家分享一篇Python使用random.shuffle()打亂列表順序的方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-11-11Python控制臺實現(xiàn)交互式環(huán)境執(zhí)行
這篇文章主要介紹了Python程序如何在交互式環(huán)境中執(zhí)行,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下2020-06-06