python多线程获取子线程任务返回值

今天想实现多线程更新资产信息,所以使用到了threading,但是我需要每个线程的返回值,这就需要我在threading.Thread的基础上进行封装


def auto_asset(node):
    ret = salt.remote_grains_execution_sigle(node)
    asset_info={}
    asset_info[‘os‘]= ret[node][‘oscodename‘]
    asset_info[‘kernelrelease‘]= ret[node][‘kernelrelease‘]
    asset_info[‘cpu_model‘]= ret[node][‘cpu_model‘]
    asset_info[‘dns‘]= ‘,‘.join(ret[node][‘dns‘][‘ip4_nameservers‘])
    asset_info[‘serialnumber‘] =  ret[node][‘serialnumber‘]
    asset_info[‘virtual‘] =  ret[node][‘virtual‘]
    asset_info[‘localhost‘] = ret[node][‘localhost‘]
    asset_info[‘mem_total‘] =  ret[node][‘mem_total‘]
    asset_info[‘num_cpus‘] =  ret[node][‘num_cpus‘]
    asset_info[‘ip4_interfaces‘] = " ".join(ret[node][‘ip4_interfaces‘][‘eth0‘])
    asset_info[‘hwaddr_interfaces‘] = ret[node][‘hwaddr_interfaces‘][‘eth0‘]
    return asset_info

import threading

class MyThread(threading.Thread):

    def __init__(self,func,args=()):
        super(MyThread,self).__init__()
        self.func = func
        self.args = args

    def run(self):
        self.result = self.func(*self.args)

    def get_result(self):
        try:
            return self.result  # 如果子线程不使用join方法,此处可能会报没有self.result的错误
        except Exception:
            return None

ass =Asset.objects.all()
ids_list =[ i.inner_ip for i in ass]
files = range(len(ids_list))
t_list = []
t_data = []
for i in files:
    t = MyThread(auto_asset, (ids_list[i],))
    t_list.append(t)
    t.start()
for t in t_list:
    t.join()  # 一定要join,不然主线程比子线程跑的快,会拿不到结果
    t_data.append(t.get_result())
    print(t.get_result())

执行结果

{‘localhost‘: ‘VM_75_82_centos‘, ‘hwaddr_interfaces‘: ‘52:54:00:95:fe:c8‘, ‘disks‘: {‘/dev/vda1‘: {‘total‘: ‘49.09G‘, ‘capacity‘: ‘17%‘, ‘avail‘: ‘38.96‘, ‘used‘: ‘7.63‘}}, ‘dns‘: ‘10.236.158.106,10.236.158.114‘, ‘ip4_interfaces‘: ‘10.105.75.82‘, ‘num_cpus‘: 1, ‘serialnumber‘: ‘a1dad25c-8e69-4838-a489-0fe1958e76df‘, ‘os‘: ‘CentOS Linux 7 (Core)‘, ‘mem_total‘: 1839, ‘cpu_model‘: ‘Intel(R) Xeon(R) CPU E5-26xx v4‘, ‘kernelrelease‘: ‘3.10.0-514.26.2.el7.x86_64‘, ‘virtual‘: ‘kvm‘}
{‘localhost‘: ‘wordpress‘, ‘hwaddr_interfaces‘: ‘fa:16:3e:1a:49:72‘, ‘disks‘: {‘/dev/vda1‘: {‘total‘: ‘29.99G‘, ‘capacity‘: ‘12%‘, ‘avail‘: ‘26.54‘, ‘used‘: ‘3.45‘}}, ‘dns‘: ‘103.224.222.222,103.224.222.223,8.8.8.8‘, ‘ip4_interfaces‘: ‘192.168.0.3‘, ‘num_cpus‘: 1, ‘serialnumber‘: ‘c6bce500-113d-11e7-a010-0425c53afb57‘, ‘os‘: ‘CentOS Linux 7 (Core)‘, ‘mem_total‘: 1839, ‘cpu_model‘: ‘Intel Core Processor (Broadwell, IBRS)‘, ‘kernelrelease‘: ‘3.10.0-514.el7.x86_64‘, ‘virtual‘: ‘kvm‘}

原文地址:https://www.cnblogs.com/guigujun/p/8734490.html

时间: 2024-11-05 22:41:14

python多线程获取子线程任务返回值的相关文章

Java多线程——<三>让线程有返回值

