Я потратил бесчисленные часы на то, чтобы заставить эту банальную работу работать, но она не сдвинется с места. Моя цель - развернуть военный файл, выполненный в Jenkins на MachineA, на MachineB с помощью команды scp
. Но я продолжаю иметь ошибки аутентификации.
Если я вручную ввел ssh в MachineA и запускаю следующую команду, она работает гладко:
scp -i ~/<keypairdemo.pem> <../*.war> ubuntu@<EC2-PRIVATE-IP>:~/apache-tomcat-8.5.39/webapps/
Теперь, если я добавлю эту точную команду в опцию shell script
в Jenkins, она выдаст следующую ошибку. Я пытался сделать chmod 777 dev/tty
, он ничего не сделал. Я возился с тем, что не могу даже сделать sudo su
сейчас на своем собственном экземпляре EC2!
[WarFileDemo] $ /bin/sh /tmp/jenkins3925660300944070231.sh
“Starting to copy the build - aPPLY”
Executing: program /usr/bin/ssh host <EC2-PRIVATE-IP>, user ubuntu, command scp -v -t ~/apache-tomcat-8.5.39/webapps/
OpenSSH_7.6p1 Ubuntu-4ubuntu0.3, OpenSSL 1.0.2n 7 Dec 2017
debug1: Reading configuration data /etc/ssh/ssh_config
debug1: /etc/ssh/ssh_config line 19: Applying options for *
debug1: Connecting to <EC2-PRIVATE-IP> [<EC2-PRIVATE-IP>] port 22.
debug1: Connection established.
debug1: key_load_public: No such file or directory
debug1: identity file /var/lib/jenkins/keypairdemo.pem type -1
debug1: key_load_public: No such file or directory
debug1: identity file /var/lib/jenkins/keypairdemo.pem-cert type -1
debug1: Local version string SSH-2.0-OpenSSH_7.6p1 Ubuntu-4ubuntu0.3
debug1: Remote protocol version 2.0, remote software version OpenSSH_7.6p1 Ubuntu-4ubuntu0.2
debug1: match: OpenSSH_7.6p1 Ubuntu-4ubuntu0.2 pat OpenSSH* compat 0x04000000
debug1: Authenticating to <EC2-PRIVATE-IP>:22 as 'ubuntu'
debug1: SSH2_MSG_KEXINIT sent
debug1: SSH2_MSG_KEXINIT received
debug1: kex: algorithm: curve25519-sha256
debug1: kex: host key algorithm: ecdsa-sha2-nistp256
debug1: kex: server->client cipher: chacha20-poly1305@openssh.com MAC: <implicit> compression: none
debug1: kex: client->server cipher: chacha20-poly1305@openssh.com MAC: <implicit> compression: none
debug1: expecting SSH2_MSG_KEX_ECDH_REPLY
debug1: Server host key: ecdsa-sha2-nistp256 SHA256:Ee13H6eEq0VyQlVMUh2zIPyi/3eO5lMhpoALmCOZS/A
debug1: read_passphrase: can't open /dev/tty: No such device or address
Host key verification failed.
lost connection
Единственный способ, которым я могу выполнить развертывание, - использовать плагин развертывания для Tomcat, для которого у меня есть учетные данные и URL-адрес сервера tomcat. Но я хочу сделать все это с помощью сценариев.