首页 > 其他分享 >一种实现docker容器嵌套的方法

一种实现docker容器嵌套的方法

时间:2024-11-15 14:48:54浏览次数:3  
标签:11 容器 57 testkvm 954298 嵌套 dockerd docker

【背景】

     有个用户需要在docker容器中再运行一个容器,实现容器嵌套, 研究了下,可以这样来实现。 

【方法】

1. 在系统上先安装一个docker服务,我的版本是20.10.17

[root@testkvm ~]# rpm -qa |grep docker
docker-ce-20.10.17-3.el7.x86_64
docker-ce-cli-20.10.17-3.el7.x86_64
docker-scan-plugin-0.17.0-3.el7.x86_64
docker-ce-rootless-extras-20.10.17-3.el7.x86_64
[root@testkvm ~]#
[root@testkvm ~]# docker version
Client: Docker Engine - Community
 Version:           20.10.17
 API version:       1.41
 Go version:        go1.17.11
 Git commit:        100c701
 Built:             Mon Jun  6 23:05:12 2022
 OS/Arch:           linux/amd64
 Context:           default
 Experimental:      true

Server: Docker Engine - Community
 Engine:
  Version:          20.10.17
  API version:      1.41 (minimum version 1.12)
  Go version:       go1.17.11
  Git commit:       a89b842
  Built:            Mon Jun  6 23:03:33 2022
  OS/Arch:          linux/amd64
  Experimental:     true
 containerd:
  Version:          1.6.6
  GitCommit:        10c12954828e7c7c9b6e0ea9b0c02b01407d3ae1
 runc:
  Version:          1.1.2
  GitCommit:        v1.1.2-0-ga916309
 docker-init:
  Version:          0.19.0
  GitCommit:        de40ad0
[root@testkvm ~]#
[root@testkvm ~]# systemctl status docker
● docker.service - Docker Application Container Engine
   Loaded: loaded (/usr/lib/systemd/system/docker.service; enabled; vendor preset: disabled)
   Active: active (running) since Thu 2024-11-14 04:57:42 CST; 2 days ago
     Docs: https://docs.docker.com
 Main PID: 954298 (dockerd)
    Tasks: 58
   Memory: 496.1M
   CGroup: /system.slice/docker.service
           └─954298 /usr/bin/dockerd -H fd:// --containerd=/run/containerd/containerd.sock

11月 14 04:57:42 testkvm dockerd[954298]: time="2024-11-14T04:57:42.624954732+08:00" level=info msg="ccResolverWrapper: sending update to cc>
11月 14 04:57:42 testkvm dockerd[954298]: time="2024-11-14T04:57:42.624970183+08:00" level=info msg="ClientConn switching balancer to \"pick>
11月 14 04:57:42 testkvm dockerd[954298]: time="2024-11-14T04:57:42.641600382+08:00" level=info msg="[graphdriver] using prior storage drive>
11月 14 04:57:42 testkvm dockerd[954298]: time="2024-11-14T04:57:42.646382394+08:00" level=info msg="Loading containers: start."
11月 14 04:57:42 testkvm dockerd[954298]: time="2024-11-14T04:57:42.779878052+08:00" level=info msg="Default bridge (docker0) is assigned wi>
11月 14 04:57:42 testkvm dockerd[954298]: time="2024-11-14T04:57:42.815611267+08:00" level=info msg="Loading containers: done."
11月 14 04:57:42 testkvm dockerd[954298]: time="2024-11-14T04:57:42.828962289+08:00" level=info msg="Docker daemon" commit=a89b842 graphdriv>
11月 14 04:57:42 testkvm dockerd[954298]: time="2024-11-14T04:57:42.829029829+08:00" level=info msg="Daemon has completed initialization"
11月 14 04:57:42 testkvm systemd[1]: Started Docker Application Container Engine.
11月 14 04:57:42 testkvm dockerd[954298]: time="2024-11-14T04:57:42.846595821+08:00" level=info msg="API listen on /run/docker.sock"
[root@testkvm ~]#

2. 上传一个centos-x86镜像,并以特权模式起一个容器

docker load -i  centos-x86.tar.gz
docker run -itd  --name ttdocker  --privileged  centos:latest bash
docker ps -a  | grep ttdocker

3. 进入容器,并额外开个会话,将docker安装包及nginx.tar镜像拷贝到容器里

docker exec -it -u 0 ttdocker bash
#另外开个会话,通过docker cp命令将安装包拷贝到容器中
docker cp docker/  ttdocker:/root/

4.在容器中安装docker服务,并执行dockerd命令启动docker

注意:在容器中不允许再用systemd方式启动docker.service守护进程,此处用dockerd命令启动

#先装iptables 2个依赖包
rpm -ivh libnfnetlink-1.0.1-4.el7.x86_64.rpm libnetfilter_conntrack-1.0.6-1.el7_3.x86_64.rpm

