SCP échoue sans erreur


45

Cela fait quelque temps que je rencontre un comportement très étrange de SCP: chaque fois que j'essaie de copier un fichier, la sortie de SCP contient une série de caractères de soulignement et le fichier n'est pas copié.

$ scp test.txt 192.168.0.2:~
job@192.168.0.2's password: 
 ________________________________________

Lorsque je crée une connexion SSH à l'aide de Midnight Commander et que je copie des fichiers, cela fonctionne.

Quelques informations sur ma machine:

$ 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

Et je suis sous Kubuntu 11.04.

Edit: Quelques infos supplémentaires demandées par les commentaires:

$ 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
job@192.168.0.2'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 no-more-sessions@openssh.com
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

et

$ type scp
scp is hashed (/usr/bin/scp)

1
Essayez avec -v pour obtenir des informations de débogage pendant la copie.
EightBitTony

Aussi, juste au cas où ... Quelle est la sortie de type scp?
rozcietrzewiacz

@EightBitTony: voir mes modifications.
Job

@rozcietrzewiacz: voir mes modifications aussi :-)
Emploi

2
Si vous le faites ssh 192.168.0.2 echo hello, obtenez-vous une sortie autre que hello?
Gilles 'SO- arrête d'être méchant'

Réponses:


77

Ok LOL, je viens de comprendre quel est le problème.

Comme j'aime tellement les vaches, j'ai mis fortune | cowsayen haut de mon .bashrcfichier ce qui produit une sortie comme celle-ci lors du démarrage bash:

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

Tout cela est bien (et parfois drôle) lors d'une exécution bashinteractive. Cependant, bash lit ~/.bashrcquand il est interactif et non comme un shell de connexion, ou s’il s’agit d’un shell de connexion et que son processus parent est rshdousshd . Lorsque vous l'exécutez scp, le serveur lance un shell qui démarre une scpinstance distante . La sortie de .bashrcconfuse scpparce qu’elle est envoyée de la même manière que les scpdonnées de protocole est envoyée. C'est apparemment un bug connu, voir ici pour plus de détails.

Notez également que les traits de soulignement que j'ai mentionnés dans la question sont ceux qui se trouvent en haut de la bulle de texte.

La solution était donc simple: je place les éléments suivants en haut de .bashrcla machine distante (de destination):

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

Cette ligne est présente dans la valeur par défaut, .bashrcmais a été mise en place à cause de mes nombreuses modifications (apparemment négligentes).


echo "don't have a cow" | cowsay
Stéphane Gimenez

Wow, après des mois de scp juste d'être cassé, vous avez finalement éclairé la réponse pour moi. Je n'aurais jamais pensé à cela. Je viens de faire un mv ~/.bashrc ~/.bashrc.baktest et de m'assurer que c'était bien le problème, et cela a fonctionné après.
Jondlm

@ScottStensland Ceci doit être placé en haut de la télécommande .bashrc. Le local est hors de propos. Notez qu'il y avait une faute de frappe dans mon commentaire (la réponse est correcte): ce n'est *i*pas *-*.
Gilles, arrête de faire le mal.

NON NON NON. rtfm. bashrc est exécuté pour les shells non interactifs. Si vous voulez des messages de vache heureuse lorsque vous vous connectez, changez votre profil bash. Si vous voulez la sagesse de la vache à chaque fois que vous ouvrez une X-Window, essayez de déterminer s'il s'agit de l'un des nombreux scénarios dans lesquels vous ne devriez pas écrire le terminal - unix.stackexchange.com/questions/9605/…
symcbean

5

D'après les informations dont je dispose, le moyen approprié d'activer sans entrave scpest moins lié à la condition de la ~/.bashrcsortie standard dans votre script, mais plutôt à la restriction de la sortie d'écran au ~/.bash_profilescript. Au moins, c’est comme ça que ça marche pour ma distribution (CentOS.)

Modifier pour plus de clarté:

  1. Ne mettez que des lignes dans votre fichier ~ / .bashrc comme requis par "toutes" les connexions distantes (c.-à-d. Que définir certains vars ENV est correct, mais que l'écho d'un texte lisible par l'homme ne l'est pas.)
  2. YMMV

l'esprit exposant? comment limiter la sortie d’écran au profil .bash?
javadba

1
Par screensortie, je veux dire echo "Greetings, Master"ou tout ce qui affiche la sortie dans la fenêtre du terminal. Ne mettez pas cela dans votre ~ / .bashrc - conservez-le dans votre script ~ / .bash_profile.
Mark Hudson
En utilisant notre site, vous reconnaissez avoir lu et compris notre politique liée aux cookies et notre politique de confidentialité.
Licensed under cc by-sa 3.0 with attribution required.