Chinaunix首页 | 论坛 | 博客
  • 博客访问: 19881591
  • 博文数量: 679
  • 博客积分: 10495
  • 博客等级: 上将
  • 技术积分: 9308
  • 用 户 组: 普通用户
  • 注册时间: 2006-07-18 10:51
文章分类

全部博文(679)

文章存档

2012年(5)

2011年(38)

2010年(86)

2009年(145)

2008年(170)

2007年(165)

2006年(89)

分类: Python/Ruby

2010-06-04 11:10:15

#!/usr/bin/env python
#gtalk: xurongzhong#gmail.com
import pxssh
ips = ["10.144.18.245","10.144.18.242"]
for ip in ips:
    print ip
    s = pxssh.pxssh()
    s.login(ip, "user", "passwd",port=36000)
    s.sendline('ls')  # run a command 
    s.prompt()             # match the prompt 
    print s.before         # print everything before the propt. 
    s.sendline ("uptime")  # run a command 
    s.prompt()             # match the prompt 
    print s.before         # print everything before the propt. 
    s.logout()

执行结果:

# ./test.py  
10.144.18.245
ls
Documents  bin  isu.tar.gz  public_html

uptime
 10:59am  up 42 days 23:25,  1 user,  load average: 11.08, 7.84, 4.42

10.144.18.242
ls
Documents  bin  isu.tar.gz  public_html

uptime
 11:00am  up 42 days 23:26,  1 user,  load average: 3.50, 9.75, 9.89

注意点:
如果报错:

pexpect .TIMEOUT: Timeout exceeded in read_nonblocking()


修改site-packages/pxssh.py

在def synch_original_prompt (self):方法下第一个self.read_nonblocking(size=10000,timeout=1) 前面增加两行代码

self.sendline()

time.sleep(0.1)

使用pxssh的速度好像一直比直接使用pexpect要慢,这方面还有待探索!



阅读(26928) | 评论(0) | 转发(1) |
给主人留下些什么吧!~~