recherche

Maison  >  Questions et réponses  >  le corps du texte

Depuis l'intérieur d'un conteneur Docker, comment puis-je me connecter à l'hôte local de la machine ?

<p>J'ai un Nginx exécuté dans un conteneur Docker. J'ai un MySql exécuté sur le système hôte. Je souhaite me connecter à MySql depuis mon conteneur. MySql se lie uniquement au périphérique localhost. </p> <p>Existe-t-il un moyen de se connecter à ce MySql ou à tout autre programme sur localhost à partir de ce conteneur Docker ? </p> <p>Cette question est différente de "Comment obtenir l'adresse IP de l'hôte Docker à partir de l'intérieur du conteneur Docker" car l'adresse IP de l'hôte Docker peut être une IP publique ou une IP privée dans le réseau, qui peut ou peut ne pas être accessible depuis le conteneur Docker (je veux dire IP publique si hébergé sur AWS ou ailleurs). Même si vous disposez de l'adresse IP de l'hôte Docker, cela ne signifie pas que vous pouvez vous connecter à l'hôte Docker depuis le conteneur, car votre réseau Docker peut être un réseau superposé, un réseau hôte, un réseau pont, un réseau macvlan. , un réseau nul, etc., ce qui limite l'accessibilité du conteneur à cette adresse IP. </p>
P粉787820396P粉787820396506 Il y a quelques jours629

