gRPC Android 客户端异常 io.grpc.StatusRuntimeException:不可用

gRPC Android client exception io.grpc.StatusRuntimeException: UNAVAILABLE

我在 tcp://localhost:50051 本地有一个 GO 服务器 运行 和一个反应本机模块 Android/iOS。

iOS 模块工作正常,当我从 android 虚拟设备尝试时,引发了以下异常。

    io.grpc.StatusRuntimeException: UNAVAILABLE
                          at io.grpc.stub.ClientCalls.toStatusRuntimeException(ClientCalls.java:230)
                          at io.grpc.stub.ClientCalls.getUnchecked(ClientCalls.java:211)
                          at io.grpc.stub.ClientCalls.blockingUnaryCall(ClientCalls.java:144)
                          at 
... callig my stub method ...
                          at android.os.AsyncTask.call(AsyncTask.java:333)
        I/System.out:     at java.util.concurrent.FutureTask.run(FutureTask.java:266)
                          at android.os.AsyncTask$SerialExecutor.run(AsyncTask.java:245)
                          at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1162)
                          at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:636)
                          at java.lang.Thread.run(Thread.java:764)
                      Caused by: java.net.ConnectException: failed to connect to localhost/127.0.0.1 (port 50051) from /:: (port 51916): connect failed: ECONNREFUSED (Connection refused)
                          at libcore.io.IoBridge.connect(IoBridge.java:138)
                          at java.net.PlainSocketImpl.socketConnect(PlainSocketImpl.java:129)
                          at java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:356)
                          at java.net.AbstractPlainSocketImpl.connectToAddress(AbstractPlainSocketImpl.java:200)
                          at java.net.AbstractPlainSocketImpl.connect(AbstractPlainSocketImpl.java:182)
                          at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:356)
                          at java.net.Socket.connect(Socket.java:616)
                          at java.net.Socket.connect(Socket.java:565)
                          at java.net.Socket.<init>(Socket.java:445)
                          at java.net.Socket.<init>(Socket.java:248)
                          at io.grpc.okhttp.OkHttpClientTransport.run(OkHttpClientTransport.java:419)
                          at io.grpc.internal.SerializingExecutor$TaskRunner.run(SerializingExecutor.java:154)
                        ... 3 more
                      Caused by: android.system.ErrnoException: connect failed: ECONNREFUSED (Connection refused)
                          at libcore.io.Linux.connect(Native Method)
                          at libcore.io.BlockGuardOs.connect(BlockGuardOs.java:126)
                          at libcore.io.IoBridge.connectErrno(IoBridge.java:152)
                          at libcore.io.IoBridge.connect(IoBridge.java:130)
                        ... 14 more

AVD 运行 10.0.2.2:8081

当 运行 在 Android 模拟器上时,localhost 是 Android 设备。您需要使用您机器的IP/hostname。