免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 3186 | 回复: 8
打印 上一主题 下一主题

在函数中修改全局字典失败 [复制链接]

论坛徽章:
22
处女座
日期:2014-10-11 13:33:292015亚冠之塔什干火车头
日期:2015-07-20 19:59:042015亚冠之塔什干火车头
日期:2015-07-26 10:59:31程序设计版块每日发帖之星
日期:2015-08-05 06:20:00每日论坛发贴之星
日期:2015-08-05 06:20:00程序设计版块每日发帖之星
日期:2015-08-07 06:20:00每日论坛发贴之星
日期:2015-08-07 06:20:002015亚冠之阿尔纳斯尔
日期:2015-10-01 15:23:28白银圣斗士
日期:2015-12-07 17:17:06操作系统版块每日发帖之星
日期:2015-12-27 06:20:002015亚冠之广州富力
日期:2015-07-08 15:48:31程序设计版块每日发帖之星
日期:2015-06-11 22:20:00
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2017-08-08 12:15 |只看该作者 |倒序浏览
本帖最后由 聆雨淋夜 于 2017-08-08 12:20 编辑
  1. #!/usr/bin/env python
  2. # -*- coding:utf-8 -*-
  3. from multiprocessing import Process,Pool
  4. import paramiko
  5. import time

  6. IPList=['1.2.3.4','5.6.7.8']
  7. cmd='ls'
  8. result_dct={}
  9. def remote_exec(hostname,command):
  10.     try:
  11.         private_key = paramiko.RSAKey.from_private_key_file('/home/test/.ssh/id_rsa')
  12.         transport = paramiko.Transport((hostname,22))
  13.         transport.connect(username='test', pkey=private_key)
  14.         ssh = paramiko.SSHClient()
  15.         ssh._transport = transport
  16.         stdin, stdout, stderr = ssh.exec_command(command)
  17.         result_dct[hostname]=stdout.readlines() if stdout else stderr.readlines()
  18.         transport.close()
  19.     except Exception as e:
  20.         print 'ssh failed'

  21. if __name__ == '__main__':
  22.     pool = Pool(5)
  23.     for ip in IPList:
  24.         pool.apply_async(func=remote_exec, args=(ip,cmd),)
  25.     pool.close()
  26.     pool.join()
  27.     print result_dct
复制代码

如上是一个多进程执行命令的脚本,定义了全局字典result_dct,在函数中给字典赋值,“result_dct[hostname]=stdout.readlines() if stdout else stderr.readlines()在脚本结束输出result_dct,发现还是{}  
在函数中加上 “global result_dct”也不行
大神帮忙看看,感谢。

论坛徽章:
33
荣誉会员
日期:2011-11-23 16:44:17天秤座
日期:2014-08-26 16:18:20天秤座
日期:2014-08-29 10:12:18丑牛
日期:2014-08-29 16:06:45丑牛
日期:2014-09-03 10:28:58射手座
日期:2014-09-03 16:01:17寅虎
日期:2014-09-11 14:24:21天蝎座
日期:2014-09-17 08:33:55IT运维版块每日发帖之星
日期:2016-04-17 06:23:27操作系统版块每日发帖之星
日期:2016-04-18 06:20:00IT运维版块每日发帖之星
日期:2016-04-24 06:20:0015-16赛季CBA联赛之天津
日期:2016-05-06 12:46:59
2 [报告]
发表于 2017-08-08 13:19 |只看该作者
回复 1# 聆雨淋夜

进程间是 fork 呀.

所以, 根本不存在共用的东西.
你改成线程试试.

论坛徽章:
22
处女座
日期:2014-10-11 13:33:292015亚冠之塔什干火车头
日期:2015-07-20 19:59:042015亚冠之塔什干火车头
日期:2015-07-26 10:59:31程序设计版块每日发帖之星
日期:2015-08-05 06:20:00每日论坛发贴之星
日期:2015-08-05 06:20:00程序设计版块每日发帖之星
日期:2015-08-07 06:20:00每日论坛发贴之星
日期:2015-08-07 06:20:002015亚冠之阿尔纳斯尔
日期:2015-10-01 15:23:28白银圣斗士
日期:2015-12-07 17:17:06操作系统版块每日发帖之星
日期:2015-12-27 06:20:002015亚冠之广州富力
日期:2015-07-08 15:48:31程序设计版块每日发帖之星
日期:2015-06-11 22:20:00
3 [报告]
发表于 2017-08-08 14:23 |只看该作者
回复 2# q1208c

改成多线程也是不行

论坛徽章:
0
4 [报告]
发表于 2017-08-08 15:15 |只看该作者
大抵原因是字典为可变变量,试试持久化方法,把子进程或子线程的数据写入持久化的对象中,再在主进程中读出来使用。

论坛徽章:
22
处女座
日期:2014-10-11 13:33:292015亚冠之塔什干火车头
日期:2015-07-20 19:59:042015亚冠之塔什干火车头
日期:2015-07-26 10:59:31程序设计版块每日发帖之星
日期:2015-08-05 06:20:00每日论坛发贴之星
日期:2015-08-05 06:20:00程序设计版块每日发帖之星
日期:2015-08-07 06:20:00每日论坛发贴之星
日期:2015-08-07 06:20:002015亚冠之阿尔纳斯尔
日期:2015-10-01 15:23:28白银圣斗士
日期:2015-12-07 17:17:06操作系统版块每日发帖之星
日期:2015-12-27 06:20:002015亚冠之广州富力
日期:2015-07-08 15:48:31程序设计版块每日发帖之星
日期:2015-06-11 22:20:00
5 [报告]
发表于 2017-08-08 15:34 |只看该作者
回复 4# urey_pp

再请教一下,这里持久化对象指的什么呢?比如说?

论坛徽章:
0
6 [报告]
发表于 2017-08-08 15:38 |只看该作者
回复 5# 聆雨淋夜

比如dbm、pickle、shelve,看你喜欢哪一个了。

论坛徽章:
0
7 [报告]
发表于 2017-08-08 15:39 |只看该作者
回复 5# 聆雨淋夜

比如dbm、pickle、shelve,看你喜欢哪一个了。可以参考我的代码。
  1. https://github.com/DingGuodong/LinuxBashShellScriptForOps/blob/f15e45e65dcd919e36f2039b6162caff45291443/functions/net/tcp/ssh/pySshConnectParallel.py
复制代码

论坛徽章:
0
8 [报告]
发表于 2017-08-08 15:40 |只看该作者

论坛徽章:
33
荣誉会员
日期:2011-11-23 16:44:17天秤座
日期:2014-08-26 16:18:20天秤座
日期:2014-08-29 10:12:18丑牛
日期:2014-08-29 16:06:45丑牛
日期:2014-09-03 10:28:58射手座
日期:2014-09-03 16:01:17寅虎
日期:2014-09-11 14:24:21天蝎座
日期:2014-09-17 08:33:55IT运维版块每日发帖之星
日期:2016-04-17 06:23:27操作系统版块每日发帖之星
日期:2016-04-18 06:20:00IT运维版块每日发帖之星
日期:2016-04-24 06:20:0015-16赛季CBA联赛之天津
日期:2016-05-06 12:46:59
9 [报告]
发表于 2017-08-10 17:11 |只看该作者
回复 3# 聆雨淋夜

线程肯定是可以的.

我就是这个办法来控制数据库连接的.

除非你的实现有问题.
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP