SCP schlägt ohne Fehler fehl

45

Ich habe seit einiger Zeit ein sehr merkwürdiges Verhalten von SCP festgestellt: Wenn ich versuche, eine Datei zu kopieren, enthält die Ausgabe von SCP eine Reihe von Unterstrichen, und die Datei wird nicht kopiert.

$ scp test.txt 192.168.0.2:~
[email protected]'s password: 
 ________________________________________

Wenn ich mit Midnight Commander eine SSH-Verbindung herstelle und Dateien kopiere, funktioniert dies.

Einige Infos zu meiner Maschine:

$ ssh -V
OpenSSH_5.8p1 Debian-1ubuntu3, OpenSSL 0.9.8o 01 Jun 2010

$ uname -a
Linux squatpc 2.6.38-10-generic #46-Ubuntu SMP Tue Jun 28 15:05:41 UTC 2011 i686 i686 i386 GNU/Linux

Und ich lasse Kubuntu 11.04 laufen.

Bearbeiten: Einige weitere Informationen wie in den Kommentaren angefordert:

$ scp -v test.txt 192.168.0.2:~
Executing: program /usr/bin/ssh host 192.168.0.2, user (unspecified), command scp -v -t -- ~
OpenSSH_5.8p1 Debian-1ubuntu3, OpenSSL 0.9.8o 01 Jun 2010
debug1: Reading configuration data /etc/ssh/ssh_config
debug1: Applying options for *
debug1: Connecting to 192.168.0.2 [192.168.0.2] port 22.
debug1: Connection established.
debug1: identity file /home/job/.ssh/id_rsa type 1
debug1: Checking blacklist file /usr/share/ssh/blacklist.RSA-2048
debug1: Checking blacklist file /etc/ssh/blacklist.RSA-2048
debug1: identity file /home/job/.ssh/id_rsa-cert type -1
debug1: identity file /home/job/.ssh/id_dsa type -1
debug1: identity file /home/job/.ssh/id_dsa-cert type -1
debug1: identity file /home/job/.ssh/id_ecdsa type -1
debug1: identity file /home/job/.ssh/id_ecdsa-cert type -1
debug1: Remote protocol version 2.0, remote software version OpenSSH_5.8p1 Debian-1ubuntu3
debug1: match: OpenSSH_5.8p1 Debian-1ubuntu3 pat OpenSSH*
debug1: Enabling compatibility mode for protocol 2.0
debug1: Local version string SSH-2.0-OpenSSH_5.8p1 Debian-1ubuntu3
debug1: SSH2_MSG_KEXINIT sent
debug1: SSH2_MSG_KEXINIT received
debug1: kex: server->client aes128-ctr hmac-md5 none
debug1: kex: client->server aes128-ctr hmac-md5 none
debug1: sending SSH2_MSG_KEX_ECDH_INIT
debug1: expecting SSH2_MSG_KEX_ECDH_REPLY
debug1: Server host key: ECDSA 28:f3:2b:31:36:43:9b:07:d8:33:ca:43:4f:ca:6c:4c
debug1: Host '192.168.0.2' is known and matches the ECDSA host key.
debug1: Found key in /home/job/.ssh/known_hosts:20
debug1: ssh_ecdsa_verify: signature correct
debug1: SSH2_MSG_NEWKEYS sent
debug1: expecting SSH2_MSG_NEWKEYS
debug1: SSH2_MSG_NEWKEYS received
debug1: Roaming not allowed by server
debug1: SSH2_MSG_SERVICE_REQUEST sent
debug1: SSH2_MSG_SERVICE_ACCEPT received
debug1: Authentications that can continue: publickey,password
debug1: Next authentication method: publickey
debug1: Offering RSA public key: /home/job/.ssh/id_rsa
debug1: Authentications that can continue: publickey,password
debug1: Trying private key: /home/job/.ssh/id_dsa
debug1: Trying private key: /home/job/.ssh/id_ecdsa
debug1: Next authentication method: password
[email protected]'s password: 
debug1: Authentication succeeded (password).
Authenticated to 192.168.0.2 ([192.168.0.2]:22).
debug1: channel 0: new [client-session]
debug1: Requesting [email protected]
debug1: Entering interactive session.
debug1: Sending environment.
debug1: Sending env LANG = en_US.UTF-8
debug1: Sending command: scp -v -t -- ~
 ________________________________________
debug1: client_input_channel_req: channel 0 rtype exit-status reply 0
debug1: channel 0: free: client-session, nchannels 1
debug1: fd 0 clearing O_NONBLOCK
debug1: fd 1 clearing O_NONBLOCK
Transferred: sent 2120, received 1872 bytes, in 0.3 seconds
Bytes per second: sent 7783.1, received 6872.6
debug1: Exit status 0

und

$ type scp
scp is hashed (/usr/bin/scp)
Job
quelle
1
Versuchen Sie es mit -v, um während des Kopiervorgangs einige Debugging-Informationen zu erhalten.
EightBitTony
Auch nur für den Fall ... Was ist die Ausgabe von type scp?
Rozcietrzewiacz
@EightBitTony: siehe meine Änderungen.
Job
@rozcietrzewiacz: siehe auch meine Änderungen :-)
Job
2
Wenn Sie dies ssh 192.168.0.2 echo hellotun, erhalten Sie eine andere Ausgabe als hello?
Gilles 'SO - hör auf böse zu sein'

Antworten:

77

Ok LOL, ich habe gerade herausgefunden, was das Problem ist.

Da ich Kühe so sehr mag, habe ich fortune | cowsaymeine .bashrcDatei an den Anfang gestellt, was beim Starten zu einer Ausgabe wie der folgenden führt bash:

 _______________________________________
< You will lose an important disk file. >
 ---------------------------------------
        \   ^__^
         \  (oo)\_______
            (__)\       )\/\
                ||----w |
                ||     ||

Dies ist alles in Ordnung (und manchmal lustig), wenn bashinteraktiv ausgeführt wird. Bash liest jedoch, ~/.bashrcwenn es sich um eine interaktive Shell und nicht um eine Anmeldeshell handelt oder wenn es sich um eine Anmeldeshell handelt und der übergeordnete Prozess rshdoder istsshd . Wenn Sie ausführen scp, startet der Server eine Shell, die eine Remote- scpInstanz startet . Die Ausgabe von ist .bashrcverwirrend, scpda sie auf die gleiche Weise wie die scpProtokolldaten gesendet wird. Dies ist offensichtlich ein bekannter Fehler, siehe hier für weitere Details.

Beachten Sie auch, dass die Unterstriche, die ich in der Frage erwähnt habe, in der oberen Zeile der Sprechblase stehen.

Die Lösung war also einfach: Ich habe Folgendes oben .bashrcauf dem Remote-Computer (Zielcomputer) platziert:

# If not running interactively, don't do anything
[[ $- == *i* ]] || return

Diese Zeile ist in der Standardeinstellung vorhanden .bashrc, wurde jedoch aufgrund meiner vielen (anscheinend nachlässigen) Änderungen entfernt.

Job
quelle
echo "don't have a cow" | cowsay
Stéphane Gimenez
Wow, nach Monaten, in denen scp gerade kaputt war, hast du mir endlich die Antwort gegeben. Daran hätte ich nie gedacht. Ich habe nur einen mv ~/.bashrc ~/.bashrc.bakTest durchgeführt, um sicherzugehen, dass dies das Problem ist, und es hat funktioniert, nachdem ich das getan habe.
Jondlm
@ScottStensland Dies muss sich oben auf der Fernbedienung befinden .bashrc. Der lokale ist irrelevant. Beachten Sie, dass ein Tippfehler in meinem Kommentar war (die Antwort ist richtig): es ist *i*, nicht *-*.
Gilles 'SO- hör auf böse zu sein'
NEIN NEIN NEIN. rtfm. bashrc wird für nicht interaktive Shells ausgeführt. Wenn Sie beim Anmelden eine Nachricht von einer glücklichen Kuh erhalten möchten, ändern Sie Ihr bash_profile. Wenn Sie jedes Mal, wenn Sie ein X-Window öffnen, Kuhweisheit wollen, versuchen Sie herauszufinden, ob dies eines der VIELEN Szenarien ist, in denen Sie das Terminal nicht schreiben sollten - unix.stackexchange.com/questions/9605/…
symcbean
5

AFAIK, der richtige Weg, um ungehindert zu aktivieren, scpist weniger, welche Bedingung für stdout in Ihrem ~/.bashrcSkript gilt, als vielmehr, die Bildschirmausgabe auf das ~/.bash_profileSkript zu beschränken. Zumindest funktioniert das so für meine Distribution (CentOS.)

Zur Verdeutlichung bearbeiten:

  1. Fügen Sie in Ihre ~ / .bashrc-Datei nur die Zeilen ein, die für "alle" Remoteverbindungen erforderlich sind.
  2. YMMV
Mark Hudson
quelle
etwas dagegen zu erklären? dh wie kann man die Bildschirmausgabe auf das .bash-Profil beschränken?
Javadba
1
Mit screenAusgabe meine ich echo "Greetings, Master"oder irgendetwas anderes, das die Ausgabe im Terminalfenster anzeigt. Fügen Sie das nicht in Ihr ~ / .bashrc ein - bewahren Sie es in Ihrem ~ / .bash_profile-Skript auf.
Mark Hudson