Python脚本之Multiprocessing 多线程

AAB377E247752DA87288BAF935E442AC

######################################

#!/usr/bin/env python

#encoding=utf-8

from multiprocessing import Process,Lock

import time,os

def say(i):

    print 'nihao:',i

#lock=Lock()

for n in range(101):

    p=Process(target=say,args=(n,))

    p.start()

    #p.join()

########################################多线程池Pool,可限制多线程数量

#!/usr/bin/env python

#encoding=utf-8

import multiprocessing

import os,sys,time

result=[]

def run_cmd(i):

    print 'threading test:',i,os.getpid()

    time.sleep(1.5)

p=multiprocessing.Pool(processes=25)

for n in range(100):

    result.append(p.apply_async(run_cmd,('%s'%n,)))

p.close()

#p.join()

for res in result:

    res.get(timeout=5)

######################################多线程pool,paramiko

import multiprocessing

import os,time

import paramiko

hosts=['192.168.1.11','192.168.1.10']

#,'192.168.1.11','192.168.1.12','192.168.1.13']

username='root'

password='123456'

port=22

name={}

d_usage={}

def cmd(hostname):

        if os.system('ping %s -c 1 &>/dev/null'%hostname)==0:

                paramiko.util.log_to_file('paramiko.log')

                s = paramiko.SSHClient()

                s.set_missing_host_key_policy(paramiko.AutoAddPolicy())

                s.connect(hostname,port,username,password)

                stdin,stdout,stderr=s.exec_command('df -kP')

                time.sleep(2)

                d_usage['%s'%hostname]= stdout.read()

                print '---------------------------------------------'

                print d_usage['%s'%hostname]

                print stdout.read()

                s.close()

        else:

                d_usage['%s'%hostname]='host Destination Host Unreachable'

                print  'host Destination Host Unreachable'

                name={'xk':[25,'male'],'zq':[23,'male'],}

p=multiprocessing.Pool(processes=10)

for hostname in hosts:

        p.apply_async(cmd,('%s'%hostname,))

#       time.sleep(10)

time.sleep(10)

p.close()

#p.join()

#print d_usage












本文转自shangshanyang51CTO博客,原文链接: http://blog.51cto.com/qqran/1962675,如需转载请自行联系原作者



  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值