SSH代理在docker compose容器内转发

前端之家收集整理的这篇文章主要介绍了SSH代理在docker compose容器内转发前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

无法打开与身份验证代理的连接.

我正在关注approach of mounting the $SSH_AUTH_SOCK as a volume,但是这样做了.

建立

的〜/ .ssh /配置

  1. Host *
  2. ForwardAgent yes

Dockerfile:

  1. FROM atlashealth/ruby:2.2.2
  2. RUN apt-get update -qq && \
  3. apt-get install -qy build-essential libxml2-dev libxslt1-dev \
  4. g++ qt5-default libqt5webkit5-dev xvfb dbus \
  5. libMysqLclient-dev \
  6. MysqL-client openssh-client git && \
  7. # cleanup
  8. apt-get clean && \
  9. cd /var/lib/apt/lists && rm -fr *Release* *Sources* *Packages* && \
  10. truncate -s 0 /var/log/*log

撰写yaml:

  1. web:
  2. build: "."
  3. environment:
  4. - SSH_AUTH_SOCK=/ssh-agent
  5. volumes:
  6. - "$SSH_AUTH_SOCK:/ssh-agent"

注意:我在我的作品上运行插值,因此$SSH_AUTH_SOCK被/private/tmp/com.apple.launchd.ZxGtZy6a9w/Listeners替换.

我已经在主机OSX上正确转发设置,它可以与另一个ubuntu主机配合使用.

docker-compose运行web bash

在容器

当我运行ssh-add -L时,它声明无法打开与身份验证代理的连接.

当我运行ssh-agent时,它会产生

  1. SSH_AUTH_SOCK=/tmp/ssh-vqjuo7FIfVOL/agent.21; export SSH_AUTH_SOCK;
  2. SSH_AGENT_PID=22; export SSH_AGENT_PID;
  3. echo Agent pid 22;

当我从bash运行echo $SSH_AUTH_SOCK时,它会产生/ ssh-agent

似乎compose使SSH_AUTH_SOCK可用于bash,但似乎ssh-agent没有获得相同的env.我错过了什么?

我使用whilp/ssh-agent解决了它,但您应该注意,这不是直接使用SSH_AUTH_SOCK,而是需要一个额外的长时间运行容器.为了便于使用,我将这种方法整合到docker-rails中.

>启动一个长时间运行的容器
docker run -d –name = ssh-agent whilp / ssh-agent:latest
>添加密钥
docker run –rm –volumes-from = ssh-agent -v~ / .ssh:/ ssh -it whilp / ssh-agent:latest ssh-add / ssh / id_rsa
>列出你的钥匙
docker run –rm –volumes-from = ssh-agent -v~ / .ssh:/ ssh -it whilp / ssh-agent:latest ssh-add -L
>将bash放入容器中并使用ssh -T git@bitbucket.org检查密钥

我的yaml看起来像:

  1. web:
  2. build: .
  3. working_dir: /project
  4. ports:
  5. - "3000"
  6. environment:
  7. # make ssh keys available via ssh forwarding (see volume entry)
  8. - SSH_AUTH_SOCK=/ssh-agent/socket
  9. volumes_from:
  10. # Use configured whilp/ssh-agent long running container for keys
  11. - ssh-agent

猜你在找的Docker相关文章