Docker中通过模板创建镜像,Docker容器、仓库及数据管理

本文涉及的产品
容器镜像服务 ACR,镜像仓库100个 不限时长
简介:

1.通过模板创建镜像


(1)首先去下载一个模板

    http://openvz.org/Download/templates/precreated //下载速度不快,下载了一个centos6的模板centos-6-x86-minimal.tar.gz

(2)导入该镜像的命令为:

    cat centos-6-x86-minimal.tar.gz|docker import - centos6

(3)查看导入的镜像

    docker images

(4)导出镜像:

    把现有镜像,导出为一个文件:

docker save -o centos-net.tar centos-net

    我们还可以用该文件恢复本地镜像:

    blob.png

(5)删除本地镜像

    blob.png

(6)导入镜像

    docker load --input aming-centos.tar  或者

    docker load < aming-centos.tar

    blob.png

    

    docker push image_name  //可以把自己的镜像传到dockerhub官方网站上去,但前提是需要先注册一个用户,后续如果有需求再研究吧

2.容器管理

     docker create  -it  centos6   bash

    //这样可以创建一个容器,但该容器并没有启动

    blob.png

     docker start   a0fa08fb3a76   //启动容器后,可以使用 docker ps  查看到,有start 就有stop,和restart

    之前我们使用的docker run 相当于先create再start

(1)创建容器

     docker run -it centos bash  

    blob.png

    这样进入了一个虚拟终端里面,我们可以运行一些命令,使用命令exit或者ctrl d 退出该bash,当退出后这个容器也会停止。

(2)让容器在后台运行

    docker run -d  可以让容器在后台运行

    比如:docker run -d centos bash -c "while :; do echo "123"; sleep 2; done"

    blob.png

(3)给容器自定义名字

     docker run --name web -itd centos bash // --name 给容器自定义名字

    blob.png

(4)让容器退出后直接删除

    docker run --rm -it centos bash -c "sleep 30" //--rm 可以让容器退出后直接删除,在这里命令执行完容器就会退出

    blob.png

    blob.png

(5)获取到容器的运行历史信息

    docker logs 可以获取到容器的运行历史信息,用法如下

    docker logs a0fa08fb3a76

    blob.png

    docker attach 可以进入一个后台运行的容器,比如

    docker attach  container_id    //但是attach命令不算好用,比如我们想要退出终端,就得exit了,这样容器也就退出了,还有一种方法

(6)进入容器

    docker exec -it a0fa08fb3a76  bash  //可以临时打开一个虚拟终端,并且exit后,容器依然运行着

(7)删除容器

    docker rm  a0fa08fb3a76 //container_id是ps的时候查看到的,这样就可以把container删除,如果是运行的容器,可以加-f

(8)迁移容器

    docker  export  a0fa08fb3a76  > file.tar  // 导出容器,可以迁移到其他机器上,需要导入

(9)导入容器生成镜像

    cat file.tar |docker import - fxq_testos   //这样会生成fxq_tesos的镜像


3.仓库管理

(1)下载registry 镜像

    docker pull registry  

    #下载registry 镜像,registy为docker官方提供的一个镜像,我们可以用它来创建本地的docker私有仓库。

    blob.png

(2)以registry镜像启动容器

    docker run -d -p 5000:5000 registry  

    #以registry镜像启动容器,-p会把容器的端口映射到宿主机上,:左边为宿主机监听端口,:右边为容器监听端口

    blob.png

    curl 127.0.0.1:5000/v2/_catalog //可以访问它

    下面我们来把其中一个镜像上传到私有仓库

    blob.png

     docker tag centos 192.168.1.169:5000/centos

    //标记一下tag,必须要带有私有仓库的ip:port

(3)标记的镜像给推送到私有仓库

     docker push 192.168.1.169:5000/centos

    //把标记的镜像给推送到私有仓库

    blob.png

    此时并不会成功,Get https://192.168.1.169:5000/v2/: http: server gave HTTP response to HTTPS client

    更改配置文件,vi /etc/docker/daemon.json

    //更改为

    { "insecure-registries":["192.168.1.169:5000"] }

(4)重启服务

    systemctl restart docker

(5)查看容器

     docker ps -a

    //查看容器已经关闭,还需要启动

    blob.png

     docker start e5b31b

    //这里的 e5b31b 为registry容器id

(6)再次push

     docker push 192.168.1.169:5000/centos

    blob.png

    blob.png

(7)查看到推送上来的镜像

     curl 127.0.0.1:5000/v2/_catalog

    //可以查看到推送上来的镜像

    blob.png

(8)客户端下载镜像:

 前提:

    安装好docker-ce ,

    更改配置文件,vi /etc/docker/daemon.json

    //更改为

    { "insecure-registries":["192.168.1.169:5000"] }

    重启服务

     systemctl restart docker

(9)拉取镜像:

     docker pull 192.168.1.169:5000/centos

    blob.png

    blob.png


4.数据管理

(1)挂载本地的目录到容器里

     docker run -tid -v /data/:/data centos bash

    //-v 用来指定挂载目录,:前面的/data/为宿主机本地目录,:后面的/data/为容器里的目录,会在容器中自动创建

    blob.png

(2)挂载数据卷

    其实我们挂载目录的时候,可以指定容器name,如果不指定就随机定义了。比如上面我们没有指定,它就生成了一个名字为angry_shirley,这个名字可以使用命令 docker ps  看最右侧一列

     docker run -itd --volumes-from angry_shirley centos bash

    这样,我们使用centos镜像创建了新的容器,并且使用了 angry_shirley 容器的数据卷

    blob.png

(3)定义数据卷容器

    有时候,我们需要多个容器之间相互共享数据,类似于linux里面的NFS,所以就可以搭建一个专门的数据卷容器,然后其他容器直接挂载该数据卷。

    首先建立数据卷容器

     docker run -itd -v /data/ --name testvol centos  bash

     //注意这里的/data/是容器的/data目录,并非本地的/data/目录。 

    然后让其他容器挂载该数据卷

    blob.png

    

    docker run -itd  --volumes-from testvol centos bash

    blob.png

    在新容器中新建1.txt

    blob.png

    看原有testvol主机上的/data目录里就是有1.txt了

    blob.png




本文转自 枫叶云  51CTO博客,原文链接:http://blog.51cto.com/fengyunshan911/2070031
相关实践学习
MySQL基础-学生管理系统数据库设计
本场景介绍如何使用DMS工具连接RDS,并使用DMS图形化工具创建数据库表。
相关文章
|
1月前
|
数据库 Docker 容器
docker容器为啥会开机自启动
通过配置适当的重启策略,Docker容器可以在主机系统重启后自动启动。这对于保持关键服务的高可用性和自动恢复能力非常有用。选择适合的重启策略(如 `always`或 `unless-stopped`),可以确保应用程序在各种情况下保持运行。理解并配置这些策略是确保Docker容器化应用可靠性的关键。
224 93
|
4天前
|
网络协议 API Docker
Docker+consul容器服务的更新与发现
通过本文的介绍,我们详细探讨了如何结合Docker和Consul来实现容器服务的更新与发现。通过Consul的服务注册和发现功能,可以高效地管理和监控容器化服务,确保系统的高可用性和可扩展性。希望本文能帮助您在实际项目中更好地应用Docker和Consul,提高系统的可靠性和管理效率。
36 23
|
4天前
|
Ubuntu API 网络虚拟化
ubuntu22 编译安装docker,和docker容器方式安装 deepseek
本脚本适用于Ubuntu 22.04,主要功能包括编译安装Docker和安装DeepSeek模型。首先通过Apt源配置安装Docker,确保网络稳定(建议使用VPN)。接着下载并配置Docker二进制文件,创建Docker用户组并设置守护进程。随后拉取Debian 12镜像,安装系统必备工具,配置Ollama模型管理器,并最终部署和运行DeepSeek模型,提供API接口进行交互测试。
90 15
|
1月前
|
Ubuntu NoSQL Linux
《docker基础篇:3.Docker常用命令》包括帮助启动类命令、镜像命令、有镜像才能创建容器,这是根本前提(下载一个CentOS或者ubuntu镜像演示)、容器命令、小总结
《docker基础篇:3.Docker常用命令》包括帮助启动类命令、镜像命令、有镜像才能创建容器,这是根本前提(下载一个CentOS或者ubuntu镜像演示)、容器命令、小总结
157 6
《docker基础篇:3.Docker常用命令》包括帮助启动类命令、镜像命令、有镜像才能创建容器,这是根本前提(下载一个CentOS或者ubuntu镜像演示)、容器命令、小总结
|
2月前
|
搜索推荐 安全 数据安全/隐私保护
7 个最能提高生产力的 Docker 容器
7 个最能提高生产力的 Docker 容器
193 35
|
1月前
|
数据库 Docker 容器
docker容器为啥会开机自启动
通过配置适当的重启策略,Docker容器可以在主机系统重启后自动启动。这对于保持关键服务的高可用性和自动恢复能力非常有用。选择适合的重启策略(如 `always`或 `unless-stopped`),可以确保应用程序在各种情况下保持运行。理解并配置这些策略是确保Docker容器化应用可靠性的关键。
62 17
|
2月前
|
Ubuntu Linux 开发工具
docker 是什么?docker初认识之如何部署docker-优雅草后续将会把产品发布部署至docker容器中-因此会出相关系列文章-优雅草央千澈
Docker 是一个开源的容器化平台,允许开发者将应用程序及其依赖项打包成标准化单元(容器),确保在任何支持 Docker 的操作系统上一致运行。容器共享主机内核,提供轻量级、高效的执行环境。本文介绍如何在 Ubuntu 上安装 Docker,并通过简单步骤验证安装成功。后续文章将探讨使用 Docker 部署开源项目。优雅草央千澈 源、安装 Docker 包、验证安装 - 适用场景:开发、测试、生产环境 通过以上步骤,您可以在 Ubuntu 系统上成功安装并运行 Docker,为后续的应用部署打下基础。
96 8
docker 是什么?docker初认识之如何部署docker-优雅草后续将会把产品发布部署至docker容器中-因此会出相关系列文章-优雅草央千澈
|
1月前
|
运维 Java 虚拟化
《docker基础篇:1.Docker简介》,包括Docker是什么、容器与虚拟机比较、能干嘛、去哪下
《docker基础篇:1.Docker简介》,包括Docker是什么、容器与虚拟机比较、能干嘛、去哪下
117 12
|
1月前
|
Kubernetes Linux 虚拟化
入门级容器技术解析:Docker和K8s的区别与关系
本文介绍了容器技术的发展历程及其重要组成部分Docker和Kubernetes。从传统物理机到虚拟机,再到容器化,每一步都旨在更高效地利用服务器资源并简化应用部署。容器技术通过隔离环境、减少依赖冲突和提高可移植性,解决了传统部署方式中的诸多问题。Docker作为容器化平台,专注于创建和管理容器;而Kubernetes则是一个强大的容器编排系统,用于自动化部署、扩展和管理容器化应用。两者相辅相成,共同推动了现代云原生应用的快速发展。
181 11
|
Shell Docker 容器
在Docker中创建应用
本文讲的是在Docker中创建应用,【编者的话】下面内容是在基于Docker,用node.js开发和部署网络应用过程中获得的经验和教训。
1818 0