docker容器引擎如何跨服务器的迁移? export和save

这两天把报警平台放在了docker里面跑了,但是宿主机本身性能就不好,所以导致mongodb到挂了好几次了。这次搞了一台牛逼的服务器,虽说是opentstack里面的主机,但是iops 很不错。

程序放在docker里面迁移起来很是方便,像是以前的话,需要重新部署环境和静态文件。 放在docker里面的话,只是需要export备份封装后,scp、rsync迁移到别的服务器就可以了。

我这边的redis和mongodb分在不同的容器里面的。 废话不多说,开始迁移。。。

查找正在运行的容器id ~

root@dev-ops:~# docker ps -a

   
CONTAINER ID        IMAGE                           COMMAND             CREATED             STATUS              PORTS                   NAMES
459e57c9a5d9        rastasheep/ubuntu-sshd:latest   /bin/bash           About an hour ago   Up 45 minutes       22/tcp                  compassionate_ptolemy  
70c74ebbfac4        rastasheep/ubuntu-sshd:14.04    /usr/sbin/sshd -D   About an hour ago   Up About an hour    0.0.0.0:49157->22/tcp   s                      
3ebbc244c486        rastasheep/ubuntu-sshd:latest   /usr/sbin/sshd -D   18 hours ago        Up About an hour    22/tcp                  redis_t2               
ed7887b93aa4        rastasheep/ubuntu-sshd:latest   /usr/sbin/sshd -D   19 hours ago        Up About an hour    0.0.0.0:49153->22/tcp   redis_test

         
root@dev-ops:~#

root@dev-ops:~# docker export 70c74ebbfac4 >ubuntu_sshd.tar

root@dev-ops:~#

root@dev-ops:~#

root@dev-ops:~# du -sh ubuntu_sshd.tar

353M    ubuntu_sshd.tar

然后把这个ubuntu_sshd.tar  传到别的服务器上。

root@31-53:~# cat ubuntu_sshd.tar | sudo docker import - niubi:latest
8f2baf1b1cf479e366524007faad6d2e2671fc693716043a4812556bc8ac9204
root@31-53:~#

本来只是想把程序、mongodb、redis迁移过去。 既然迁移,干脆把所有的images迁移到新的节点上来。

docer export 对应导入的命令是cat xxx | docker import - name 。我这里用的是niubi:latest ......

cat ubuntu_sshd.tar | sudo docker import - niubi:latest

上面的方式是用docker export。 export是当前的状态,docker save 是针对镜像images。

主要的区别是 save是可以回滚以前的配置。 export 只是当前的。

我们通过 docker images --tree 看到他的历史记录。Docker的文件系统AUFS,一种“增量文件系统”,用户所做修改以增量的方式保存,所以才能看到这些历史的增量。

咱们用save 看看备份效果。 是1.1G  ,这里是包含那些记录的。刚才咱们用export测试的时候,会发现文件只有300M左右。

root@dev-ops:~# docker save rastasheep/ubuntu-sshd >ubuntu_sshd.tar
 
root@dev-ops:~#
root@dev-ops:~#
root@dev-ops:~# du -sh ubuntu_sshd.tar
1.1G    ubuntu_sshd.tar
root@dev-ops:~#

我估计如果有分布式文件系统 ,比如mfs,nfs。可以更好的试试用docker的数据卷来做本地文件夹和容器内的关联。 这样的话,备份更加自定义了。 毕竟环境这东西不会变,变的只是data数据,然后文件目录又在分布式文件里面,可以更好做迁移。只要那边启动一个环境,目录一关联就可以了。

sudo docker run --volumes-from dbdata -v $(pwd):/backup ubuntu tar cvf /backup/backup.tar /dbdata

备份迁移的方式自己选,推荐用export,毕竟save太大了,对于历史也没啥用处 !

对于数据安全关注更深的话,可以用docker volumes这样的数据映射。

时间: 2024-09-17 06:56:40

docker容器引擎如何跨服务器的迁移? export和save的相关文章

你还不造吗?Docker容器技术5大窍门!

Docker自从去年走到聚光灯下后,其粉丝基数就一直在增长.想要了解为什么,以及想从你的容器中获得更多,以下主要回顾了2015年Docker容器的五大窍门.2014年Docker复兴了容器技术,并在过去的一年里主导了整个容器市场.容器的便携性和可扩展性在云用户和开发人员那里得到了共鸣,并随着应用的增长,Docker不断地针对企业用户扩展其自身功能.尽管竞争对手争相提供类似服务,但Docker已经成为一个家喻户晓的名字.不过,一些企业仍然不确定他们是否应该采用容器以及如何将容器集成到他们的云环境中

这些Docker容器技术窍门你都知道吗?

