|
|
Yayınlandı 19.11.2019 10:10:01
|
|
|
|

Docker konteynerinin varsayılan ağı, ana bilgisayarla aynı LAN'da (ayrı bir LAN IP'si kullanılan) bir köprü şeklindedir; program üretim ortamında çalışırken, veritabanı, redis vb. ile bağlantı sağlamak için sadece ilgili hizmet adresini yapılandırmanız yeterlidir.
Bir geliştirme ortamında, hizmet docker'da çalışıyor ve veritabanı yerel olarak çalışıyorsa, 127.0.0.1'i yapılandırmak kolay değildir.
Bu iki şekilde çözülebilir.
Çözüm 1:
Ana makine ve konteyneri iki ayrı makine olarak ele alın ve adresi yapılandırırken ana bilgisayarın LAN IP'sini veya genel IP'sini yapılandırın.
Çözüm 2:
Ancak ana adresi doğrudan şu şekilde yaz: host.docker.internalİkinci yöntem ise docker sürümünün 18.03'ten büyük olmasını gerektirir ve Windows ile Mac'te mevcut olmalıdır。
Bu iki yöntemin ana bilgisayara erişip erişemediğini test etmek için, docker ile doğrudan bir görüntü çalıştırarak komut satırına ping atabilirsiniz:
Yukarıdaki görselden de görebileceğiniz gibi, konteyner erişimihost.docker.internalHost hizmetine erişebilirsiniz, /etc/hosts dosyasını kontrol ederek, alan adı yönlendirmesi olmadığını ve docker'ın temel ilkesini bilmediğinizi göreceksiniz.
Hem ana bilgisayar hem de konteyner, host.docker.internal üzerinden ana bilgisayarın hizmetlerine erişebilir, ancak ping komutuyla geri dönen adres farklıdır, aşağıdaki gibi:
|
Önceki:Örnekler, Redis önbellek penetrasyonu, önbellek çığı ve önbellek dağılımının ne olduğunu açıklarÖnümüzdeki:Autofac "Dairesel bileşen bağımlılığı tespit edildi" hatası çözüldü
|