Je peux me connecter via SSH en utilisant l'authentification par clé sur SERVER1 et SERVER2. Cependant, je ne peux pas copier de fichiers entre les deux serveurs. Pourquoi? Comment puis-je copier entre eux? (les données que je dois copier sont plus grandes que le disque dur de mon ordinateur portable)
Mon ordinateur portable fonctionne sous Ubuntu 10.04 LTS et les deux serveurs sont AIX 5300-10-02-0943. Mon ~/.ssh/known_hosts
fichier sur mon carnet contient les clés publiques de ces deux serveurs. J'utilise tsocks
car je dois utiliser un tunnel SSH pour atteindre ces deux serveurs. Les deux serveurs peuvent se cingler.
[USER@NOTEBOOK ~] tsocks scp -v -i /home/USER/.ssh/id_rsa -p -r root@SERVER1:/PATH/TO/DIR root@SERVER2:/PATH/TO/DIR
Executing: /usr/bin/ssh '-v' '-x' '-oClearAllForwardings yes' '-n' '-l' 'root' 'SERVER1' 'scp -v -r -p' '/PATH/TO/DIR' 'root@SERVER2:/PATH/TO/DIR'
OpenSSH_5.3p1 Debian-3ubuntu7, OpenSSL 0.9.8k 25 Mar 2009
debug1: Reading configuration data /etc/ssh/ssh_config
debug1: Applying options for *
debug1: Connecting to SERVER1 [SERVER1] port 22.
debug1: Connection established.
debug1: identity file /home/USER/.ssh/identity type -1
debug1: identity file /home/USER/.ssh/id_rsa type 1
debug1: Checking blacklist file /usr/share/ssh/blacklist.RSA-1024
debug1: Checking blacklist file /etc/ssh/blacklist.RSA-1024
debug1: identity file /home/USER/.ssh/id_dsa type -1
debug1: Remote protocol version 2.0, remote software version OpenSSH_5.2p1+sas
debug1: match: OpenSSH_5.2p1+sas pat OpenSSH*
debug1: Enabling compatibility mode for protocol 2.0
debug1: Local version string SSH-2.0-OpenSSH_5.3p1 Debian-3ubuntu7
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: SSH2_MSG_KEX_DH_GEX_REQUEST(1024<1024<8192) sent
debug1: expecting SSH2_MSG_KEX_DH_GEX_GROUP
debug1: SSH2_MSG_KEX_DH_GEX_INIT sent
debug1: expecting SSH2_MSG_KEX_DH_GEX_REPLY
debug1: Host 'SERVER1' is known and matches the RSA host key.
debug1: Found key in /home/USER/.ssh/known_hosts:59
debug1: ssh_rsa_verify: signature correct
debug1: SSH2_MSG_NEWKEYS sent
debug1: expecting SSH2_MSG_NEWKEYS
debug1: SSH2_MSG_NEWKEYS received
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 public key: /home/USER/.ssh/id_rsa
debug1: Server accepts key: pkalg ssh-rsa blen 151
debug1: Authentication succeeded (publickey).
debug1: channel 0: new [client-session]
debug1: Requesting [email protected]
debug1: Entering interactive session.
debug1: Sending environment.
debug1: Sending env LANG = en_US.utf8
debug1: Sending command: scp -v -r -p /PATH/TO/DIR root@SERVER2:/PATH/TO/DIR
Executing: program /applications/ssh/5.20.15.0/bin/ssh host SERVER2, user root, command scp -v -r -p -t /PATH/TO/DIR
OpenSSH_5.2p1+sas, OpenSSL 0.9.8k 25 Mar 2009
debug1: Reading configuration data /etc/ssh/ssh_config
debug1: Connecting to SERVER2 [SERVER2] port 22.
debug1: Connection established.
debug1: permanently_set_uid: 0/0
debug1: identity file /root/.ssh/identity type -1
debug1: identity file /root/.ssh/id_rsa type -1
debug1: identity file /root/.ssh/id_dsa type -1
debug1: Remote protocol version 2.0, remote software version OpenSSH_5.2p1+sas
debug1: match: OpenSSH_5.2p1+sas pat OpenSSH*
debug1: Enabling compatibility mode for protocol 2.0
debug1: Local version string SSH-2.0-OpenSSH_5.2
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: SSH2_MSG_KEX_DH_GEX_REQUEST(1024<1024<8192) sent
debug1: expecting SSH2_MSG_KEX_DH_GEX_GROUP
debug1: SSH2_MSG_KEX_DH_GEX_INIT sent
debug1: expecting SSH2_MSG_KEX_DH_GEX_REPLY
debug1: read_passphrase: can't open /dev/tty: No such device or address
Host key verification failed.
lost connection
debug1: client_input_channel_req: channel 0 rtype exit-status reply 0
debug1: channel 0: free: client-session, nchannels 1
Transferred: sent 1984, received 3848 bytes, in 0.3 seconds
Bytes per second: sent 6903.4, received 13389.2
debug1: Exit status 1
[USER@NOTEBOOK ~] tsocks scp -i /home/USER/.ssh/id_rsa -p -r root@SERVER1:/PATH/TO/DIR root@SERVER2:/PATH/TO/DIR
Host key verification failed.
lost connection
[USER@NOTEBOOK ~]
Réponses:
C'est très facile à corriger. Vous voyez, le serveur source ne connaît pas le serveur de destination et il ne peut pas vous demander de confirmer l'identité, car vous n'avez pas de terminal ouvert là-bas:
Connectez-vous simplement au compte / serveur source et essayez de ssh (ou scp) au compte dest, acceptez la clé d'hôte et annulez la connexion / scp. Vous devriez pouvoir copier.
Sinon, essayez:
Si vous avez une clé SSH avec accès au serveur de destination et pas le serveur source, l'ajout
-o "ForwardAgent=yes"
vous permettra de transférer votre agent SSH vers le serveur source afin qu'il puisse utiliser votre clé SSH pour se connecter au serveur de destination.la source
Un petit diagnostic: à partir de là
Je soupçonne (suppose) que cela fonctionne de cette façon, la copie de serveur à serveur avec les
scp
journauxSERVER1
et exécute lascp
commande pour envoyer le fichierSERVER2
; ainsi, l'appelant (deSERVER1
) doit s'authentifier. Maintenant, cela échoue car il n'est pas interactif (il n'y en a pas/dev/tty
) et il n'y a aucun moyen de demander une phrase secrète.Cela signifie que la copie de la clé
SERVER1
(je ne peux pas dire si cela est possible dans votre situation) pourrait probablement résoudre le problème (je pense ...) ( S'il n'y a pas de phrase secrète ... ce qui est plutôt mauvais )Modifier Une solution pourrait être la suivante, utilisez
sshfs
pour accéder aux fichiers que vous souhaitez envoyer, envoyez-les viascp
depuis lesshfs
répertoire -mounted. Cela devrait vous procurer l'interactivité nécessaire (si la supposition ci-dessus était juste) et garder toutes les clés locales.la source
ssh SERVER1 scp *args-YOU-specifiy*
pour un peu plus de flexibilité. Peut-être qu'unestdin
ruse pourrait aider ... Je ne suis pas sûr.ssh-agent
) de @ utopiabound sonne beaucoup mieux questdin
ruse.J'ai essayé cela et cela fonctionne pour moi entre deux systèmes, quelques différences:
ssh-add
)Essayez ce qui suit:
la source
vous voudrez peut-être utiliser l'
-3
option de scp, il dirige le trafic via votre ordinateur portable.c'est à dire
[USER@NOTEBOOK ~] scp -3 root@SERVER1:/PATH/TO/DIR root@SERVER2:/PATH/TO/DIR
la source
Essayez ces options pour ssh:
Dans mon cas, j'essaye de me connecter avec ssh depuis l'intérieur du SP dans postgreSQL. Échec de la première tentative:
La source du problème: impossible d'écrire dans know_host
Sortie de connexion suivante:
Succès !!!
la source