Docker自从去年走到聚光灯下后,其粉丝基数就一直在增长.想要了解为什么,以及想从你的容器中获得更多,以下主要回顾了2015年Docker容器的五大窍门. 2014年Docker复兴了容器技术,并在过去的一年里主导了整个容器市场.容器的便携性和可扩展性在云用户和开发人员那里得到了共鸣,并随着应用的增长,Docker不断地针对企业用户扩展其自身功能. 尽管竞争对手争相提供类似服务,但Docker已经成为一个家喻户晓的名字.不过,一些企业仍然不确定他们是否应该采用容器以及如何将容器集成到他们的云环

【干货】全自主研发Docker容器调度引擎——Newbon

背景:       大家所熟知的Docker容器调度引擎包括,K8S, Swarm, Mesos和Rancher,这些调度引擎都是开源的国外引擎,各有各的特点.在同客户和圈内人士沟通中,很多人直言国内容器创业公司大多只是将各种开源组件集成在一起,同质化严重,没有核心竞争力.作为国内第一批的容器创业公司--Ghostcloud精灵云,深知国内需要在容器的诸多领域拥有真正完全可控,同时具有核心竞争力的产品.因此,容器云平台最核心的调度引擎迫切需要一个完全可控,自主的产品,在这种背景下Newbon应运

无忧之道:Docker中容器的备份、恢复和迁移

今天,我们将学习如何快速地对docker容器进行快捷备份.恢复和迁移.Docker是一个开源平台,用于自动化部署应用,以通过快捷的途径在称之为容器的轻量级软件层下打包.发布和运行这些应用.它使得应用平台独立,因为它扮演了Linux上一个额外的操作系统级虚拟化的自动化抽象层.它通过其组件cgroups和命名空间利用Linux内核的资源分离特性,达到避免虚拟机开销的目的.它使得用于部署和扩展web应用.数据库和后端服务的大规模构建组件无需依赖于特定的堆栈或供应者. 所谓的容器,就是那些创建自Dock

CoreOS 称 Docker 有根本性缺陷,推出自己的容器引擎 Rocket

Docker 容器 是目前最热的容器技术之一,而 CoreOS 则是基于 Linux 的操作系统,主要用于大规模的服务器发布.CoreOS 使用 Docker 容器构建其服务,并对 Docker 项目做出巨大贡献.但今天该公司 宣布 正在开发自己的容器引擎,因为其不同意 Docker 的发展方向. CoreOS 的 CEO Alex Polvi 在该新闻中写道:我们一直认为 Docker 应该成为一个简单的基础单元,但不幸的是事情并如我们期望的那样,Docker 正在构建一些工具用于发布云服务器

为什么用Yarn来做Docker容器调度引擎

前言 Mesos 其实我不是非常熟悉,所以有些内容可能会有失偏颇,带有个人喜好.大家也还是需要有自己的鉴别能力 Mesos和Yarn 都非常棒,都是可编程的框架.一个硬件,不能编程,就是死的,一旦可以编程就活了,就可以各种折腾,有各种奇思妙想可以实现,同样的,一个软件,只要是可编程的,基本也就活了,容易形成生态. Yarn VS Mesos 我先说说在做容器调度引擎的时候,为什么选择Yarn而不是Mesos. 可部署性 先说明下,这里探讨的是Yarn或者Mesos集群的部署,不涉其上的应用.Ya

跨主机网络概述 - 每天5分钟玩转 Docker 容器技术(48)

前面已经学习了 Docker 的几种网络方案:none.host.bridge 和 joined 容器,它们解决了单个 Docker Host 内容器通信的问题.本章的重点则是讨论跨主机容器间通信的方案. 跨主机网络方案包括: docker 原生的 overlay 和 macvlan. 第三方方案:常用的包括 flannel.weave 和 calico. docker 网络是一个非常活跃的技术领域,不断有新的方案开发出来,那么要问个非常重要的问题了: 如此众多的方案是如何与 docker 集成

跨主机使用 Rex-Ray volume - 每天5分钟玩转 Docker 容器技术(77)

上一节我们在 docker1 上的 MySQL 容器中使用了 Rex-Ray volume mysqldata,更新了数据库.现在容器已经删除,今天将演示在 docker2 中重新使用这个卷. 在 dokcer2 上执行如下命令,启动 MySQL 容器: docker run --name mydb_on_docker2 -v mysqldata:/var/lib/mysql -d mysql 新容器也使用相同的卷 mysqldata,不过这次不需要指定环境变量 MYSQL_ROOT_PASSW

虚拟化与Docker容器:云计算旧爱新欢的博弈

Docker容器技术--这个风头直追OpenStack的云计算开源项目,关于它的热议已席卷虚拟化乃至云计算行业,业内各大厂商(包括亚马逊.红帽.IBM和 VMware 等)都加入了容器的行列.这不禁让人想问:容器技术的崛起是否会带来虚拟化时代的结束? 容器,并不是一个新技术.容器的Linux版本最早见于内核2.3.x,名不见经传地发展了几十年,但在过去的一年里,Docker带领容器技术突然跃进了大众视野.Docker何以突然获得行业巨头的青睐? 从技术角度看,传统容器只解决了容器执行(run)问