Impossible de se connecter à un serveur Go GRPC exécuté dans un conteneur Docker local
Lors de l'exécution d'un client GRPC sur un service GRPC exécuté localement, il est Il est important de prendre en compte le point de terminaison d'écoute du serveur. Par défaut, lors de la spécification d'un nom d'hôte ou d'une adresse IP (dans ce cas, localhost), le serveur n'écoutera que sur cette adresse spécifique.
Dans le contexte des conteneurs Docker, l'écoute sur localhost (127.0.0.1) est problématique car il n’est pas accessible en dehors du conteneur. Bien que Docker puisse exposer les ports sur la machine hôte, le serveur n'écoutera que sur 127.0.0.1 dans le conteneur.
Pour résoudre ce problème, le point de terminaison d'écoute doit être remplacé par *:51672, demandant au serveur d'écouter. sur toutes les adresses IP disponibles dans le conteneur. Cela permet au conteneur de recevoir le trafic transféré de la machine hôte sur le port exposé.
Pour vérifier le problème, les règles iptables peuvent être examinées à l'aide des commandes suivantes :
iptables -n -L iptables -t nat -n -L
Ces règles sont créés par Docker pour implémenter la redirection de port. En configurant le serveur pour écouter toutes les adresses IP disponibles, le client peut se connecter avec succès au service GRPC exécuté dans le conteneur Docker.
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!