
Ich habe ein Bash-Skript, das mehrere SSH-Befehle ausführt, und bin auf ein Problem gestoßen. Ich habe daran gearbeitet, eine automatische SSH-Schlüsselgenerierung für das Skript hinzuzufügen, und habe einen seltsamen Fehler, bei dem die SSH-Befehle funktionieren, wenn sie manuell über die Konsole eingegeben werden, aber nicht innerhalb des Skripts.
Die Befehlsfolge ist wie folgt: (Schlüsselgenerierung > Suche nach Remote-Skript > Ausführen des Remote-Skripts)
mkdir -p ~/.ssh
echo "StrictHostKeyChecking no" > ~/.ssh/config
ssh-keygen -q -t rsa -N '' <<< ""$'\n'"y" 2>&1 >/dev/null
sshpass -f password.txt ssh-copy-id [email protected]
ssh [email protected] "test -e /home/user/script.sh"
ssh [email protected] "echo password | sudo -S /home/user/script.sh > log.txt"
Dies funktioniert in der Konsole einwandfrei, aber im Skript funktioniert es plötzlich nicht mehr. Der einzige Unterschied besteht darin, dass im Skript einige Echos vorhanden sind, um Daten an ein Protokoll anzuhängen, was die SSH-Befehle nicht beeinträchtigen sollte.
Der erste SSH-Befehl funktioniert , der zweite jedoch nicht. Er erhält 6 Mal eine Verbindungsabweisung und gibt normalerweise einen Exit von 255 zurück. Unten sehen Sie ein Beispielprotokoll, wenn er mit dem Flag -v ausgeführt wird.ssh [email protected] "test -e /home/user/script.sh"
ssh [email protected] "echo password | sudo -S /home/user/script.sh > log.txt"
OpenSSH_7.2p2 Ubuntu-4ubuntu2.4, OpenSSL 1.0.2g 1 Mar 2016
debug1: Reading configuration data /root/.ssh/config
debug1: Reading configuration data /etc/ssh/ssh_config
debug1: /etc/ssh/ssh_config line 19: Applying options for *
debug1: Connecting to x.x.x.x [x.x.x.x] port 22.
debug1: connect to address x.x.x.x port 22: Connection refused
ssh: connect to host x.x.x.x port 22: Connection refused
OpenSSH_7.2p2 Ubuntu-4ubuntu2.4, OpenSSL 1.0.2g 1 Mar 2016
debug1: Reading configuration data /root/.ssh/config
debug1: Reading configuration data /etc/ssh/ssh_config
debug1: /etc/ssh/ssh_config line 19: Applying options for *
debug1: Connecting to x.x.x.x [x.x.x.x] port 22.
debug1: connect to address x.x.x.x port 22: Connection refused
ssh: connect to host x.x.x.x port 22: Connection refused
OpenSSH_7.2p2 Ubuntu-4ubuntu2.4, OpenSSL 1.0.2g 1 Mar 2016
debug1: Reading configuration data /root/.ssh/config
debug1: Reading configuration data /etc/ssh/ssh_config
debug1: /etc/ssh/ssh_config line 19: Applying options for *
debug1: Connecting to x.x.x.x [x.x.x.x] port 22.
debug1: connect to address x.x.x.x port 22: Connection refused
ssh: connect to host x.x.x.x port 22: Connection refused
OpenSSH_7.2p2 Ubuntu-4ubuntu2.4, OpenSSL 1.0.2g 1 Mar 2016
debug1: Reading configuration data /root/.ssh/config
debug1: Reading configuration data /etc/ssh/ssh_config
debug1: /etc/ssh/ssh_config line 19: Applying options for *
debug1: Connecting to x.x.x.x [x.x.x.x] port 22.
debug1: connect to address x.x.x.x port 22: Connection refused
ssh: connect to host x.x.x.x port 22: Connection refused
OpenSSH_7.2p2 Ubuntu-4ubuntu2.4, OpenSSL 1.0.2g 1 Mar 2016
debug1: Reading configuration data /root/.ssh/config
debug1: Reading configuration data /etc/ssh/ssh_config
debug1: /etc/ssh/ssh_config line 19: Applying options for *
debug1: Connecting to x.x.x.x [x.x.x.x] port 22.
debug1: connect to address x.x.x.x port 22: Connection refused
ssh: connect to host x.x.x.x port 22: Connection refused
OpenSSH_7.2p2 Ubuntu-4ubuntu2.4, OpenSSL 1.0.2g 1 Mar 2016
debug1: Reading configuration data /root/.ssh/config
debug1: Reading configuration data /etc/ssh/ssh_config
debug1: /etc/ssh/ssh_config line 19: Applying options for *
debug1: Connecting to x.x.x.x [x.x.x.x] port 22.
debug1: connect to address x.x.x.x port 22: Connection refused
ssh: connect to host x.x.x.x port 22: Connection refused
Und das PS AUX, wenn es lief.
ps aux | grep ssh
root 1287 0.0 0.3 65504 6500 ? Ss Sep18 0:02 /usr/sbin/sshd -D
root 4409 0.0 0.0 14220 888 pts/0 S+ 11:14 0:00 grep --color=auto ssh
root 20680 0.0 0.3 94860 6900 ? Ss 09:09 0:00 sshd: user [priv]
user 20760 0.0 0.1 94860 3540 ? S 09:09 0:00 sshd: user@notty
user 20761 0.0 0.1 12876 2000 ? Ss 09:09 0:00 /usr/lib/openssh/sftp-server
root 21024 0.0 0.3 94860 7052 ? Ss 08:13 0:00 sshd: user [priv]
user 21133 0.0 0.2 94860 4636 ? R 08:13 0:04 sshd: user@pts/0
Meine Frage ist also: Wie kann ich dieses Problem genau diagnostizieren und beheben?
Danke im Voraus.