区别在于invoke_shell使用SSH shell通道,而exec_command使用SSH exec通道.
作为用户/开发人员对您真正意味着什么,实际上取决于SSH服务器,而不是Paramiko本身.
常见的* nix OpenSSH服务器:
> shell通道执行登录shell(就像使用SSH终端客户端登录一样).然后,shell将显示命令提示符并等待客户端/用户键入命令. shell通道的目的是实现交互式shell会话.这是非常罕见的事情.如果这样做,您通常希望使用终端仿真(Paramiko invoke_shell无条件地执行此操作,但实际上可以在没有终端仿真的情况下打开shell通道).在正常情况下,SSH终端客户端(如OpenSSH ssh或PuTTY)显然会使用shell通道.
> exec命令将命令作为“参数”并在隔离环境中执行 – 仍然通过用户的默认shell,但不作为“登录”shell,这可能会导致命令执行的显着差异.
exec通道的目的是自动执行命令.因此,通常您不希望使用终端仿真,以避免命令执行诸如分页,着色和主要交互式确认之类的奇特内容.这就是get_pty的默认值为False的原因.
当您在其命令行上指定要执行的命令时,OpenSSH ssh或PuTTY plink将使用exec通道:
ssh user@host command
对于不太常见的SSH服务器,差异可能更加显着.有些服务器甚至可能不支持其中一个频道.它们看起来同时支持两者也很常见,但其中一个(通常是执行官)完全被打破了.