忘记密码   免费注册 查看新帖 | 论坛精华区

ChinaUnix.net

  平台 论坛 博客 认证专区 大话IT HPC论坛 徽章 文库 沙龙 自测 下载 频道自动化运维 虚拟化 储存备份 C/C++ PHP MySQL 嵌入式 Linux系统
最近访问板块 发新帖
查看: 1025 | 回复: 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
发表于 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”也不行
大神帮忙看看,感谢。

论坛徽章:
32
荣誉会员
日期:2011-11-23 16:44:17射手座
日期:2014-09-03 16:01:17天蝎座
日期:2014-08-21 17:18:48丑牛
日期:2014-08-29 16:06:45天秤座
日期:2014-08-29 10:12:18天秤座
日期:2014-08-26 16:18:20双子座
日期:2014-07-30 11:38:27寅虎
日期:2014-08-04 10:24:12IT运维版块每日发帖之星
日期: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
发表于 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
发表于 2017-08-08 14:23 |显示全部楼层
回复 2# q1208c

改成多线程也是不行

论坛徽章:
0
发表于 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
发表于 2017-08-08 15:34 |显示全部楼层
回复 4# urey_pp

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

论坛徽章:
0
发表于 2017-08-08 15:38 |显示全部楼层
回复 5# 聆雨淋夜

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

论坛徽章:
0
发表于 2017-08-08 15:39 |显示全部楼层
回复 5# 聆雨淋夜

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

论坛徽章:
0
发表于 2017-08-08 15:40 |显示全部楼层

论坛徽章:
32
荣誉会员
日期:2011-11-23 16:44:17射手座
日期:2014-09-03 16:01:17天蝎座
日期:2014-08-21 17:18:48丑牛
日期:2014-08-29 16:06:45天秤座
日期:2014-08-29 10:12:18天秤座
日期:2014-08-26 16:18:20双子座
日期:2014-07-30 11:38:27寅虎
日期:2014-08-04 10:24:12IT运维版块每日发帖之星
日期: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
发表于 2017-08-10 17:11 |显示全部楼层
回复 3# 聆雨淋夜

线程肯定是可以的.

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

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

本版积分规则

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号 北京市公安局海淀分局网监中心备案编号:11010802020122
广播电视节目制作经营许可证(京) 字第1234号 中国互联网协会会员  联系我们:
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP