这个问题我折腾了1天多,终于在看到了这篇博文后,顿悟了
https://blog.csdn.net/luckyjiet/article/details/80979378
感谢这位博主,指明了道路,不然我还在走歪路呢
正文
要想建立容器之间的连接其实很容器,比如下面这段代码中的--link就与mysql_server容器建立起了关联,且连接别名为db,创建好这个叫mysql_client2的容器后,进入容器你可以尝试用 ping db,是能ping通的,因为db已经代表了mysql_server容器的内部ip地址,也就是说mysql_client2和mysql_server是处于一个局域网网段的
docker run --name=mysql_client2 --link=mysql_server:db -t -i kongxx/mysql_client /usr/bin/mysql -h db -u root -pletmein
好了转向docker-compose
一开始,我一直被上面提到的--link所误导,以为主要是靠--link来实现容器间连接的,而且对网段这个东西也没重视,然后一直在找关于docker-compose的 links 和 external_links 这两个指令的玩法,结果各种失败,还好找着找着终于把路莫名找正了,一个瞎子终于摸到了活耗子。
其实最关键的就是容器网络networks,在写docker-compose.yml脚本时,对networks理解得太模糊,导致没弄明白怎么建立容器间的关联,其实只要把几个容器放到同一个已经创建好的network里就行了,下面就用我的脚本作为案例进行说明
上代码
(注意,如想练习,请不要复制我的代码,下面的代码有些是手动修改补充的,可能会格式不太对,yml对格式很严格的,一旦缩进格式不对,docker-compse up -d 就会执行报错)
先创建一个mysql容器,注意,这个mysql容器放到了一个新创建的mysql_net网络中,先看好,记住这个容器的名称我定为 mysqldb,下面会提到,别看不懂,就是这句命令:【container_name: mysqldb】指定容器名称
version: '3'
services:
mysqldb:
image: mysql/mysql-server:latest
container_name: mysqldb
environment:
MYSQL_ROOT_PASSWORD: 123456
ports:
- "3306:3306"
volumes:
- /home/mysql/conf:/etc/mysql/conf.d
- /home/mysql/data:/var/lib/mysql
- /home/mysql/logs:/logs
- /home/mysql/sql:/home/sql
restart: always
networks:
- mysql_net
networks:
mysql_net:
driver: bridge
接下来再创建一个java容器,我因为要建立可持续化功能,所以容器的基础是gitlab-runner,容器基础是什么这里并不重要,暂且忽略,关键是,下面的这个 gitlab-runner-server 容器要与上面的 mysqldb 容器建立关联,就在于最后的那个 networks 指令
networks:
dvserver_net:
external:
name: mysql_net
这里的 dvserver_net 只是当前docker-compose.yml脚本中起的一个网络别名而已,最关键的是
external:
name: mysql_net
这句说明 dvserver_net 执行外部已经创建好的 mysql_net 网络,也就是上面的 msqldb 容器所在的网络,这样一来,gitlab-runner-server 容器就和上面的 mysqldb 容器在同一个局域网网段了,也就建立的关联,启动这个gitlab-runner-server并进入后,你可以通过ping mysqldb 测试,就能ping通了,因为ping的这个mysqldb 在gitlab-runner-server容器中只是个mysql容器的ip地址的别名而已,其实就是在ping ip
gitlab-runner-server容器的完整代码如下(对了,这里的【image: gitlab-runner-java:v1】是我自己写的dockerfile创建的镜像而已,这里可以忽略)
version: '3'
services:
datavisual_server:
image: gitlab-runner-java:v1
container_name: gitlab-runner-server
ports:
- "6789:80"
restart: always
networks:
- dvserver_net
networks:
dvserver_net:
external:
name: mysql_net
网友评论