Python利用ansible分發(fā)處理任務(wù)
其實(shí)對(duì)python熟悉的人都可以自己用paramiko來(lái)寫(xiě)任務(wù)的分發(fā)系統(tǒng),再結(jié)合gevent的協(xié)程就能實(shí)現(xiàn)異步的處理。
如果只想用工具的朋友可以使用一些工具,類似{puppet,saltstack,fabric,ansible,chef}等,其實(shí)這些工具的都是很好用的,不過(guò)于學(xué)習(xí)的成本,我建議大家使用ansible,這個(gè)模塊封裝的不錯(cuò),功能也很齊全。
我們首先先安裝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
如果你的機(jī)器沒(méi)有做無(wú)密碼訪問(wèn),那么就在后面加上密碼吧,如果你的SSH端口做過(guò)改動(dòng),那么請(qǐng)?jiān)贗P后面加上端口號(hào)。如果有報(bào)錯(cuò)的話,你先安裝一下apt-get install sshpass
做完上面這些準(zhǔn)備工作,我們的ansible就可以運(yùn)行了
ansible Boss+Merchant+Web -m shell -a "hostname;ip a" 這里的Boss+Merchant+Web是我在hosts文件中定義的主機(jī)組 -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)的教程下仔細(xì)查看,反正我一般都用shell。。。
現(xiàn)在來(lái)玩玩playbook,其實(shí)就是把命令保存到文件中,再執(zhí)行,也就是一回事,不必非要用這個(gè)東西,我們自己也能寫(xiě)代碼來(lái)封裝這些命令
mkdir -p /etc/ansible/playbooks touch boss.yml more boss.yml - hosts : Boss+Merchant+Web hosts 文件中的主機(jī)組 remote_user : root tasks : - name : update_boss 任務(wù)代號(hào) 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
這個(gè)是結(jié)果,不過(guò)這個(gè) cowsay是怎么打印出來(lái)的,我了個(gè)去,這是什么情況?
利用-vvvv來(lái)查看具體的執(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。
以上所述就是本文的全部?jī)?nèi)容了,希望大家能夠喜歡。
相關(guān)文章
Java中MultipartFile與File互轉(zhuǎn)的實(shí)現(xiàn)
本文主要介紹了Java中MultipartFile與File互轉(zhuǎn)的實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2023-03-03Python使用random.shuffle()打亂列表順序的方法
今天小編就為大家分享一篇Python使用random.shuffle()打亂列表順序的方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2018-11-11Python控制臺(tái)實(shí)現(xiàn)交互式環(huán)境執(zhí)行
這篇文章主要介紹了Python程序如何在交互式環(huán)境中執(zhí)行,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-06-06跟老齊學(xué)Python之網(wǎng)站的結(jié)構(gòu)
本教程的最終目的就是教會(huì)大家如何使用Python制作網(wǎng)站,非常的詳盡,需要的朋友可以參考下2014-10-10pymongo實(shí)現(xiàn)多結(jié)果進(jìn)行多列排序的方法
這篇文章主要介紹了pymongo實(shí)現(xiàn)多結(jié)果進(jìn)行多列排序的方法,涉及Python排序的相關(guān)技巧,需要的朋友可以參考下2015-05-05