当前位置: 首页 > 面试题库 >

无法连接到在本地Docker容器中运行的Go GRPC服务器

杨甫
2023-03-14
问题内容

我有去grpc服务。我正在开发Mac,塞拉利昂。在本地针对服务运行grpc客户端时,一切都很好,但是在Docker容器中针对相同服务运行相同的客户端时,出现此错误:

transport: http2Client.notifyError got notified that the client transport was broken EOF.
FATA[0000] rpc error: code = Internal desc = transport is closing

这是我的docker文件:

FROM golang:1.7.5

RUN mkdir -p /go/src/github.com/foo/bar
WORKDIR /go/src/github.com/foo/bar

COPY . /go/src/github.com/foo/bar
# ONBUILD RUN go-wrapper download
RUN go install

ENTRYPOINT /go/bin/bar

EXPOSE 51672

我的命令来建立图像:

docker build -t bar .

我的命令启动Docker容器:

docker run -p 51672:51672 --name bar-container bar

其他资讯:

  • 客户端程序可以在Docker容器中正常运行
  • 连接到常规的休息端点可以正常工作(http2,与grpc相关吗?)
  • lsof在OS X中运行命令会产生以下结果
        $lsof -i | grep 51672
    com.docke   984 oldDave   21u  IPv4 0x72779547e3a32c89      0t0  TCP *:51672 (LISTEN)
    com.docke   984 oldDave   22u  IPv6 0x72779547cc0fd161      0t0  TCP localhost:51672 (LISTEN)
  • 这是我的服务器代码的片段:
        server := &Server{}
    endpoint := "localhost:51672"
    lis, err := net.Listen("tcp", endpoint)
    if err != nil {
        log.Fatalf("failed to listen: %v", err)
    }

    s := grpc.NewServer(grpc.Creds(creds))

    pb.RegisterExpServiceServer(s, server)

    // Register reflection service on gRPC server.
    reflection.Register(s)

    log.Info("Starting Exp server: ", endpoint)

    if err := s.Serve(lis); err != nil {
        log.Fatalf("failed to serve: %v", err)
    }

问题答案:

当您指定要侦听的主机名或IP地址(在本例中为解析为127.0.0.1的localhost)时,服务器将仅侦听该IP地址。

当您不在Docker容器之外时,在localhost上侦听不是问题。如果您的服务器仅侦听127.0.0.1:51672,则您的客户端可以轻松连接到该服务器,因为连接也是从127.0.0.1建立的。

当您在Docker容器中运行服务器时,它只会像以前一样监听127.0.0.1:51672。127.0.0.1是本地环回地址,在容器外部无法访问。

当您使用“ -p
51672:51672”启动Docker容器时,它将转发到127.0.0.1:51672的流量到该容器的IP地址,在我的情况下为172.17.0.2。

容器在docker0网络接口内获取IP地址(您可以使用“ ip addr ls”命令查看)

因此,当您的流量在172.17.0.2:51672上转发到容器时,那里没有任何监听,连接尝试失败。

解决方法:

问题在于侦听端点:

endpoint := "localhost:51672"

要解决您的问题,请将其更改为

endpoint := ":51672"

这将使您的服务器侦听其容器的所有IP地址。

附加信息:

当您在Docker容器中公开端口时,Docker将创建iptables规则来进行实际转发。看到这个。您可以使用以下方法查看这些规则:

iptables -n -L 
iptables -t nat -n -L


 类似资料:
  • 我有go grpc服务。我在mac电脑上开发,塞拉。当针对本地服务运行grpc客户机时,一切都很好,但当针对docker容器中的相同服务运行相同客户机时,我会出现以下错误: 下面是我的服务器代码片段:

  • 问题内容: 我有MySQL的Laravel应用程序,我正在尝试使用docker-compose在Docker中运行它。但是,当应用尝试连接数据库时,它会抛出: Connector.php 55行中的PDOException:SQLSTATE [HY000] [2002]无法通过套接字’/var/run/mysqld/mysqld.sock’连接到本地MySQL服务器(2) 我的docker-com

  • 我正在docker容器中运行sql server` 所有这些都成功完成了。现在,当我尝试使用Java连接到数据库时,我得到了错误。 192.168.56.101是我的虚拟机的ip。我正在虚拟机上运行Linux。 我收到通信链路故障错误。 我在谷歌上搜索并找到了一些关于以下链接的解决方案,但没有一个对我有用。 使用JDBC和MySQL解决“通信链路故障” 如何连接docker中作为容器运行的MySQ

  • 我正在运行Docker容器,其中运行一个jar文件。 此jar文件需要访问Elasticsearch以读取数据,并且此Elasticsearch服务安装在本地计算机上(不在Docker容器中) 我需要从Docker容器连接到本地Elasticsearch服务以使其正常工作 我在Dockerfile中写了EXPOSE 9200 9300 service-port,我的Docker run命令如下,

  • 问题内容: 遵循此示例:https : //docs.docker.com/engine/examples/mongodb/ 当尝试使用以下命令连接到mongoDB时:( 其中ip是boot2docker ip的名称)+ docker ps的端口号: 27017 / tcp 或-P 0.0.0.0:49155->27017/tcp 无论哪种方式,我都会收到以下错误: 警告:无法连接到ip:2701

  • 我的docker版本是1.13.1。我正试图从我的docker容器连接到redis-server,但我遇到了拒绝连接的错误。详细的日志如下: 原因:redis.clients.jedis.exceptions.jedisconnectionException:java.net.Connection:redis.clients.jedis.Connection(Connection.java:207