美文网首页dibo
docker 容器之间互相访问(互联)

docker 容器之间互相访问(互联)

作者: 爱吃豆包 | 来源:发表于2019-07-16 14:14 被阅读17次

在上一篇文章里面我们构建了一个eureka服务注册中心组件,已经放在Docker容器中运行。
但是我们在这里在构建一个config配置中心服务组件!

在架构中,所有的子服务都往注册中心进行服务注册。以前直接在服务器部署的时候,通过服务器地址直接进行注册,比较方便。
但是放到docker容器中后,每个子服务都是一个容器,那么就涉及到了容器与容器之间的互相访问!
有两个方法:
1.每个容器都映射宿主机器的一个端口,在部署在容器中的子服务在通过这个映射的端口进行访问注册!但是不友好,因为并不是每个服务都需要对外暴露端口!
2.容器与容器之间进行关联,关联后就可以进行互相访问!

这里采用第二种方式,构建一个config配置中心容器,在往容器中的eureka上进行注册!

查看docker容器中正在运行的eureka

// 查询正在运行的容器
docker ps

输出

C:\Users\szc>docker ps
CONTAINER ID        IMAGE                COMMAND                  CREATED             STATUS              PORTS                    NAMES
721961e5d932        eureka_image:0.0.1   "nohup java -jar /yu…"   3 days ago          Up 33 minutes       0.0.0.0:9000->8080/tcp   eureka

找打最后面的NAMES字样,值是 eureka

现在首先修改config配置中心项目中的application.ymleureka注册地址:

...... 省略一段配置.........
eureka:
  client:
    service-url:
      defaultZone: http://eureka:8080/eureka/

重点在最后的 defaultZone: http://eureka:8080/eureka/ 中 eureka 字样,代替了之前的服务器IP地址
然后打包config配置中心项目!打包成jar

构建清单

构建config配置中心清单.png

构建config配置中心的Dockerfile文件:

# 基础镜像
FROM java
# 镜像构建作者
LABEL maintainer docker_user<907147608@qq.com>
# 设置环境变量
# ENV JAVA_HOME=/xxx/xxx/jdk8
# 复制文件到目录 <本地目录> <容器目录>
COPY config-server-0.0.1.jar /yunpan/smart-community/
# RUN 运行命令, 这个命令一般用户镜像安装的初始化操作,就是你这个进行需要的依赖设置
# RUN wget=http://xxx/xxx/jdk8
# CMD 命令, 如果 docker run [image] 后面没有追加命令,则执行CMD命令
# CMD nohup java -jar config-server-0.0.1.jar > eureka-sever.log &
# ENTRYPOINT 命令,此命令无论 docker run [image] 后面是否追加命令都执行,如果有追加的命令,则拼接在 ENTRYPOINT 命令的后面
ENTRYPOINT ["nohup","java", "-jar","/yunpan/smart-community/config-server-0.0.1.jar",">","config-server.log","&"]

开始构建(在windows上构建)

docker build -t config:0.0.1 E:\docker_worker\config

启动构建成功的config

docker run -d --name config --link eureka config:0.0.1

--link 参数就是指定需要关联哪一个容器,指定的就是容器的名称(取的是容器中的NAMES字段的值)
参数的格式为--link name: alias, 其中name是要链接的容器的名称 ,alias是别名。别名可以省略!

然后访问eureka
http://localhost:9000/

访问docker中的eureka.png

发现已经注册成功!

探究docker可以容器之间互联的原因:

进入容器config配置中心容器

docker exec -it f8a1aa11f3fa bash
C:\Users\szc>docker exec -it f8a1aa11f3fa bash
root@f8a1aa11f3fa:~# tail /etc/hosts
127.0.0.1       localhost
::1     localhost ip6-localhost ip6-loopback
fe00::0 ip6-localnet
ff00::0 ip6-mcastprefix
ff02::1 ip6-allnodes
ff02::2 ip6-allrouters
172.17.0.2      eureka 721961e5d932
172.17.0.3      f8a1aa11f3fa
root@f8a1aa11f3fa:~#

发现在容器中 /etc/hosts 中最后两行:

172.17.0.2      eureka 721961e5d932
172.17.0.3      f8a1aa11f3fa

看到这个发现只是在/etc/hosts中做个转发操作!
也就是把上面在config配置中心项目中的application.yml文件的defaultZone: http://eureka:8080/eureka/ 中 eureka 字样进行了解析!解析成defaultZone: http://172.17.0.2:8080/eureka/,这个地址也就是eureka的容器地址!

传送门:

docker 通过Dockerfile构建镜像 Eureka服务中心

相关文章

  • docker 容器之间互相访问(互联)

    在上一篇文章里面我们构建了一个eureka服务注册中心组件,已经放在Docker容器中运行。但是我们在这里在构建一...

  • 不同主机上容器之间通信 Docker + Swarm

    在单台主机上的不同容器之间可以通过 docker inspect 查看IP地址互相访问,因为这些容器都在Docke...

  • Docker:Docker网络管理(宿主机和容器互相访问,容器间

    摘要:Docker 整理Docker网络管理知识,包括Docker网络基础,宿主机和容器互相访问,容器间网络通信,...

  • 【Docker】容器内互相访问

    在容器内,要访问不同的容器服务时,可以直接通过服务名称进行访问。 注意,是在容器内访问其他容器服务! 比如: 我的...

  • Docker基本命令

    镜像操作相关命令 容器操作相关命令 访问Docker仓库 Docker数据管理 端口映射与容器互联 Dockerf...

  • docker网络模式

    docker网络 使用网络 外部访问容器 -p/P端口映射参数 docker port查看当前端口映射 容器互联 ...

  • Docker 网络

    Docker允许通过外部访问容器或容器互联的方式来提供网络服务。 安装Docker时,会自动安装一块Docker网...

  • Docker实战系列(4)-网络配置

    Docker 允许通过外部访问容器或容器互联的方式来提供网络服务。 外部访问容器 容器中可以运行一些网络应用,要让...

  • Docker 网络

    Docker 允许通过外部访问容器或容器互联的方式来提供网络服务。 外部访问容器 容器中可以运行一些网络应用,要让...

  • 关于对docker run --link的理解

    前言 在实践中,自己会遇到2个容器之间互相访问通信的问题,这个时候就用到了docker run --link选项。...

网友评论

    本文标题:docker 容器之间互相访问(互联)

    本文链接:https://www.haomeiwen.com/subject/mlyzkctx.html