- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我正在尝试在 Python 3 中创建一个结构,使我能够轻松地在远程计算机上执行一个函数。假设我已经有了一个 python tcp 服务器,它将运行它接收到的函数,在远程服务器上运行,我目前正在考虑使用像
这样的装饰器@execute_on(address, port)
这将创建执行它正在装饰的函数所需的必要上下文,然后将函数和上下文发送到远程计算机上的 tcp 服务器,然后由远程计算机执行它。首先,这有点理智吗?如果不能,您能推荐一种更好的方法吗?我进行了一些谷歌搜索,但没有找到满足这些需求的任何内容。
我有一个用于 tcp 服务器和客户端的快速但肮脏的实现,所以相当肯定它会起作用。我可以通过
获得传递给装饰器的函数(例如 func)的字符串表示import inspect
string = inspect.getsource(func)
然后可以将其发送到可以执行的服务器。问题是,如何获取函数执行所需的所有上下文信息?例如,如果 func 定义如下,
import MyModule
def func():
result = MyModule.my_func()
MyModule 需要在全局上下文或远程服务器上的 funcs 本地上下文中对 func 可用。在这种情况下,这相对微不足道,但根据何时以及如何使用 import 语句,它可能会变得更加复杂。在 Python 中是否有一种简单而优雅的方法来做到这一点?我目前想出的最好办法是使用 ast 库提取所有导入语句,使用检查模块获取这些模块的字符串表示,然后在远程服务器上重建整个上下文。不是特别优雅,我可以看到很多错误的空间。
谢谢你的时间
最佳答案
除非远程服务器以某种方式受到非常严格的保护或“极其沙盒化”(例如 BSD“ jail ”),否则您概述的方法风险极大——任何可以向其发送函数的人都可以在那里运行任意代码。
假设您有一个您完全信任的身份验证系统,就会出现您意识到的“脆弱性”问题——函数可以依赖于执行时在其模块中定义的任何全局变量(这可能与您可以定义的不同)通过检查检测:在执行时确定导入模块的集合,更一般地说是全局变量的集合,是一个图灵完备的问题)。
您可以通过序列化函数的全局变量以及函数本身来处理全局变量问题,在您将它发送到远程执行时(无论您以可读字符串形式序列化所有这些东西,还是其他方式,都是小问题)。但这仍然会给您留下在函数内执行导入的问题。
除非您愿意对“远程”函数施加一些限制,例如“函数内部没有导入(以及从中调用的函数)”,我认为您可以服务器覆盖 __import__
(所有 import 语句使用的内置函数,旨在根据特殊需求覆盖,例如您的需求;-)以从发送客户端请求额外的模块(当然,这要求所述客户端也具有“类似服务器”的能力,因为它必须能够响应来自服务器的此类“模块请求”)。
你不能对远程函数施加一些限制,使这个任务回到理智的领域......?
关于python - 如何将 python 函数复制到远程计算机然后执行它?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/2962531/
有没有办法在不进行提交/ check out 的情况下应用差异补丁或类似补丁? 我的情况:我工作时经常在计算机之间切换,我的提交历史记录有一堆“switching machines”消息。 我最初的猜
我的自定义引导加载程序中有代码从地址 0x8E00 处的 512 字节缓冲区复制内存。进入高内存,0x100000和更高。这在某些计算机上运行良好,而在其他计算机上崩溃(我假设是三重故障)。此代码在
服务器有没有办法将一些数据无线无缝地推送到客户端,可能是 Windows(电话)、iPhone、Mac 或 Android 设备,没有任何操作系统集成? 如果是这样,最好的设计模式是什么,最好的技术是
我无法理解hadoop的真正本质。 如果我有足够的资源来购买可以处理PB级数据的 super 计算机,那么为什么我需要Hadoop基础架构来管理如此大的数据? 最佳答案 hadoop的全部目的是能够在
我有一个奇怪的问题,或者我可能无法理解Grails i18n机制的工作原理。 我将以下内容插入到index.gsp文件中: LocaleContextHolder.locale:
我正在尝试为我的小弟弟编写一个简单的程序。他经常在他的电脑后面,但他应该为学校学习简单的算术 :D 我想制作以下程序: 他启动了他的电脑 他需要做一些简单的练习并完成 如果他做对了 x 次,他可以继续
有人能告诉我如何在 diff 主机(计算机)上为 MySQL 数据库做一个简单的数据库备份吗?我正在尝试将我的数据库从一台主机(服务器)移动到一台新主机(服务器) 最佳答案 如果您只是需要在服务器之间
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 要求我们推荐或查找工具、库或最喜欢的场外资源的问题对于 Stack Overflow 来说是无关紧要的,因
我正在尝试让 Android 应用程序使用 USB 电缆与运行 ubuntu 12.04 lts 的 Linux 计算机进行通信。我正在尝试使用 usbdeviceconnection 类,但是当我通
我刚刚使用 docker-toolbox 1.8.2 安装了 docker在 Windows 10 上。 由于由于this issue我不得不使用这些命令重新创建 docker 镜像 docker-m
如何删除处于 GURU_MEDITATION 错误状态的 VirtualBox 计算机?在 VirtualBox 未运行时删除该目录是否足够? 编辑:发布后,我删除了“在文件管理器中显示”导航到的整个
当我们在 Azure 机器学习服务中将模型部署为 ACIWebService 时,不需要指定任何 deployment_target。 根据AzureML documentation对于 azurem
当我们在 Azure 机器学习服务中将模型部署为 ACIWebService 时,不需要指定任何 deployment_target。 根据AzureML documentation对于 azurem
我遇到的主要问题是当我选择 stay 时会发生什么上hand_one ,然后 hit上hand_two . 而不是让我hit or stay上hand_two再次,它让我回到hit or stay上h
我知道我可以使用 putty 来 ssh 进入每台 Linux 机器并更新 CentOS 服务器...但我希望有人能够为我指明正确的方向,告诉我如何通过 PowerShell 或 Windows 中的
在 MIX 计算机中,一个单词由五个字节和一个符号组成。符号在内存中是如何表示的?是另一个字节,所以每个字真的是六个字节吗? 谢谢。 最佳答案 你的问题不是很清楚。体系结构规范未指定实际实现。它仅指定
我是 Python 的初级程序员,我的电脑有一个奇怪的问题。当我的计算机上有一个 .py 文件(包含一个有效的脚本)并双击它打开时,会发生以下情况:程序打开(它是黑屏 View ),但它会在一秒钟内自
我正在尝试在 Windows 上使用 plink 创建到 Linux 机器的隧道,并让转储文件最终出现在 Windows 机器上。看起来 this answer会工作,是我的问题的基础。但是尝试一下并
我想在 Windows 7 和 10 计算机上执行重启,但我首先需要将 Jenkins 节点暂时离线。在执行重启之前,我需要完成所有正在运行的任务。然后我远程登录到服务器并重新启动计算机。然而,在我重
我正在编写一个简单的程序,从 MySQL 数据库中提取计算机名称,然后将这些名称存储到字符串数组列表中(这部分工作正常)。之后,我编写了一个类和一个方法,将字符串作为参数(这将是计算机名称)并尝试对其
我是一名优秀的程序员,十分优秀!