[Python]用python实现批量/并发处理
2012-11-21 13:46
411 查看
最近在学习python,感觉很不错,特别是实现批量/并发处理。实现起来非常方便,比shell方便很多。刚学python一个月,在这留个记录。下面分享一段代码。多提建议/意见~(QQ群交流:24967504)
需求:批量查看/对比线上服务器的状态情况,如uptime、df -h、MD5sum文件等等。本打算让执行命令通过传参进行、密码通过交互输入(3次不对退出)。后面再完善~~
#-*- coding: utf-8 -*-
#!/usr/bin/python
import paramiko
import threading
def ssh2(ip,username,passwd,cmd):
try:
ssh = paramiko.SSHClient()
ssh.set_missing_host_key_policy(paramiko.AutoAddPolicy())
ssh.connect(ip,22,username,passwd,timeout=5)
for m in cmd:
stdin,stdout,stderr = ssh.exec_command(m)
stdin.write("Y")
out = stdout.readlines()
for o in out:
print o,
print '[OK]%s' %(ip),
print '========================================================================='
ssh.close()
except:
print '[Error]%s' %(ip),
print '========================================================================='
def main():
cmd = ['uptime'] #执行命令
username = "root"
passwd = "密码"
threads = [4]
f = file('list.txt') #ip列表
while True:
ip = f.readline()
if len(ip) == 0:
break
a = threading.Thread(target=ssh2,args=(ip,username,passwd,cmd))
a.start()
f.close()
if __name__ == '__main__':
main()
执行结果:
[root@bw-vm-soft ~]# python ssh2.py
13:31:28 up 514 days, 7:28, 1 user, load average: 10.27, 9.44, 9.03
[OK]192.168.13.116
=========================================================================
13:31:28 up 514 days, 8:04, 1 user, load average: 5.99, 6.05, 6.46
[OK]192.168.13.117
=========================================================================
本文出自 “Richard Shen运维/架构” 博客,请务必保留此出处http://lxsym.blog.51cto.com/1364623/1065854
需求:批量查看/对比线上服务器的状态情况,如uptime、df -h、MD5sum文件等等。本打算让执行命令通过传参进行、密码通过交互输入(3次不对退出)。后面再完善~~
#-*- coding: utf-8 -*-
#!/usr/bin/python
import paramiko
import threading
def ssh2(ip,username,passwd,cmd):
try:
ssh = paramiko.SSHClient()
ssh.set_missing_host_key_policy(paramiko.AutoAddPolicy())
ssh.connect(ip,22,username,passwd,timeout=5)
for m in cmd:
stdin,stdout,stderr = ssh.exec_command(m)
stdin.write("Y")
out = stdout.readlines()
for o in out:
print o,
print '[OK]%s' %(ip),
print '========================================================================='
ssh.close()
except:
print '[Error]%s' %(ip),
print '========================================================================='
def main():
cmd = ['uptime'] #执行命令
username = "root"
passwd = "密码"
threads = [4]
f = file('list.txt') #ip列表
while True:
ip = f.readline()
if len(ip) == 0:
break
a = threading.Thread(target=ssh2,args=(ip,username,passwd,cmd))
a.start()
f.close()
if __name__ == '__main__':
main()
执行结果:
[root@bw-vm-soft ~]# python ssh2.py
13:31:28 up 514 days, 7:28, 1 user, load average: 10.27, 9.44, 9.03
[OK]192.168.13.116
=========================================================================
13:31:28 up 514 days, 8:04, 1 user, load average: 5.99, 6.05, 6.46
[OK]192.168.13.117
=========================================================================
本文出自 “Richard Shen运维/架构” 博客,请务必保留此出处http://lxsym.blog.51cto.com/1364623/1065854
相关文章推荐
- [Python]用python实现批量/并发处理(完善版)
- python实现指定目录下批量文件的单词计数:并发版本
- python实现指定目录下批量文件的单词计数:并发版本
- 网络库多线程并发处理实现
- python实现批量重命名文件
- Python学习笔记(六)多进程实现并发服务器
- Python socket实现处理多个连接
- 机器学习算法的Python实现 (3):CART决策树与剪枝处理
- Python中的greenlet包实现并发编程的入门教程
- Java实现高并发的处理的方式
- [Python]ctypes+struct实现类c的结构化数据串行处理
- Python的并发处理:(一)并行运行多个互不相干的子进程
- Python3中常用的处理时间和实现定时任务的方法的介绍
- Python几种并发实现方案的性能比较
- 用 Python 实现每秒处理 120 万次 HTTP 请求
- epoll + 多线程实现并发网络连接处理
- 11.python并发入门(part10 多进程之间实现通信,以及进程之间的数据共享)
- Python实现采用进度条实时显示处理进度的方法
- Python和perl实现批量对目录下电子书文件重命名的代码分享
- Python 图形处理库PIL批量修改图片大小和格式