docker compose容器间服务访问

这篇博客记录了在非生产环境中,如何解决使用Docker的grpcclient服务通过dockercompose配置文件与grpcserver服务进行通讯的问题。通过将两个服务置于同一网络server下,client可以使用服务名‘grpcserver’直接调用server的8089端口,避免了因IP变化导致的通讯障碍。

今天遇到了一个使用多个docker容器时服务间通讯的问题,在这里做个记录,也帮助需要的人。

现在有两个服务–grpcclientgrpcserver,需要在client中调用server的函数,这时需要指定server的地址。由于不是在生产环境,所以ip是会变的,所以这里不能通过指定ip的方式来访问。
这里直接贴出docker compose 的配置文件

version: '3'

services:
  grpcserver:
    build:
      context: .
      dockerfile: $GOPATH/src/gRpcServer/Dockerfile
    image: grpcserver:latest
    container_name: grpcserver
    ports:
      - "8089:8089"
    networks:
      - server
    command: ["./opt/main"]

  grpcclient:
    build:
      context: .
      dockerfile: $GOPATH/src/gRpcClient/Dockerfile
    image: grpcclient:latest
    container_name: grpcclient
    ports:
      - "8088:8088"
    networks:
      - server
    command: ["./opt/main"]

networks:
  server:
    driver:
      bridge

由上面的配置文件看出两个服务都使用了server这个network,这样client调用server时可以直接使用server的服务名称

Conn, err = grpc.Dial("grpcserver:8089", opts...)
if err != nil {
    panic(err)
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值