- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在使用 Fabric 在远程 Windows 7 系统上运行一些命令。我所做的是这样的:
env.hosts=['192.168.91.235']
env.user='test'
env.password='123456'
def test_windows():
run("ifconfig",shell=False)
pass
它适用于“ipconfig”并输出远程系统的网络信息,因此我确定 ssh 连接正常。但它不适用于我尝试过的任何其他命令,例如“cd”、“echo hello”。错误是:
out: Unable to execute command or shell on remote system: Failed to Execute process.
我想远程运行 Windows shell 脚本,我应该这样做吗?
附注如果我通过腻子连接窗口,命令“cd”“echo hello”就可以工作。
[更新]
我意识到fabric正在使用env.shell来解释我传递的命令,现在我的问题是:可以为fabric env.shell指定一个Windows shell吗?以及如何?
[再次更新]
我将“cmd.exe”分配给env.shell,但它卡在执行“cmd.exe”上。经过几次尝试,env.shell="cmd.exe /c"
最终起作用了。现在我可以通过fabric远程执行dir
,echo
。
[最终解决后更新:]
我不确定我的解决方案是否有缺陷,到目前为止一切顺利。
我的解决方案是在Windows上使用msys+在Linux上使用fabric+在Windows上使用freesshd作为ssh服务器。
Windows 上的 msys 提供了“bash”,正如 Andrew Walker 下面提到的,fabric 期望“bash”并且在它上表现出色。尽管在上面的[再次更新]中,fabric也可以与cmd.exe /c
一起使用并在其上执行Windows命令。
要将 msys bash/shell 分配给 Fabric,用户应该具体告诉 env 如何找到 bash
env.shell='cmd.exe /c c:/msys/1.0/bin/sh.exe -l -c'
cmd.exe /c
告诉 Fabric 下面的字符串应该作为 cmd.exe 中的“命令”执行,/c
之后的 cmd.exe
表示 Windows cmd 上下文中的命令,就像 cmd.exe /c "command"
然后c:/msys/1.0/bin/sh -l -c
由cmd.exe执行,并且fabric正在执行msys shell。我不确定 -l
是做什么的,msys shell 在没有 -l
的情况下无法在 bin 文件夹中找到 fakelinuxcommand.exe ,所以我得出的结论是 -l
对环境有所帮助。 -c
与 /c
中的 cmd.exe /c
类似,表示以下字符串作为 c:/msys/1.0/bin/sh
的命令,因此传递给 ssh 客户端的以下内容在 msys shell 中作为命令执行。
一个清晰的集成示例:
env.password='123456'
env.user='test'
env.hosts=['test@192.168.91.238']
env.shell='cmd.exe /c c:/msys/1.0/bin/sh.exe -l -c'
def run_shell_command(command):
return run(command,pty=False)
函数run_shell_command中的参数command
将与env.shell连接并由msys shell执行。
[我的结论]
我认为如果没有“类似 bash”的伪终端,fabric 就无法工作。在【再次更新】中,linux中的fabric可以执行远程windows的cmd.exe中的命令。在某些仅存在远程 winodw 的情况下,这就足够了。 msys 提供了一个 linux bash,允许我从本地 linux 在远程 Windows 和远程 linux 上执行相同的 shell 脚本。
最佳答案
我同意 Martian Puss 结论,即“Fabric 可以在没有‘bash-like’ shell 的情况下工作”。
我已将 FreeSSHd 软件安装到我的 Windows 7 计算机中(作为服务运行),并且我已向“sistemas”用户授予对 Windows shell 的访问权限。
然后,可以使用以下 Fabric 代码在该 shell 上远程调用命令(例如 systeminfo):
from fabric.api import env, run
env.hosts=["sistemas@cliente03"]
def test_win():
run("systeminfo", shell=False, pty=False)
特别注意 shell=False
参数,这是使其正常工作的关键。
如果我们运行它,我们会得到以下结果:
[sistemas@cliente01 ~]$ fab test_win
[sistemas@cliente03] Executing task 'test_win'
[sistemas@cliente03] run: systeminfo
[sistemas@cliente03] Login password for 'sistemas':
[sistemas@cliente03] out:
[sistemas@cliente03] out: Host Name: RP_CLIENTE03
[sistemas@cliente03] out: OS Name: Microsoft Windows 7 Professional
[sistemas@cliente03] out: OS Version: 6.1.7601 Service Pack 1 Build 7601
[sistemas@cliente03] out: OS Manufacturer: Microsoft Corporation
[sistemas@cliente03] out: OS Configuration: Standalone Workstation
...
[sistemas@cliente03] out:
Done.
Disconnecting from cliente03... done.
关于shell - Fabric无法在Windows上执行远程命令,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/22504784/
我刚刚偶然发现Fabric并且文档并没有真正说明它是如何工作的。 我有根据的猜测是您需要在客户端和服务器端都安装它。 Python 代码存储在客户端,并在命令运行时通过 Fabric 的有线协议(pr
以下是我对 Hyperledger Fabric 系统的理解。如果有任何不正确的地方,请告诉我。 1) 所以我们有同行(背书人、 anchor 人、将军(拥有分类帐的人)、排序人)。此外,当我们设置结
我部署了一个持久性级别为 Silver 的全新 Service Fabric 集群,fabric:/System/InfrastructureService/FE 服务运行状况不佳,并出现以下错误:
我对使用 Fabric 很感兴趣,api 在未连接到互联网时如何工作? 我发现 firebase(与此工具类似的工具)会将数据存储在本地,然后对服务器进行批量更新。但是,超过 72 小时的任何内容都不
Fabric CA Server 和 Fabric CA Client 的功能是什么? Fabric CA 服务器和 Fabric CA 客户端的角色是什么? 谢谢 最佳答案 Fabric CA 提供
我想在不同的环境中使用相同的应用程序,我在 documentation 中找到了它, Apps with Multiple Environments Let’s say you have an app
我目前正在尝试学习 Hyperledger Fabric,我设法了解了如何设置网络(Orderer、Peers 等),但现在是链代码的一部分。 但是,我发现两个不同的 git 存储库(据我所知)可用于
我在 following this tutorial 时遇到错误 cannot convert from 'System.Fabric.StatelessServiceContext' to 'Sys
在我没有改变任何东西之前它可以工作,但今天我收到了这个错误,这里是我的 gradle buildscript { repositories { mavenCentral() maven
Fabric beta 手动分发有时不会发送邀请电子邮件,即使在它向该人显示“已邀请”的网页中也是如此。如果我点击重新发送邀请,那个人就会收到。我的 QA 团队人员必须一直来找我重新发送邀请。我知道
默认情况下,Hyperledger Fabric 在将许多证书保存到区 block 链之前将其存储在交易中。无论如何或任何想法/技术来最小化区 block 链中的交易大小? 任何想法都非常有用! 最佳
我是 Hyperledger Fabric 的新手。我正在阅读 Fabric 的文档最新版本,但我不清楚 Fabric 的共识。 Fabric 使用的共识是什么?它是如何工作的?请解释。 最佳答案 我
我是 Hyperledger Fabric 的新手,我正在尝试在本地向服务器注册 Fabric 客户端。这是我到目前为止所做的。 go get -u github.com/hyperledger/fa
Hyperledger Fabric 中链和状态数据库的主要区别是什么。我很困惑它们是否相同。 最佳答案 Hyperledger Fabric 中有两个“存储”数据的地方: 账本 状态数据库 账本是真
我尝试将图像上传到分类帐中(将图像转换为 base64 字符串并将其作为交易中的 arg 传递)。 当我发送大小为 30 kb 的图像时,它工作正常,但是对于 100 kb 的图像,我的交易失败了,指
我正在尝试在初始化 Fabric CA 服务器后注册管理员: fabric-ca-server init -b “admin:adminpw” 并启动 CA 服务器: fabric-ca-serve
我正在使用来自 super 账本fabric firstsample的cryptogen工具,它未在 crypto-config/peerorganisation/org1.example.com/m
我离开了一家公司,用于访问 Fabric 的电子邮件已被删除。 现在我在同一家公司工作,他们用相同的句柄重新创建了电子邮件。我不知道这是否是问题所在,但我没有收到任何包含报告的电子邮件,也没有收到 B
如果我有 1 个组织 orgA ,在这个组织下我有 2 个用户:user1和 user2 , 在 orgA 中也有 1 个对等点,让我们称之为 peer0 . 现在想象一下,user1的证书在orgA
全部, 据我所知,在 Hyperledger Fabric 环境中,orderer 将消息传递给 peer。如果有离线对等。恢复到 ON-LINE 时,消息如何传递给对端? orderer如何知道pe
我是一名优秀的程序员,十分优秀!