docker的容器修改后保存及更新本地镜像

列出镜像:

docker命令images
获取镜像:

#生产中我们都是自己搭建自己的私有仓库
注意:从第三方镜像仓库获取镜像可能出现https证书问题,例如:

解决方案,还是建议通过nginx+ssl的代理方式来实现安全。如果只是为了学习,可以用以下办法:
到/etc/sysconfig/default目录,找到docker文件,在其中添加如下代码:

之后重启docker服务:

镜像保存与导入
保存方式一:save
save命令会将镜像完整保存,包括历史版本和元数据信息,所以文件可能比较大。
-o: 表示以文件的形式导出 紧跟在-o后面的是导出文件保存的位置 最后是镜像(仓库:TAG,或者镜像id)

保存方式二:export
确切的说,export其实是容器的保存,只把镜像当前的状态保存下来,没有历史版本等信息,所有文件比较小
-o:表示以文件形式导出 紧跟在-o后面的是导出文件保存位置
最后是容器的id 容器通过sudo docker ps -a 查看
docker export -o ubuntu1204.tar d0751467dcad
镜像导入:
docker load
sudo docker load < /home/fengzheng/Docker/ubtuntu12.04.tar
镜像删除删除镜像前,要先把依赖于这个镜像的容器删除(sudo docker rm 容器id)
删除镜像的命令是docker rmi [镜像id]

提交修改的容器,并生成新的镜像
当对现有容器进行修改后,例如安装了某些软件、修改了配置等,要保存当前修改并生成新的镜像,使用docker commit命令 ,这个命令和git的commit命令很像
# -a:修改者信息 -m:注释、说明 紧跟着当前操作的容器id 最后是要生成的新的镜像名称

常用参数解释:

-t 表示让Docker分配一个伪终端并绑定到容器的标准输入上
-i 表示让容器的标准输入保持打开
-d 表示以守护方式打开(即非交互模式,后台运行)
还有一个比较常用的,做网络配置时端口映射的参数-p,例如下面的命令将宿主机的3222端口映射到容器的22端口、将宿主机的3280端口映射到容器的22端口,用法如下:
#-p 设置端口映射 -p 宿主机端口:容器端口
sudo docker run -t -i -p 3222:22 -p 3280:80 87e5b6b3ccc1 /bin/bash
查看容器列表

#查看已启动的容器

#查看所有容器

启动一个已存在的容器  
#后面的id为容器ID

进入容器  

停止容器

删除容器
容器必须是停止状态的才可以删除,否则-f

导出容器
#将容器id为7691a814370e 的导出到当前目录下 名称为ubuntu.tar

发表评论

:?: :razz: :sad: :evil: :!: :smile: :oops: :grin: :eek: :shock: :???: :cool: :lol: :mad: :twisted: :roll: :wink: :idea: :arrow: :neutral: :cry: :mrgreen: