Сценарий туннеля ssh навсегда зависает при развертывании beanstalk - PullRequest
4 голосов
/ 14 июня 2019

Я пытаюсь создать туннель ssh при развертывании приложения на aws beanstalk. Я хочу поставить туннель как фоновый процесс, который всегда подключен при развертывании приложения. Сценарий навсегда зависает при развертывании, и я не понимаю, почему.

"/home/ec2-user/eclair-ssh-tunnel.sh":
mode: "000500" # u+rx
owner: root
group: root
content: |
  cd /root
  eval $(ssh-agent -s)
  DISPLAY=":0.0" SSH_ASKPASS="./askpass_script" ssh-add eclair-test-key </dev/null
# we want this command to keep running in the backgriund
# so we add & at then end
nohup ssh -L 48682:localhost:8080 ubuntu@[host...] -N &

и вот вывод, который я получаю от /var/log/eb-activity.log:

[2019-06-14T14:53:23.268Z] INFO  [15615] - [Application update suredbits-api-root-0.37.0-testnet-ssh-tunnel-fix-port-9@30/AppDeployStage1/AppDeployPostHook/01_eclair-ssh-tunnel.sh] : Starting activity...

ssh туннель порожден, и я могу найти его, выполнив:

[ec2-user@ip-172-31-25-154 ~]$ ps aux | grep 48682
root     16047  0.0  0.0 175560  6704 ?        S    14:53   0:00 ssh -L 48682:localhost:8080 ubuntu@ec2-34-221-186-19.us-west-2.compute.amazonaws.com -N

Если я уничтожу этот процесс, развертывание продолжится, как и ожидалось, что указывает на ошибку в туннельном скрипте. Кажется, я не могу узнать, где.

1 Ответ

0 голосов
/ 24 июня 2019

Вам нужно добавить опцию -n в ssh при запуске в фоновом режиме, чтобы избежать чтения из стандартного ввода.

...