Docker Compose’da “network not found” Hatası Nasıl Çözülür?

Docker Nedir ve Neden Tercih Edilir?

Docker, uygulamaları bağımlılıklarıyla birlikte izole bir ortamda çalıştırmaya olanak tanıyan konteyner tabanlı bir sanallaştırma platformudur. Geleneksel sanallaştırma yöntemlerine göre daha hafif, hızlı ve esnektir. Docker’ın sunduğu başlıca avantajlar şunlardır:

  • Bir Docker container’ı, geliştirici bilgisayarından prodüksiyon ortamına sorunsuz taşınabilir.
  • Aynı fiziksel makine üzerinde birden fazla izole uygulama çalıştırılabilir.
  • İmajlar sayesinde saniyeler içinde uygulama ortamları oluşturulabilir.
  • Uygulama ortamları sürümlenebilir ve geri alınabilir.
  • Hub üzerinde binlerce hazır imaj mevcuttur.

Docker ve Docker Compose Kurulumu

Docker Compose, birden fazla container’ı tek bir YAML dosyası aracılığıyla tanımlayıp birlikte yönetmeye olanak tanır. Kurulumu oldukça basittir; sisteminizde Docker’ın yüklü olması yeterlidir. Detaylı kurulum için Docker rehberine göz atabilir, kısaca aşağıda kurulum terminalleriyle açıklanan adımları takip edebilirsiniz. Bu sayede Compose yapılandırmasına geçmeden önce gerekli ortamı eksiksiz şekilde hazırlayabilirsiniz.

Docker Kurulumu

Ubuntu örneğiyle:

sudo apt update
apt install docker.io
sudo systemctl enable --now docker

Docker Compose Kurulumu

sudo curl -L "https://github.com/docker/compose/releases/download/v2.24.4/docker-compose-$(uname -s)-$(uname -m)" -o /usr/local/bin/docker-compose
sudo chmod +x /usr/local/bin/docker-compose

❌ “network not found” Hatası Çözümü

Bu hata genellikle docker-compose.yml dosyasında tanımlanan bir ağın sistemde mevcut olmamasından kaynaklanır. Eğer yapılandırma dosyasında harici (external) bir ağ kullanımı tanımlanmışsa ve bu ağ önceden oluşturulmamış ya da sistemde yapılan temizlik işlemleri sonucu silinmişse, Docker Compose bu ağı bulamadığı için çalışmayı durdurur. Bu durumda yapılacak ilk şey, ilgili ağın sistemde var olup olmadığını kontrol etmektir.

Eğer ağ mevcut değilse, manuel olarak oluşturmak ya da external tanımını kaldırarak Docker’ın bu ağı otomatik üretmesine izin vermek problemi çözecektir. Hatanın kaynağını doğru bir şekilde analiz etmek ve ağ tanımlarını dikkatli yapmak, benzer sorunların tekrar yaşanmasını önleyecektir.

ERROR: Network my_custom_network declared as external, but could not be found.

Ağı Manuel Oluşturun; Eğer ağ sistemde yoksa, aşağıdaki komutla oluşturabilirsiniz:

docker network create my_custom_network

Compose Dosyasını Düzenleyin; Ağ harici olmak zorunda değilse external: true satırını kaldırın:

networks:
my_custom_network:
driver: bridge

Mevcut Ağları Listeleyin; Kontrol etmek için:

docker network ls

Sistem Temizliği Sonrası Ağları Yeniden Oluşturun

docker system prune veya docker network prune gibi komutlar ağı silmiş olabilir. Bu durumda elle yeniden oluşturmanız gerekir.

Docker ağlarıyla ilgili daha fazla bilgi edinmek için docker network inspect <ağ_ismi> komutunu kullanarak ilgili ağın yapılandırma detaylarını ve bağlı konteynerleri görüntüleyebilirsiniz. Geliştirme ve üretim ortamlarını birbirinden ayırmak için docker-compose.override.yml gibi farklı yapılandırma dosyaları kullanmak, yapıların esnekliğini artırır ve ortamlar arası geçişi kolaylaştırır.

Ayrıca, Docker Compose dosyalarınızı Git gibi bir versiyon kontrol sistemiyle takip etmek, yapılandırma değişikliklerini geriye dönük izlemek ve ekip içi işbirliğini kolaylaştırmak açısından büyük avantaj sağlar. Eğer tek bir sunucuda birden fazla Compose projesi çalıştırıyorsanız, her proje için benzersiz ağ adları tanımlamanız, olası çakışmaları önleyerek sistemin daha istikrarlı çalışmasını sağlar.

Sık Sorulan Sorular (SSS)

Docker ağı sistemden neden silinir?
Docker ağı çeşitli nedenlerle sistemden silinebilir. En yaygın senaryo, docker system prune veya docker network prune gibi temizlik işlemleri sırasında kullanılmayan ağların otomatik olarak kaldırılmasıdır. Ayrıca ağ, kullanıcı tarafından manuel olarak da silinmiş olabilir. Harici ağlar bu işlemlerden etkilenebileceği için dikkatli olunmalıdır.

Tanımlı bir ağı manuel olarak nasıl oluşturabilirim?
Eğer docker-compose.yml dosyanızda belirtilen bir ağ sistemde mevcut değilse, ağı şu komutla manuel olarak oluşturabilirsiniz:

docker network create my_custom_network

Burada my_custom_network yerine Compose dosyanızda tanımlı olan ağ ismini yazmalısınız. Bu komut, Docker’a o isimde bir köprü ağı (bridge network) oluşturmasını söyler.

Docker Compose özel bir ağ olmadan da çalışır mı?
Evet, Docker Compose dosyanızda özel bir ağ tanımı yapılmadıysa, Docker varsayılan bridge ağı üzerinden servisleri çalıştırır. Bu durumda manuel ağ oluşturmanıza gerek kalmaz. Ancak özel bir yapı veya proje bazlı izolasyon gerekiyorsa, özel ağ tanımlamak ve bu ağı dikkatli yönetmek önemlidir.

Yorum yapın