Docker - Konteynerler ve Kabuklar

Varsayılan olarak, bir kapsayıcı başlattığınızda, bir de shell commandkabı aşağıda gösterildiği gibi başlatırken. Bu, konteynerlerle çalışırken önceki bölümlerde gördüğümüz şeydi.

Yukarıdaki ekran görüntüsünde, aşağıdaki komutu verdiğimizi görebilirsiniz -

sudo docker run –it centos /bin/bash

Bu komutu yeni bir konteyner oluşturmak için kullandık ve ardından konteynerden çıkmak için Ctrl + P + Q komutunu kullandık. Konteynerden çıktıktan sonra bile konteynerin hala var olmasını sağlar.

Docker ile konteynerin hala var olduğunu doğrulayabiliriz pskomut. Doğrudan konteynırdan çıkmamız gerekirse, konteynerin kendisi imha edilirdi.

Artık konteynırlara takmanın ve onları imha etmeye gerek kalmadan temiz bir şekilde çıkmanın daha kolay bir yolu var. Bunu başarmanın bir yolu,nsenter komut.

Koşmadan önce nsenter komutu, önce yüklemeniz gerekir nsentergörüntü. Aşağıdaki komut kullanılarak yapılabilir -

docker run --rm -v /usr/local/bin:/target jpetazzo/nsenter

Kullanmadan önce nsenter komutu, kabın İşlem Kimliğini almamız gerekiyor çünkü bu, nsenterkomut. İşlem kimliğini Docker üzerinden alabilirizinspect command ve aracılığıyla filtrelemek Pid.

Yukarıdaki ekran görüntüsünde görüldüğü gibi, ilk olarak docker psçalışan kapsayıcıları görmek için komut. Ef42a4c5e663 kimliğine sahip çalışan bir konteyner olduğunu görebiliriz.

Daha sonra Docker'ı kullanıyoruz inspect bu kabın yapılandırmasını incelemek için komut verin ve ardından grepyalnızca İşlem Kimliğini filtrelemek için komut. Ve çıktıdan Process ID'nin 2978 olduğunu görebiliriz.

Artık işlem kimliğine sahip olduğumuza göre, ilerleyebilir ve nsenter Docker konteynerine eklemek için komut.

nsenter

Bu yöntem, bir kişinin konteynerden çıkmadan bir konteynere bağlanmasına izin verir.

Sözdizimi

nsenter –m –u –n –p –i –t containerID komutu

Seçenekler

  • -u bahsetmek için kullanılır Uts namespace

  • -m bahsetmek için kullanılır mount namespace

  • -n bahsetmek için kullanılır network namespace

  • -p bahsetmek için kullanılır process namespace

  • -i s kapsayıcının etkileşimli modda çalışmasını sağlamak için.

  • -t konteynerin G / Ç akışlarını ana işletim sistemine bağlamak için kullanılır.

  • containerID - Bu, konteynerin kimliğidir.

  • Command - Bu, konteyner içinde çalıştırma komutudur.

Geri dönüş değeri

Yok

Misal

sudo nsenter –m –u –n –p –i –t 2978 /bin/bash

Çıktı

Çıktıdan şu noktaları gözlemleyebiliriz -

  • Komut istemi, bash shell doğrudan yayınladığımızda nsenter komut.

  • Daha sonra exitkomut. Şimdi normal olarak kullanmadıysanıznsenterkomut, konteyner imha edilecek. Ama şunu fark edeceksiniz ki,nsenter komutu, konteyner hala çalışır durumda.