分布式进阶(九)Ubuntu下使用nsenter进入Docker容器

举报
SHQ5785 发表于 2020/12/30 01:44:54 2020/12/30
【摘要】 使用nsenter进入Docker容器 Docker容器运行后,如何进入容器进行操作呢?起初我是用SSH。如果只启动一个容器,用SSH还能应付,只需要将容器的22端口映射到本机的一个端口即可。当我启动了五个容器后,每个容器默认是没有配置SSH Server的,安装配置SSHD,映射容器SSH端口,实在是麻烦。   我发现很多Docker镜像都是没有安装SSHD服务的,难...

使用nsenter进入Docker容器

Docker容器运行后,如何进入容器进行操作呢?起初我是用SSH。如果只启动一个容器,用SSH还能应付,只需要将容器的22端口映射到本机的一个端口即可。当我启动了五个容器后,每个容器默认是没有配置SSH Server的,安装配置SSHD,映射容器SSH端口,实在是麻烦。

 

我发现很多Docker镜像都是没有安装SSHD服务的,难道有其他方法进入Docker容器?

 

浏览了Docker的文档,我没有找到答案。还是要求助于无所不能的Google,万能的Google告诉我用nsenter吧。

 

在大多数Linux发行版中,util-linux包中含有nsenter.如果没有,你需要安装它.

 

cd /tmp

 

curl https://www.kernel.org/pub/linux/utils/util-linux/v2.24/util-linux-2.24.tar.gz 

 

tar -zxvf util-linux-2.24.tar.gz

 

cd util-linux-2.24

 

./configure --without-ncurses

 

make nsenter

 

cp nsenter /usr/local/bin

 

使用shell脚本 docker-enter,将如下代码保存为docker-enter, chmod 777 docker-enter

 

  #!/bin/sh

 

  if [ -e $(dirname "$0")/nsenter ]; then

    # with boot2docker, nsenter is not in the PATH but it is in the same folder

    NSENTER=$(dirname "$0")/nsenter

  else

    NSENTER=nsenter

  fi

 

  if [ -z "$1" ]; then

    echo "Usage: `basename "$0"` CONTAINER [COMMAND [ARG]...]"

    echo ""

    echo "Enters the Docker CONTAINER and executes the specified COMMAND."

    echo "If COMMAND is not specified, runs an interactive shell in CONTAINER."

  else

    PID=$(docker inspect --format "{{.State.Pid}}" "$1")

    if [ -z "$PID" ]; then

      exit 1

    fi

    shift

 

    OPTS="--target $PID --mount --uts --ipc --net --pid --"

 

    if [ -z "$1" ]; then

      # No command given.

      # Use su to clear all host environment variables except for TERM,

      # initialize the environment variables HOME, SHELL, USER, LOGNAME, PATH,

      # and start a login shell.

      "$NSENTER" $OPTS su - root

    else

      # Use env to clear all host environment variables.

      "$NSENTER" $OPTS env --ignore-environment -- "$@"

    fi

  fi

 

运行 docker-enter <container id> (前提是必须存在已经已经运行的容器),这样就进入到指定的容器中

文章来源: shq5785.blog.csdn.net,作者:No Silver Bullet,版权归原作者所有,如需转载,请联系作者。

原文链接:shq5785.blog.csdn.net/article/details/45965819

【版权声明】本文为华为云社区用户转载文章,如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。