répondre à tous(2)je répondrai

  • P粉517090748

    P粉5170907482023-08-24 11:07:24

    Disponible sur toutes les plateformes

    Docker v 20.10 et supérieur (au 14 décembre 2020)

    Utilisez votre adresse IP interne ou connectez-vous à un nom DNS spécial host.docker.internal qui sera résolu en adresse IP interne utilisée par l'hôte.

    Ceci est à des fins de développement et ne s'applique pas aux environnements de production en dehors de Docker Desktop.

    Avertissement Linux

    Pour activer cette fonctionnalité dans Docker sous Linux, ajoutez --add-host=host.docker.internal:host-gateway à votre commande docker pour activer la fonctionnalité.

    Pour activer cette fonctionnalité dans Docker Compose sous Linux, ajoutez la ligne suivante à la définition du conteneur :

    extra_hosts:
        - "host.docker.internal:host-gateway"
    

    Selon certains utilisateurs, le nom DNS spécial ne fonctionne que dans le réseau bridgebridge par défaut de Docker et non dans les réseaux personnalisés.

    Pour les anciennes versions macOS et Windows de Docker

    Docker v 18.03 et supérieur (au 21 mars 2018)

    Utilisez votre adresse IP interne ou connectez-vous à un nom DNS spécial host.docker.internal qui sera résolu en adresse IP interne utilisée par l'hôte.

    Le support Linux est en attente https://github.com/docker/for-linux/issues/264

    Pour les anciennes versions macOS de Docker

    Docker pour Mac v 17.12 à v 18.02

    Idem que ci-dessus, mais en utilisant docker.for.mac.host.internaldocker.for.mac.host.internal.

    Docker pour Mac v 17.06 à v 17.11

    Idem que ci-dessus, mais utilisez plutôt docker.for.mac.localhostdocker.for.mac.localhost.

    Docker pour Mac 17.05 et versions antérieures

    Pour accéder à la machine hôte à partir d'un conteneur Docker, vous devez attacher un alias IP à votre interface réseau. Vous pouvez lier n'importe quelle adresse IP de votre choix, assurez-vous simplement que vous ne l'utilisez pas pour autre chose.

    sudo ifconfig lo0 别名 123.123.123.123/24sudo ifconfig lo0 alias 123.123.123.123/24

    Assurez-vous ensuite que votre serveur écoute sur l'adresse IP ci-dessus ou 0.0.0.0。如果它正在监听本地主机127.0.0.10.0.0.0. S'il écoute sur localhost

    127.0.0.1, il n'acceptera pas les connexions.

    Ensuite, pointez simplement votre conteneur Docker vers cette IP pour accéder à l'hôte !

    curl -X GET 123.123.123.123:3000Pour tester, vous pouvez exécuter quelque chose comme

    curl -X GET 123.123.123.123:3000 à l'intérieur du conteneur.

    L'alias sera réinitialisé à chaque redémarrage, créez donc un script de démarrage si nécessaire.

    Solution et plus de documentation ici : https://docs.docker.com/desktop/networking/#use-cases-and-workarounds-for-all-platforms

    🎜

    répondre
    0
  • P粉019353247

    P粉0193532472023-08-24 09:26:22

    Éditeur :

    Si vous utilisez Docker-for-mac ou Docker-for-Windows 18.03+, utilisez l'hôte host.docker.internal (au lieu de 127.0.0.1< /code> dans votre chaîne de connexion).

    Si vous utilisez Docker-for-Linux 20.10.0+, vous pouvez également utiliser l'hôte host.docker.internal if您使用 --add-host host.docker.internal:host-gateway

    si

    vous le lancez en utilisant le

    --add-host host.docker.internal:host-gateway
    option Conteneur Docker, ou ajout de l'extrait de code suivant dans le fichier docker-compose.yml :
    extra_hosts:
        - "host.docker.internal:host-gateway"
    

    Sinon, veuillez lire ci-dessous

    docker run 命令中使用 --network="host",然后 docker 容器中的 127.0.0.1TLDR

    Utilisez --network="host" dans la commande docker run, puis 127.0.0.1 dans le conteneur Docker pointera vers votre hôte Docker.


    Remarque : ce mode n'est disponible que pour Docker sous Linux,

    selon la documentation

    .

    Remarques sur le mode réseau du conteneur Docker

    Docker propose

    différents modes réseaudocker0 lors de l'exécution de conteneurs. Selon le mode que vous choisissez, vous vous connecterez différemment à la base de données MySQL exécutée sur l'hôte Docker.

    docker run --network="bridge" (par défaut)sudo ip addr show docker0

    Docker crée un pont nommé

    docker0 par défaut. L'hôte Docker et le conteneur Docker ont tous deux une adresse IP sur le pont. docker0 网络接口上的 IP 地址为 172.17.42.1

    Sur l'hôte Docker, entrez

    sudo ip addr show docker0 et vous obtiendrez un résultat comme ceci : docker run --rm -it ubuntu:trusty bash 并在容器中输入 ip addr show eth0

    [vagrant@docker:~] $ sudo ip addr show docker0
    4: docker0: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc noqueue state UP group default
        link/ether 56:84:7a:fe:97:99 brd ff:ff:ff:ff:ff:ff
        inet 172.17.42.1/16 scope global docker0
           valid_lft forever preferred_lft forever
        inet6 fe80::5484:7aff:fefe:9799/64 scope link
           valid_lft forever preferred_lft forever

    Donc, l'adresse IP de mon hôte Docker sur l'interface réseau

    docker0 est 172.17.1.192172.17.42.1.

    Maintenant, démarrez un nouveau conteneur et installez un shell dessus : 172.17.42.1docker run --rm -it ubuntu:trusty bash et dans le conteneur, tapez

    ip addr show eth0 pour savoir comment son interface réseau principale est défini : 🎜
    root@e77f6a1b3740:/# ip addr show eth0
    863: eth0: <BROADCAST,UP,LOWER_UP> mtu 1500 qdisc pfifo_fast state UP group default qlen 1000
        link/ether 66:32:13:f0:f1:e3 brd ff:ff:ff:ff:ff:ff
        inet 172.17.1.192/16 scope global eth0
           valid_lft forever preferred_lft forever
        inet6 fe80::6432:13ff:fef0:f1e3/64 scope link
           valid_lft forever preferred_lft forever
    🎜Ici, l'adresse IP de mon conteneur est 🎜172.17.1.192. Visualisez maintenant la table de routage : 🎜
    root@e77f6a1b3740:/# route
    Kernel IP routing table
    Destination     Gateway         Genmask         Flags Metric Ref    Use Iface
    default         172.17.42.1     0.0.0.0         UG    0      0        0 eth0
    172.17.0.0      *               255.255.0.0     U     0      0        0 eth0
    🎜Ainsi, l'adresse IP de l'hôte docker 🎜172.17.42.1 est définie comme route par défaut et est accessible depuis votre conteneur. 🎜
    root@e77f6a1b3740:/# ping 172.17.42.1
    PING 172.17.42.1 (172.17.42.1) 56(84) bytes of data.
    64 bytes from 172.17.42.1: icmp_seq=1 ttl=64 time=0.070 ms
    64 bytes from 172.17.42.1: icmp_seq=2 ttl=64 time=0.201 ms
    64 bytes from 172.17.42.1: icmp_seq=3 ttl=64 time=0.116 ms

    docker run --network="host"

    Vous pouvez également exécuter le conteneur Docker et définir les paramètres réseau sur 主机。这样的容器将与 docker 主机共享网络堆栈,从容器的角度来看,localhost(或127.0.0.1)将引用 docker 主机。 p>

    Veuillez noter que tout port ouvert dans le conteneur Docker sera ouvert sur l'hôte Docker. Cela ne nécessite pas l'option -p 或 <代码>-P docker run.

    Configuration IP sur mon hôte docker :

    [vagrant@docker:~] $ ip addr show eth0
    2: eth0: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc pfifo_fast state UP group default qlen 1000
        link/ether 08:00:27:98:dc:aa brd ff:ff:ff:ff:ff:ff
        inet 10.0.2.15/24 brd 10.0.2.255 scope global eth0
           valid_lft forever preferred_lft forever
        inet6 fe80::a00:27ff:fe98:dcaa/64 scope link
           valid_lft forever preferred_lft forever

    Et les conteneurs Docker du mode host :

    [vagrant@docker:~] $ docker run --rm -it --network=host ubuntu:trusty ip addr show eth0
    2: eth0: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc pfifo_fast state UP group default qlen 1000
        link/ether 08:00:27:98:dc:aa brd ff:ff:ff:ff:ff:ff
        inet 10.0.2.15/24 brd 10.0.2.255 scope global eth0
           valid_lft forever preferred_lft forever
        inet6 fe80::a00:27ff:fe98:dcaa/64 scope link
           valid_lft forever preferred_lft forever

    Comme vous pouvez le constater, l'hôte Docker et le conteneur Docker partagent exactement la même interface réseau et ont donc la même adresse IP.


    Connectez-vous à MySQL depuis le conteneur

    Mode Pont

    Pour accéder à MySQL exécuté sur un hôte Docker à partir d'un conteneur en mode pont, vous devez vous assurer que le service MySQL écoute les connexions sur l'172.17.42.1adresse IP.

    Pour ce faire, assurez-vous d'avoir bind-address = 172.17.42.1bind-address = 0.0.0.0 ) dans votre fichier de configuration MySQL (my.cnf).

    Si vous devez définir une variable d'environnement avec l'adresse IP de la passerelle, vous pouvez exécuter le code suivant dans le conteneur :

    export DOCKER_HOST_IP=$(route -n | awk '/UG[ \t]/{print }')

    Puis dans votre application, utilisez la variable d'environnement DOCKER_HOST_IP pour ouvrir une connexion à MySQL.

    Remarque : Si vous utilisez bind-address = 0.0.0.0, votre serveur MySQL écoutera les connexions sur toutes les interfaces réseau. Cela signifie que votre serveur MySQL est accessible depuis Internet ; assurez-vous de définir les règles de pare-feu en conséquence.

    Remarque 2 : Si vous utilisez bind-address=172.17.42.1, votre serveur MySQL n'écoutera pas les connexions établies vers 127.0.0.1>. Les processus exécutés sur l'hôte Docker qui souhaitent se connecter à MySQL doivent utiliser l'adresse IP bind-address = 172.17.42.1,您的MySQL服务器将不会侦听与127.0.0.1建立的连接>。在 docker 主机上运行的想要连接到 MySQL 的进程必须使用 172.17.42.1.

    Mode hôte

    Pour accéder à MySQL exécuté sur un hôte docker depuis un conteneur en mode hôte, vous pouvez conserver bind-address = 127.0.0.1 并连接到 127.0.0.1 dans la configuration MySQL depuis votre conteneur :

    [vagrant@docker:~] $ docker run --rm -it --network=host mysql mysql -h 127.0.0.1 -uroot -p
    Enter password:
    Welcome to the MySQL monitor.  Commands end with ; or \g.
    Your MySQL connection id is 36
    Server version: 5.5.41-0ubuntu0.14.04.1 (Ubuntu)
    
    Copyright (c) 2000, 2014, Oracle and/or its affiliates. All rights reserved.
    
    Oracle is a registered trademark of Oracle Corporation and/or its affiliates. Other names may be trademarks of their respective owners.
    
    Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.
    
    mysql>

    Remarque : Veuillez utiliser mysql -h 127.0.0.1,而不是mysql -h localhost ; sinon le client MySQL tentera de se connecter à l'aide d'un socket Unix.

    répondre
    0
  • Annulerrépondre