#### 前言

实际部署的docker服务中,会存在两个容器的互相通信情况,这就需要使用到--link选项

 

#### 作用

- 链接两个容器,使得源容器(被链接的容器)和接收容器(主动去链接的容器)之间可以互相通信

- 接收容器可以获取源容器的一些数据,eg: 源容器的环境变量

 

#### 语法

> --link <container-name/container-id>:alias     

注释: container-name/container-id为源容器的container-name/container-id,alias为源容器在link下的别名   

 

#### 示例

 

##### 源容器elasticsearch

> docker run -d --name elasticsearch --restart always -p 9200:9200 -p 9300:9300 elasticsearch:7.6.1

 

##### 接收容器logstash

> docker run -d --name logstash --restart always --link elasticsearch:elasticsearch -p 5044:5044 logstash:7.6.1   

 

#### 测试

进入接收容器

> docker exec -it kibana /bin/bash

 

##### 通信

> bash-4.2$ ping -c 2 elasticsearch

```
PING elasticsearch (172.17.0.5) 56(84) bytes of data.
64 bytes from elasticsearch (172.17.0.5): icmp_seq=1 ttl=64 time=0.076 ms
64 bytes from elasticsearch (172.17.0.5): icmp_seq=2 ttl=64 time=0.083 ms

--- elasticsearch ping statistics ---
2 packets transmitted, 2 received, 0% packet loss, time 999ms
rtt min/avg/max/mdev = 0.076/0.079/0.083/0.009 ms

```

 

##### 环境变量

> bash-4.2$ env   

```
HOSTNAME=8a081a50c046
ELASTICSEARCH_PORT_9200_TCP_PORT=9200
TERM=xterm
ELASTIC_CONTAINER=true
ELASTICSEARCH_ENV_ELASTIC_CONTAINER=true
ELASTICSEARCH_NAME=/kibana/elasticsearch
ELASTICSEARCH_PORT_9200_TCP_PROTO=tcp
ELASTICSEARCH_PORT_9300_TCP_PORT=9300
ELASTICSEARCH_PORT_9300_TCP_ADDR=172.17.0.5
PATH=/usr/share/kibana/bin:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin
PWD=/usr/share/kibana
SHLVL=1
HOME=/usr/share/kibana
ELASTICSEARCH_PORT=tcp://172.17.0.5:9200
ELASTICSEARCH_ENV_discovery.type=single-node
ELASTICSEARCH_PORT_9200_TCP=tcp://172.17.0.5:9200
ELASTICSEARCH_PORT_9300_TCP=tcp://172.17.0.5:9300
ELASTICSEARCH_PORT_9300_TCP_PROTO=tcp
ELASTICSEARCH_PORT_9200_TCP_ADDR=172.17.0.5
_=/usr/bin/env

```

Logo

权威|前沿|技术|干货|国内首个API全生命周期开发者社区

更多推荐