一.概述 到目前为止,我们已经能够声明并使一个线程任务运行起来了.但是遇到一个问题:现在定义的任务都没有任何返回值,那么加入我们希望一个任务运行结束后告诉我一个结果,该结果表名任务执行成功或失败,此时该怎么办呢? 答案是使用Callable.之前定义的任务都直接实现了Runnable,该接口的run方法并无返回值.而Callable的call方法可以根据你传入的泛型参数返回对应类型的数据. 二.实现 1.实现Callable接口,定义可返回结果的线程任务 public class TaskCal

Java多线程——<四>让线程有返回值

一.概述 到目前为止,我们已经能够声明并使一个线程任务运行起来了.但是遇到一个问题:现在定义的任务都没有任何返回值,那么加入我们希望一个任务运行结束后告诉我一个结果,该结果表名任务执行成功或失败,此时该怎么办呢? 答案是使用Callable.之前定义的任务都直接实现了Runnable,该接口的run方法并无返回值.而Callable的call方法可以根据你传入的泛型参数返回对应类型的数据. 二.实现 1.实现Callable接口,定义可返回结果的线程任务 public class TaskCal

asp.net 父窗体获取子窗体的返回值,可用来对父窗体局部更新

今天在项目上遇到了这个问题,其实只是window.returnValue的简单应用,不是asp.net的专属内容.作为积累,记录一个简单的实现模型. 图1  用到的文件 从图1中我们可以看到,只用到了两个页面,其中Default.aspx作为父页面,Default2.aspx作为子页面被弹出.Default.aspx页面上有两个TextBox一个Button,代码如下: 1 <%@ Page Language="C#" AutoEventWireup="true&quo

20150812 Asp.net 父窗体获取子窗体的返回值,更新父窗体文本控件(应用)

1. 父窗体 **************************************** using System;using System.Collections;using System.Configuration;using System.Data;using System.Linq;using System.Web;using System.Web.Security;using System.Web.UI;using System.Web.UI.HtmlControls;using

Python+PyQT5的子线程更新UI界面的实例《新手必学》

今天小编就为大家分享一篇Python+PyQT5的子线程更新UI界面的实例,具有很好的参考价值,希望对大家有所帮助.一起跟随小编过来看看吧子线程里是不能更新UI界面的,在移动端方面.Android的UI访问是没有加锁的,多个线程可以同时访问更新操作同一个UI控件.也就是说访问UI的时候,android系统当中的控件都不是线程安全的,这将导致在多线程模式下,当多个线程共同访问更新操作同一个UI控件时容易发生不可控的错误.所以Android中规定只能在UI线程中访问UI,相当于从另一个角度给Andr

在Java 线程中返回值的用法

http://icgemu.iteye.com/blog/467848 在Java 线程中返回值的用法 博客分类: Java Javathread 有时在执行线程中需要在线程中返回一个值:常规中我们会用Runnable接口和Thread类设置一个变量:在run()中改变变量的值,再用一个get方法取得该值,但是run何时完成是未知的:我们需要一定的机制来保证. 在在Java se5有个Callable接口:我们可以用该接口来完成该功能: 代码如: Java代码   package com.thr

线程的返回值

线程的返回值当线程退出时,线程可以选择向主线程返回一个值,返回方式一共有4种1\如果要返回int类型,可以使用pthread_exit((int)* return_value);2\使用全局变量返回(这个最简单)3\使用malloc所分配的空间4\直接返回字符串,如pthread_exit("return value"); #include <stdio.h> #include <stdlib.h> #include <string.h> #incl

Selenium2学习-036-WebUI自动化实战实例-034-JavaScript 在 Selenium 自动化中的应用实例之六(获取 JS 执行结果返回值)

Selenium 获取 JavaScript 返回值非常简单,只需要在 js 脚本中将需要返回的数据 return 就可以,然后通过方法返回 js 的执行结果,方法源码如下所示: 1 /** 2 * Get Object of return from js 3 * 4 * @author Aaron.ffp 5 * @version V1.0.0: autoSeleniumDemo main.aaron.sele.core SeleniumCore.java execJSR, 2015-8-9

怎样获取shell函数的返回值及shell命令的返回值?

1.获取shell函数调用的返回值: #!/bin/sh info() { cat jlb.sh } res=`info` echo "state: "$? echo "res: "${res} 说明:res=`info`这一行为调用函数info,里面的符号`不是单引號,而是Esc按键以下的那个.另外$?返回的为上一条命令的运行状态,不是返回值. 2.获取shell命令的返回值,原理同上,比如: #!/bin/sh info=`cat jlb.sh` echo &q