Bu yazı docker nedir, container nedir ve temel operasyonları ve volume yapılarına dair genel bir bilginiz olduğunu varsayıyor.
Bir sunucuda çalışan bir konteynerimiz olsun. Bu konteynere bağlı bir ya da birden fazla volume olsun. Konteynerı farklı bir sunucuya taşımak (migrate) istiyoruz ya da sadece veriyi yedeklemek istiyoruz. Konteyneri, imageden tekrar oluşturmak çok kolay, önemli olan veriyi nasıl taşıyacağımız, nasıl yedekleyeceğimiz. Aşağıda bunu örneklerle açıklamaya çalıştım.
Backup
Bir containerım <source>
var, volume bağlı. Bu volumeleri yani datayı yedeklemek istiyorum. Direkt olarak volume’ü yedekleyemiyoruz. Geçici bir container üzerinden işlem yapıyoruz, bu containerın yapacakları
- İlgili volumeleri mount etmek
- Yedeklenecek dizinleri .tar haline getirmek
- .tar dosyasını dışarıya atmak host makine üzerinde saklamak
docker run --rm --volumes-from <source> -v /root/backup/<source>:/backup alpine tar cf /backup/backup.tar /directory/we/want/to/backup
Yukarıdaki komut;
- alpine image’i çalıştırarak bir container oluşturacak.
- source container’ındaki tüm volumeleri aynı şekilde mount edecek.
- host makine üzerinde /root/backup/source dizinini containerda /backup dizinine mount edecek.
- containerda tar cf komutunu çalıştıracak ve yedeklenmek istenen dizini tarlayıp backup.tar dosyasını oluşturacak.
Bir örnek üzerinden süreci tane tane anlatalım. Önce boş bir volume ve oluşturalım.
docker volume create test
Volume için aşağıdaki dizin oluşacaktır ve içi boş olacaktır.
ls /var/lib/docker/volumes/test/_data
Oluşturduğumuz volume’ü kullarak yine test adında yeni bir container oluşturalım.
docker run -it --name test -v test:/test ubuntu /bin/bash
Test volume’ü /test dizinine mount edilmiş, test adında bir container ubuntu image’inden oluşturuldu ve /bin/bash çalıştırıldı. Bash ortamında artık container’ın içindeyiz. Aşağıdaki komutlarla test amaçlı oluşturduğumuz dizinde birkaç dosya oluşturalım.
cd /test
touch f1 f2 f3
exit
Container içerisinde /test dizininde f1, f2, f3 adlarında 3 boş dosya oluşturduk. Bu dosyaları host üzerinde mount ettiğimiz volume içerisinde görebiliriz.
ls /var/lib/docker/volumes/test/_data
Bu dosyaları yani container verisini, a.k.a volume, yedeklemek istiyoruz. Yedekleme işlemi için yeni bir container create edeceğiz. Bu konteynerin tek görevi yedeklemeyi yapmak, işimiz bitince sileceğiz.
- Bu container’a ilgili volume mount edilecek.
- Container, artık kendisine bağlanmış olan veri ile tar ball oluşturacak.
- Amacını yerine getiren konteyner sistemden silinecek.
docker run --rm --volumes-from test -v /root/backup/test_data:/backup alpine tar cf /backup/backup.tar /test
Transfer
Eğer gerekiyorsa veriyi yedeklemek için oluşturduğumuz .tar dosyasını farklı bir host’a taşıyıp orada restore edebiliriz veya aynı hostta da restore edebiliriz.
sftp user@hostipaddress
put backup.tar
bye
Restore
Varsayalım ki test_restore
adında bir volume oluşturup veriyi bu volume üzerine restore etmek istiyoruz.
docker volume create test_restore
docker run --rm -v test_restore:/restore -v /root/backup/test_data/:/backup alpine tar xf /backup/backup.tar -C /restore
Yukarıdaki komutu adım adım açıklarsak:
- alpine image’ini kullanarak bir container oluştur.
- test_restore volume’ünü container üzerindeki /restore dizinine mount et.
- host üzerindeki /root/backup/test_data dizinini, container üzerinde /backup dizinine mount et.
- /backup/backup.tar dosyasını /restore dizinine extract et.
- oluşturduğun containeri sil.
Kontrol amaçlı aşağıdaki dizine bakılabilir.
ls /var/lib/docker/volumes/test_restore/_data
Real Life Example
GitLab Image
Burada sadece birkaç kod paylaşarak bir konteyner için birden fazla directory veya volume olduğunda nasıl yapılacağını ele alacağım.
Backup Gitlab
docker run --rm --volumes-from gitlab -v /root/backup/gitlab/:/backup alpine tar cf /backup/backup.tar /var/log/gitlab /etc/gitlab /var/opt/gitlab
Restore Gitlab
docker run --rm -v gitlab_logs:/var/log/gitlab -v gitlab_config:/etc/gitlab -v gitlab_data:/var/opt/gitlab -v /root/backup/gitlab:/backup alpine tar xf /backup/backup.tar -C /
Grafana Image
Backup Grafana
docker run --rm --volumes-from grafana -v $(pwd):/backup alpine tar cf /backup/backup.tar /var/lib/grafana
Restore Grafana
docker volume create grafana
docker run --rm -v grafana:/var/lib/grafana -v $(pwd):/backup alpine tar xf /backup/backup.tar -C /