不能使用面料 - 是否需要任何服务器配置?

时间:2012-04-19 04:53:29

标签: python ubuntu fabric

我正在使用fabric在机架空间服务器上远程部署我的应用。我在家用计算机上使用相同的操作系统(Ubuntu Server 10.04)在虚拟机上尝试了我的脚本,它们似乎都可以工作。

奇怪的是,所有put结构命令在真实服务器上都失败了。所有其他命令(runcdsudo等)似乎都可以正常工作。

仅在定位此特定服务器时才会发生这种情况,这是我执行的命令:

fab test --host remote-server

remote-server是我.ssh/config的别名。我的fabfile:

@task
def test():
    sudo("echo testing")
    put("/tmp/file.txt", "/tmp/")

tmp/test_file.txt只是我用于测试的文本文件

这是输出

[remote-server] Executing task 'test'
[remote-server] sudo: echo testing
[remote-server] out: testing

Traceback (most recent call last):
  File "/home/user/env/lib/python2.6/site-packages/fabric/main.py", line 712, in main
    *args, **kwargs
  File "/home/user/env/lib/python2.6/site-packages/fabric/tasks.py", line 298, in execute
    multiprocessing
  File "/home/user/env/lib/python2.6/site-packages/fabric/tasks.py", line 197, in _execute
    return task.run(*args, **kwargs)
  File "/home/user/env/lib/python2.6/site-packages/fabric/tasks.py", line 112, in run
    return self.wrapped(*args, **kwargs)
  File "/home/user/project/fabfile/__init__.py", line 33, in test
    put("/tmp/file.txt", "/tmp/")
  File "/home/user/env/lib/python2.6/site-packages/fabric/network.py", line 457, in host_prompting_wrapper
    return func(*args, **kwargs)
  File "/home/user/env/lib/python2.6/site-packages/fabric/operations.py", line 338, in put
    ftp = SFTP(env.host_string)
  File "/home/user/env/lib/python2.6/site-packages/fabric/sftp.py", line 20, in __init__
    self.ftp = connections[host_string].open_sftp()
  File "/home/user/env/lib/python2.6/site-packages/ssh/client.py", line 399, in open_sftp
    return self._transport.open_sftp_client()
  File "/home/user/env/lib/python2.6/site-packages/ssh/transport.py", line 844, in open_sftp_client
    return SFTPClient.from_transport(self)
  File "/home/user/env/lib/python2.6/site-packages/ssh/sftp_client.py", line 105, in from_transport
    chan.invoke_subsystem('sftp')
  File "/home/user/env/lib/python2.6/site-packages/ssh/channel.py", line 240, in invoke_subsystem
    self._wait_for_event()
  File "/home/user/env/lib/python2.6/site-packages/ssh/channel.py", line 1114, in _wait_for_event
    raise e
ssh.SSHException: Channel closed.
Disconnecting from root@server.com... done.

我是否需要在远程服务器上配置以便能够使用put发送文件?

2 个答案:

答案 0 :(得分:8)

感谢@Drake我发现远程计算机上的sftp服务器存在问题。

为此进行测试:

$ sftp remote-server
subsystem request failed on channel 0
Couldn't read packet: Connection reset by peer

我读到这是为了启用sftp我需要添加行

Subsystem sftp /usr/lib/openssh/sftp-server

/etc/ssh/sshd_config并重新启动(/etc/init.d/ssh restart)ssh服务。但是这条线已经存在并且无法正常工作。

然后,在阅读http://forums.debian.net/viewtopic.php?f=5&t=42818后,我将该行更改为

Subsystem sftp internal-sftp

重新启动ssh服务,现在正在运行:

$ sftp remote-server
Connected to remote-server
sftp>

答案 1 :(得分:3)

我有同样的问题。 我发现我的服务器上没有安装sftp。 我安装了openssh并重新启动了sshd服务。

yum -y install openssh
service sshd restart

然后我也有同样的问题。 我检查了系统日志/ var / log / messages。我发现以下错误

Jul  3 04:23:20 <ip> sshd[13996]: subsystem request for sftp
Jul  3 04:23:20 <ip> sshd[13996]: error: subsystem: cannot stat /usr/libexec/sftp-   server: No such file or directory
Jul  3 04:23:20 <ip> sshd[13996]: subsystem request for sftp failed, subsystem not found

我找到了位于“/ usr / libexec / openssh / sftp-server”中的sftp-server位置,脚本正在查看“/ usr / libexec / sftp-server”位置 我创建了符号链接,我的问题得到了解决。

root@<ip> fabric]# locate sftp-server
/usr/libexec/openssh/sftp-server
/usr/share/man/man8/sftp-server.8.gz

ln -s /usr/libexec/openssh/sftp-server /usr/libexec/sftp-server