python下paramiko模块学习之二:利用配置文件登录批量主机

简介:

  之前我写过一篇关于python中paramiko模块简单功能的文章,今天继续给大家介绍这个模块的一些用法。

     今天主要是利用python读取配置文件来登录批量主机,并在主机上执行shell命令,废话不说了,直接上代码了,大家可以看看:

 
  1. #!/usr/bin/env python 
  2. import paramiko 
  3. import os 
  4. import datetime 
  5. from ConfigParser import ConfigParser 
  6. ConfigFile='config.ini' 
  7. config=ConfigParser() 
  8. config.read(ConfigFile) 
  9. hostname1=''.join(config.get('IP','ipaddress')) 
  10. address=hostname1.split(';'
  11. print address 
  12. username='root' 
  13. password='abc123' 
  14. port=22 
  15. local_dir='/tmp/' 
  16. remote_dir='/tmp/test/' 
  17. if __name__=="__main__"
  18.         for ip in address: 
  19.                 paramiko.util.log_to_file('paramiko.log'
  20.                 s=paramiko.SSHClient() 
  21.                 s.set_missing_host_key_policy(paramiko.AutoAddPolicy()) 
  22.                 s.connect(hostname=ip,username=username,password=password) 
  23.                 stdin,stdout,stderr=s.exec_command('free;ifconfig;df -h'
  24.                 print stdout.read() 
  25.                 s.close() 

下面再贴上config.ini配置文件内容:

 
  1. [IP] 
  2.  

 
  1. ipaddress = 74.63.229.*;69.50.220.* 
 
  1.  

下面给大家看下效果:

 

 
  1. [root@centos6 python]# clear 
  2. [root@centos6 python]# python paramiko-config.py 
  3. ['74.63.229.*''69.50.220.*'
  4.              total       used       free     shared    buffers     cached 
  5. Mem:        393216      22308     370908          0          0          0 
  6. -/+ buffers/cache:      22308     370908 
  7. Swap:            0          0          0 
  8. lo        Link encap:Local Loopback 
  9.           inet addr:127.0.0.1  Mask:255.0.0.0 
  10.           inet6 addr: ::1/128 Scope:Host 
  11.           UP LOOPBACK RUNNING  MTU:16436  Metric:1 
  12.           RX packets:14 errors:0 dropped:0 overruns:0 frame:0 
  13.           TX packets:14 errors:0 dropped:0 overruns:0 carrier:0 
  14.           collisions:0 txqueuelen:0 
  15.           RX bytes:956 (956.0 B)  TX bytes:956 (956.0 B) 
  16.  
  17. venet0    Link encap:UNSPEC  HWaddr 00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00 
  18.           UP BROADCAST POINTOPOINT RUNNING NOARP  MTU:1500  Metric:1 
  19.           RX packets:36498 errors:0 dropped:0 overruns:0 frame:0 
  20.           TX packets:36433 errors:0 dropped:0 overruns:0 carrier:0 
  21.           collisions:0 txqueuelen:0 
  22.           RX bytes:8698019 (8.2 MiB)  TX bytes:5322427 (5.0 MiB) 
  23.  
  24. venet0:0  Link encap:UNSPEC  HWaddr 00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00 
  25.           inet addr:74.63.229.*  P-t-P:74.63.229.56  Bcast:0.0.0.0  Mask:255.255.255.255 
  26.           UP BROADCAST POINTOPOINT RUNNING NOARP  MTU:1500  Metric:1 
  27.  
  28. Filesystem            Size  Used Avail Use% Mounted on 
  29. /dev/simfs             10G  408M  9.7G   4% / 
  30. tmpfs                 192M     0  192M   0% /lib/init/rw 
  31. tmpfs                 192M     0  192M   0% /dev/shm 
  32.  
  33.              total       used       free     shared    buffers     cached 
  34. Mem:        262144     154120     108024          0      50948      62668 
  35. -/+ buffers/cache:      40504     221640 
  36. Swap:       262136          0     262136 
  37. eth0      Link encap:Ethernet  HWaddr 00:16:3E:27:61:01 
  38.           inet addr:69.50.220.*  Bcast:69.50.223.255  Mask:255.255.240.0 
  39.           UP BROADCAST RUNNING MULTICAST  MTU:1500  Metric:1 
  40.           RX packets:43755717 errors:0 dropped:0 overruns:0 frame:0 
  41.           TX packets:79002 errors:0 dropped:0 overruns:0 carrier:0 
  42.           collisions:0 txqueuelen:1000 
  43.           RX bytes:3003027220 (2.7 GiB)  TX bytes:39705224 (37.8 MiB) 
  44.  
  45. lo        Link encap:Local Loopback 
  46.           inet addr:127.0.0.1  Mask:255.0.0.0 
  47.           UP LOOPBACK RUNNING  MTU:16436  Metric:1 
  48.           RX packets:0 errors:0 dropped:0 overruns:0 frame:0 
  49.           TX packets:0 errors:0 dropped:0 overruns:0 carrier:0 
  50.           collisions:0 txqueuelen:0 
  51.           RX bytes:0 (0.0 b)  TX bytes:0 (0.0 b) 
  52.  
  53. Filesystem            Size  Used Avail Use% Mounted on 
  54. /dev/sda1              15G  4.7G  9.4G  33% / 
  55. none                  128M     0  128M   0% /dev/shm 
  56.  
  57. [root@centos6 python]# 

   呵呵,代码十分简单,我在linux虚拟机下执行没有问题,上面的2个实体ip是我的2个VPS,登录和执行都很快,但是在window下却报错,比较困惑,也没有深究,希望有知道的同仁指点下。

    这个例子这个例子十分简单,大家可以扩张下,在运维工作中,我们管理的机器可不止2台吧,你就可以你管理的服务器IP都写在配置文件里,中间又分号隔开就可以了,还有一点就是你可能执行的命令也有很多,其实也可以写在配置文件里,而不必像我这样写死在代码里面,其他扩展功能大家可以自己去看看

本文转自你是路人甲还是霍元甲博客51CTO博客,原文链接http://blog.51cto.com/world77/706999如需转载请自行联系原作者


world77

相关文章
|
1天前
|
测试技术 Python
Python 有趣的模块之pynupt——通过pynput控制鼠标和键盘
Python 有趣的模块之pynupt——通过pynput控制鼠标和键盘
|
1天前
|
Serverless 开发者 Python
《Python 简易速速上手小册》第3章:Python 的函数和模块(2024 最新版)
《Python 简易速速上手小册》第3章:Python 的函数和模块(2024 最新版)
25 1
|
3天前
|
机器学习/深度学习 算法 Python
使用Python实现集成学习算法:Bagging与Boosting
使用Python实现集成学习算法:Bagging与Boosting
15 0
|
3天前
|
Python
python学习-函数模块,数据结构,字符串和列表(下)
python学习-函数模块,数据结构,字符串和列表
25 0
|
4天前
|
Python
python学习14-模块与包
python学习14-模块与包
|
4天前
|
Python
python学习12-类对象和实例对象
python学习12-类对象和实例对象
|
9天前
|
安全 Java 数据处理
Python网络编程基础(Socket编程)多线程/多进程服务器编程
【4月更文挑战第11天】在网络编程中,随着客户端数量的增加,服务器的处理能力成为了一个重要的考量因素。为了处理多个客户端的并发请求,我们通常需要采用多线程或多进程的方式。在本章中,我们将探讨多线程/多进程服务器编程的概念,并通过一个多线程服务器的示例来演示其实现。
|
9天前
|
程序员 开发者 Python
Python网络编程基础(Socket编程) 错误处理和异常处理的最佳实践
【4月更文挑战第11天】在网络编程中,错误处理和异常管理不仅是为了程序的健壮性,也是为了提供清晰的用户反馈以及优雅的故障恢复。在前面的章节中,我们讨论了如何使用`try-except`语句来处理网络错误。现在,我们将深入探讨错误处理和异常处理的最佳实践。
|
12天前
|
缓存 监控 Python
解密Python中的装饰器:优雅而强大的编程利器
Python中的装饰器是一种强大而又优雅的编程工具,它能够在不改变原有代码结构的情况下,为函数或类添加新的功能和行为。本文将深入解析Python装饰器的原理、用法和实际应用,帮助读者更好地理解和利用这一技术,提升代码的可维护性和可扩展性。