前沿:
這兩天把報警平台放在了docker里面跑了,但是宿主機本身性能就不好,所以導致mongodb到掛了好幾次了。這次搞了一台牛逼的服務器,雖說是opentstack里面的主機,但是iops 很不錯。
感謝向軍同學的幫助,不然就升級uek內核就能搞死我。
你的程序放在docker里面遷移起來很是方便,像是以前的話,需要重新部署環境和靜態文件。 放在docker里面的話,只是需要export備份封裝后,scp、rsync遷移到別的服務器就可以了。
我這邊的redis和mongodb分在不同的容器里面的。 廢話不多說,開始遷移。。。
查找正在運行的容器id ~
root@dev-ops:~# docker ps -a
root@dev-ops:~#
root@dev-ops:~# docker export 70c74ebbfac4 >ubuntu_sshd.tar
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
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。
docker 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 http://rfyiamcool.blog.51cto.com/1030776/1540414
備份遷移的方式自己選,推薦用export,畢竟save太大了,對於歷史也沒啥用處 !
對於數據安全關注更深的話,可以用docker volumes這樣的數據映射。
開源項目Docker,Red Hat新的虛擬化選擇 http://www.linuxidc.com/Linux/2013-10/91051.htm
dockerlite: 輕量級 Linux 虛擬化 http://www.linuxidc.com/Linux/2013-07/87093.htm
Docker的搭建Gitlab CI 全過程詳解 http://www.linuxidc.com/Linux/2013-12/93537.htm
Docker 和一個正常的虛擬機有何區別? http://www.linuxidc.com/Linux/2013-12/93740.htm
Docker 將改變所有事情 http://www.linuxidc.com/Linux/2013-12/93998.htm
以下是我發掘到的內容:
Docker是如何工作的(簡單說明)
Docker是基於鏡像的。鏡像類似於已經包含了文件、配置和安裝好的程序的虛擬機鏡像。同樣的,你可以像啟動虛擬機一樣啟動多個鏡像實例。運行中的鏡像稱為容器。你可以修改容器(比如刪除一個文件),但這些修改不會影響到鏡像。不過,你使用docker commit <container-id> <image-name>命令可以把一個正在運行的容器變成一個新的鏡像。
舉個例子:
# 像Docker官方的hello world例子一樣,拉取一個叫busybox的鏡像 sudo docker pull busybox # 查看本地已經有哪些鏡像 # 我們可以看到busybox sudo docker images # 現在讓我們來修改下busybox鏡像的容器 # 這次,我們創建一個文件夾 sudo docker run busybox mkdir /home/test # 讓我們再看看我們有哪些鏡像了。 # 注意每條命令執行后容器都會停止 # 可以看到有一個busybox容器 sudo docker ps -a # 現在,可以提交修改了。 # 提交后會看到一個新的鏡像busybox-1 # <CONTAINER ID> 是剛剛修改容器后得到的ID sudo docker commit <CONTAINER ID> busybox-1 # 再看看我們有哪些鏡像。 # 我們現在同時有busybox和busybox-1鏡像了。 sudo docker images # 我們執行以下命令,看看這兩個鏡像有什么不同 sudo docker run busybox [ -d /home/test ] && echo 'Directory found' || echo 'Directory not found' sudo docker run busybox-1 [ -d /home/test ] && echo 'Directory found' || echo 'Directory not found'
現在,我們有兩個不同的鏡像了(busybox和busybox-1),還有一個通過修改busybox容器得來的容器(多了一個/home/test文件夾)。下面來看看,是如何持久化這些修改的。
導出(Export)
#Export命令用於持久化容器(不是鏡像)。所以,我們就需要通過以下方法得到容器ID: sudo docker ps -a #接着執行導出: sudo docker export <CONTAINER ID> > /home/export.tar
sudo docker export <CONTAINER ID> > /home/export.tar
sudo docker export <CONTAINER ID> -o /home/export.tar
最后的結果是一個2.7MB大小的Tar文件(比使用save命令稍微小些)。
保存(Save)
#Save命令用於持久化鏡像(不是容器)。所以,我們就需要通過以下方法得到鏡像名稱: sudo docker images #接着執行保存: sudo docker save busybox-1 > /home/save.tar
sudo docker save busybox-1 > /home/save.tar
sudo docker save busybox-1 -o /home/save.tar
最后的結果是一個2.8MB大小的Tar文件(比使用export命令稍微大些)。
它們之間的不同
現在我們創建了兩個Tar文件,讓我們來看看它們是什么。首先做一下小清理——把所有的容器和鏡像都刪除:
# 查看所有的容器 sudo docker ps -a # 刪除它們 sudo docker rm <CONTAINER ID> # 查看所有的鏡像 sudo docker images # 刪除它們 sudo docker rmi busybox-1 sudo docker rmi busybox
譯注:可以使用 docker rm $(docker ps -q -a) 一次性刪除所有的容器,docker rmi $(docker images -q) 一次性刪除所有的鏡像。
現在開始導入剛剛導出的容器:
cat /home/export.tar | sudo docker import - busybox-1-export:latest
# 導入export.tar文件 cat /home/export.tar | sudo docker import - busybox-1-export:latest # 查看鏡像 sudo docker images # 檢查是否導入成功,就是啟動一個新容器,檢查里面是否存在/home/test目錄(是存在的) sudo docker run busybox-1-export [ -d /home/test ] && echo 'Directory found' || echo 'Directory not found
使用類似的步驟導入鏡像:
docker load < /home/save.tar
# 導入save.tar文件 docker load < /home/save.tar # 查看鏡像 sudo docker images # 檢查是否導入成功,就是啟動一個新容器,檢查里面是否存在/home/test目錄(是存在的) sudo docker run busybox-1 [ -d /home/test ] && echo 'Directory found' || echo 'Directory not found'
那,它們之間到底存在什么不同呢?我們發現導出后的版本會比原來的版本稍微小一些。那是因為導出后,會丟失歷史和元數據。執行下面的命令就知道了:
# 顯示鏡像的所有層(layer)
sudo docker images --tree
執 行命令,顯示下面的內容。正你看到的,導出后再導入(exported-imported)的鏡像會丟失所有的歷史,而保存后再加載(saveed- loaded)的鏡像沒有丟失歷史和層(layer)。這意味着使用導出后再導入的方式,你將無法回滾到之前的層(layer),同時,使用保存后再加載 的方式持久化整個鏡像,就可以做到層回滾(可以執行docker tag <LAYER ID> <IMAGE NAME>來回滾之前的層)。
vagrant@Ubuntu-13:~$ sudo docker images --tree
├─f502877df6a1 Virtual Size: 2.489 MB Tags: busybox-1-export:latest
└─511136ea3c5a Virtual Size: 0 B
└─bf747efa0e2f Virtual Size: 0 B
└─48e5f45168b9 Virtual Size: 2.489 MB
└─769b9341d937 Virtual Size: 2.489 MB
└─227516d93162 Virtual Size: 2.489 MB Tags: busybox-1:latest