#再装iptables
rpm -ivh iptables-1.4.21-35.el7.x86_64.rpm --nodeps --force

#最后装docker
rpm -ivh ./*  --nodeps --force

#执行dockerd命令,启动docker进程
dockerd

5. 去第二个会话, 再登录一次ttdocker容器, 导入nginx镜像与创建容器

docker exec -it -u 0 ttdocker bash
docker load -i nginx1.tar
docker images
docker run -itd --name testnginx  nginx:stable-perl
docker ps -a

6. 检查nginx容器

【总结】

    由于容器中不能再用systemd来启动docker守护进程,需有个终端一直用dockerd命令来起进程,较为麻烦,有建议过用户直接起2个docker容器更简单, 单由于其业务特点只能以此种方式启动。 或许真有这种业务场景,需要嵌套使用吧, 此处只提供实现方法,不探讨实现价值。  

标签:11,容器,57,testkvm,954298,嵌套,dockerd,docker
From: https://blog.csdn.net/weixin_43948680/article/details/143798247

相关文章

  • Kubernetes网络调试:进入容器网络命名空间(netns)的实用指南
    在Kubernetes中,进入容器的网络命名空间(netns)是一个高级操作,通常用于网络调试和故障排除。以下是一些实用的技巧和步骤,帮助进入容器的netns:一、获取容器ID和进程ID(PID首先,需要使用kubectl命令获取目标Pod中容器的ID,然后根据容器运行时(如containerd或dockerd)获取容器的主进程PID......
  • dockerfile中cmd和entrypoint的区别
    cmd语法TheCMDinstructionhasthreeforms:CMD["executable","param1","param2"](execform,thisisthepreferredform)CMD["param1","param2"](asdefaultparameterstoENTRYPOINT)CMDcommandparam1par......
  • 5分钟上手 Docker:镜像优化
    Docker是一种流行的容器化技术,它允许开发者将应用程序及其所有依赖打包成一个标准化的单元——镜像。优化Docker镜像不仅能减小镜像的体积,提高下载和部署速度,还能增强安全性。在本文中,我们将介绍一些镜像优化的技巧,帮助你在5分钟内快速上手Docker镜像的优化。1.使用合适......
  • 搭建本地docker私服库
    1、本地镜像发布到私有库1.1、Docker Registry是什么1官方DockerHub地址:https://hub.docker.com/,中国大陆访问太慢了且准备被阿里云取代的趋势,不太主流。2Dockerhub、阿里云这样的公共镜像仓库可能不太方便,涉及机密的公司不可能提供镜像给公网,所以需要创建一个本地私人......
  • docker compose网络
    基本概念默认情况下,Compose会为我们的应用创建一个网络,服务的每个容器都会加入该网络中。这样,容器就可被该网络中的其他容器访问,不仅如此,该容器还能以服务名称作为hostname被其他容器访问。默认情况下,应用程序的网络名称基于Compose的工程名称,而项目名称基于docker-compose.yml......
  • Docker && Kubernetes
     Docker镜像与容器Docker中有两个重要概念。一个是容器(Container):容器特别像一个虚拟机,容器中运行着一个完整的操作系统。可以在容器中装Nodejs,可以执行npminstall,可以做一切你当前操作系统能做的事情另一个是镜像(Image):镜像是一个文件,它是用来创建容器的。如果你有装过......
  • 提问:如何实现,我在docker container中,curl localhost:11434时,实际访问的是宿主机的1143
    背景我们需要在dify中配置ollama。ollama服务起来之后,会把服务挂在localhost的11434上。但是,我的dify一般是在docker里起的。所以我在dockercontainer里,访问localhost:11434时,实际无法访问到宿主机的11434,也就没办法调用宿主机上的ollama。怎么解决?方法一:找到宿主机......
  • 什么是C++命名空间 有什么作用?如何定义使用命名空间?且交代命名空间是否允许嵌套?
    1)什么是C++命名空间有什么作用?命名空间的定义:在C++中,命名空间(Namespace)是一种将代码组织成逻辑组的机制,用于避免不同代码模块之间的命名冲突。它提供了一个声明区域,在该区域内可以定义各种类型、函数、变量等,并且这些定义的名称在该命名空间内是唯一的。命名空间的作用:......
  • centOS7 docker 安装步骤
    一、安装前检查工作:1.检查/etc/yum.repos.d/CentOS-Base.repo文件是否存在,如果不存在,从网络仓库中复制一份新的CentOS-Base.repo文件。sudocurl-o/etc/yum.repos.d/CentOS-Base.repohttp://mirrors.aliyun.com/repo/Centos-7.repo或者使用wget:sudowget-O/etc/yum.r......
  • 容器runtime
    https://forum.huawei.com/enterprise/en/comprehensive-comparison-of-docker-containerd-and-cri-o/thread/714267095098867712-667213860488228864https://duyanghao.github.io/sample-container-runtime/https://docs.openeuler.org/zh/docs/22.03_LTS_SP2/docs/Contain......