Kev*_*ata 1 go grpc docker-compose docker-network
我有一个具有给定文件夹结构的 git 存储库
grpc-repo
|---grpc-client (:8083)
|---grpc-server (:9000)
|---docker-compose.yml
|---Dockerfile
|---Dockerfile2
Run Code Online (Sandbox Code Playgroud)
现在,这些gRPC客户端-服务器项目正常无缝运行。但是,我需要将这个项目进行 dockerize。
下面给出的是我的docker-compose.yml
version: "3.3"
services:
client:
container_name: grpc-client
build:
dockerfile: Dockerfile
context: .
volumes:
- .:/app
ports:
- 8083:8083
networks:
- my-network
server:
container_name: grpc-server
build:
dockerfile: Dockerfile2
context: .
volumes:
- .:/app
ports:
- 9000:9000
networks:
- my-network
networks:
my-network:
driver: bridge
Run Code Online (Sandbox Code Playgroud)
对项目进行 docker 化后,我可以轻松连接到 gRPC 客户端。但是客户端无法连接到 gRPC 服务器。
它说 ...
rpc error: code = Unavailable desc = connection error: desc = \"transport: Error while dialing dial tcp :9000: connect: connection refused
Run Code Online (Sandbox Code Playgroud)
这就是我在 golang 代码中创建与服务器的连接的方式
conn, err := grpc.Dial(":9000", grpc.WithInsecure())
if err != nil {
log.Fatalf("could not connect: %s", err)
}
Run Code Online (Sandbox Code Playgroud)
谁能帮我解决我在这里做错了什么?提前致谢 !
要从另一个容器访问在 docker 容器中运行的 gRPC,您必须使用 DNS 解析。
grpc.Dial("dns:///grpc-server:9000", grpc.WithInsecure())
Run Code Online (Sandbox Code Playgroud)
其中grpc-server是您声明的容器名称container_name: grpc-server
| 归档时间: |
|
| 查看次数: |
2672 次 |
| 最近记录: |