Docker 容器基础系统镜像打包

时间:2025-05-12 08:25:30
    因为容器本身是共享宿主操作系统内核,所以容器基础系统镜像包本身就是一个标准的 Linux rootfs + 用户自定义的工具。根据这个思路,我们就可以构建一个自己的容器基础系统镜像。

    构建标准的 Linux rootfs 的方式有很多种方法,Redhat、Debian、SUSE等主流的发行版都有提供相应的工具支持。

    大概的流程如下:

        构建基础的 rootfs —> 配置基础系统参数 —> 部署用户自定义软件 —> 清理系统 —> 打包为容器镜像 —> 测试镜像 —> 发布仓库

以 Ubuntu 16.04.01 LTS 版为例,制作一个 Ubuntu 16.04 LTS 的 Docker 基础系统镜像:

1、安装 Debootstrap :
        
        sudo apt install debootstrap

2、通过 Debootstrap 构建 Ubuntu 16.04 LTS 的 rootfs :

       1)、创建 rootfs 存放的位置,如我们把新的 rootfs 存放在 /opt/new_os:

                sudo mkdir -p /opt/new_os
    
        2)、构建基础 Ubuntu 16.04 LTS 的 rootfs(Debootstrap 工具的参数使用 --help 查看):
                
                sudo debootstrap --verbose --arch=amd64 xenial /opt/new_os /ubuntu

        3)、配置基础系统参数:

                a、切换到新 rootfs :
                        
                        sudo chroot /opt/new_os /bin/bash
    
                b、安装基础包(请根据实际需求安装):
        
                
                        apt -y update && apt -y upgrade && apt -y install vim locales

                c、配置系统字符集(根据提示进行):
    
                        dpkg-reconfigure locales

                d、配置时区:
    
                        cp /usr/share/zoneinfo/Asia/Shanghai /etc/localtime
    
                e、可选:配置第三方衍生系统版本信息(如:UbuntuKylin)
        
                       tee /etc/ubuntukylin-release <<-‘EOF'
                       DISTRIB_ID=Ubuntu Kylin
                       DISTRIB_RELEASE=16.04
                       DISTRIB_CODENAME=xenial
                       DISTRIB_DESCRIPTION="Ubuntu Kylin 16.04"
                       EOF
        
                f、清理系统:

                        rm -Rf /tmp/*  && apt clean

                g、 退出当前 rootfs
            
                        exit

        4)、打包并创建 Docker 镜像(前置条件:当前系统已经配置了 Docker 运行时环境):

                 sudo tar -C /opt/new_os/ -c . | sudo docker import - new_os

         5)、测试

                 sudo docker run new_os  cat /etc/lsb-release

3、发布到仓库(以发布到官方仓库为例,私有仓库请自行上传)

         sudo docker login shibingli@
         ……
         sudo docker tag new_os  shibingli/new_os
         sudo docker push shibingli/new_os

4、完成。

5、补充,如果要把当前的系统环境打包为容器基础镜像,主要是 rootfs 的处理,可以参考以下命令:

        1)、 tar --numeric-owner --exclude=/proc --exclude=/sys -cvf new_os.tar  /
        2)、 cat new_os.tar | docker import - new_os

    或

        sudo tar --numeric-owner --exclude=/proc --exclude=/sys -C / -c . | sudo docker import - new_os


上述步骤完成后,再次通过 docker 登陆到 new_os ,然后清理一下无用的引导和内核配置文件即可。