Docker-compose实战

各位小伙伴们,我们前面的篇文章分享了、docker的基础知识点、如何编写一个Dockerfiledocker网络是怎么回事、如何编写docker-compose.yml文件。已经为本文做好了充分的铺垫。

那么这边文章就和小伙本们分享如何将你自己的微服务项目进行服务的编排。

准备

要想编排项目,首先我们得有一个项目。不要着急,作者给大家准备了一个自己的SpringCloud的项目,包含服务注册中心、服务的提供者、服务的消费者、配置中心等。本文我们会用到其中的三个服务来进行服务编排。项目GitHub地址,项目结构如下图:

说明:本次我们只会用到其中的三个服务,eureka-server:服务注册中心,order-server:订单服务,order-client-feign:订单查询服务

开始

在进行服务编排以前,我们需要给要给要编排的服务编写Dockerfile文件。首先来编写eureka-server:服务注册中心的文件

创建Dockerfile文件

将项目clone到你的本地,打开项目根目录,创建Dockerfile文件,并为为项目编写Dockerfile文件,至于Dockerfile文件的每一行命令是什么意思,请参考Dockerfile你值得拥有 如下图:

构建镜像

如果小伙伴们还不知道如何构建镜像,请看这篇文章 Dockerfile你值得拥有 ,在执行以下命令之前先将jar包打出来。即eureka-server-0.0.1-SNAPSHOT.jar

执行如下俩行命令

# 构建镜像
docker build -f /Users/wangyupeng/IdeaProjects/cloud-framework/eureka-server/Dockerfile .
# 指定镜像仓库个tag
docker build -t cloud-framework/eureka:1.0 .

执行完命令后,我们执行docker images,查看是否有我们的镜像生成,如下图

同理,我们完成order-server:订单服务,order-client-feign:订单查询服务的镜像构建工作。镜像仓库和镜像tag分别是cloud-framework/order-client-feign:1.0和,cloud-framework/order-server:1.0如下图,可见,我们自己构建的docker镜像。

这里忘记了一件重要的事情,由于docker默认的网络模式是bridge参考:docker网络,各个容器的IP都不相同,所以我们需要给Eureka Server ,配置一个主机名:EurekaServer,所有的微服务都使用主机名连接注册中心。

修改配置

首先将注册中心的配置进行修改:

# 原配置
eureka:
 instance:
    hostname: localhost
  # 设置不检索其他服务
  client:
    fetch-registry: false
  # 不注册自己
    register-with-eureka: false
    ## 服务注册地址
    service-url:
      defaultZone: http://${eureka.instance.hostname}:${server.port}/eureka/
 # 修改为
eureka:
  # 设置Eureka的hostname
  instance:
    hostname: EurekaServer
  # 设置不检索其他服务
  client:
    fetch-registry: false
  # 不注册自己
    register-with-eureka: false
  # 服务注册地址
    service-url:
      defaultZone: http://${eureka.instance.hostname}:${server.port}/eureka/

将服务消费与提供者的配置修改如下

eureka:
  client:
    service-url:
      defaultZone: http://EurekaServer:8761/eureka

重新构建镜像

按上面的构建镜像的步骤,分别生成新的镜像。

编写docker-compose.yml文件

version: '3.8'
services:
  eureka-server:
    image: cloud-framework/eureka:1.0
    container_name: cloud_eureka
    hostname: EurekaServer
    ports:
      - "8761:8761"
    networks:
      - cloudnetwork
  order-server:
    image: cloud-framework/order-service:1.0
    container_name: cloud_order-server
    ports:
      - "8081:8081"
    links:
      - eureka-server:EurekaServer
    networks:
      - cloudnetwork
    depends_on:
      - eureka-server
  order-client:
    image: cloud-framework/order-client-feign:1.0
    container_name: cloud_order-client
    ports:
      - 9001:9001
    links:
      - eureka-server:EurekaServer
    networks:
      - cloudnetwork
    depends_on:
      - eureka-server

networks:
  cloudnetwork:
    driver: bridge

以上都是一些常规的配置,包括服务的名称,所用的镜像,容器的名称,端口的映射,使用的网络,其中depends_on配置的意思是,本服务需要依赖eureka-server,还有需要注意的一点是:由于docker默认的网络模式bridge,所以需要修改eureka-server服务的配置

# 将hostname由变为localhost EurekaServer
eureka:
  # 设置Eureka的hostname
  instance:
    hostname: EurekaServer
  # 设置不检索其他服务
  client:
    fetch-registry: false
  # 不注册自己
    register-with-eureka: false
  # 服务注册地址
    service-url:
      defaultZone: http://EurekaServer:${server.port}/eureka/

同样的order-serviceorder-client-feign服务的配置也需要修改为如下配置:

eureka:
  client:
    service-url:
      defaultZone: http://EurekaServer:8761/eureka

启动Compose

进入到docker-compose.yml文件所在目录执行如下命令,然后浏览器输入http://localhost:8761/

docker-compose up

看到如下画面,说明我们利用docker-composeSpringCloud服务编排成功了

验证

我们执行如下命令进入到order-client-feign容器内部

# 首先执行,找到服务运行的容器
docker ps
#然后执行下面命令,进入到容器
docker exec -it af01ed522b98  /bin/bash 
# 然后访问服务提供者的接口
curl -v http://localhost:9001/query

出现如下结果,表示在容器内部我们也能够访问到接口,并成功返回结果

小结

好啦,小伙伴们,本文我们讨论了,如何将自己的SpringCloud微服务,使用Dockerfile进行服务构建,并使用docker-compose进行服务编排,并成功编排完成。相关代码案例以上传到 GitHub,当然,作者只是编排了三个服务,小伙伴们可以自行拉取代码,将其他的服务一并进行编排试验。

Docker-compose实战的更多相关文章

  1. Docker深入浅出系列 | Docker Compose多容器实战

    目录 前期准备 Docker Compose是什么 为什么要用Docker Compose Docker Compose使用场景 Docker Compose安装 Compose Yaml文件结构 C ...

  2. Istio入门实战与架构原理——使用Docker Compose搭建Service Mesh

    本文将介绍如何使用Docker Compose搭建Istio.Istio号称支持多种平台(不仅仅Kubernetes).然而,官网上非基于Kubernetes的教程仿佛不是亲儿子,写得非常随便,不仅缺 ...

  3. 010.Docker Compose构建WordPress实战

    一 前期规划 类型 版本 备注 WordPress镜像 wordpress:latest   MySQL数据库 5.7   Docker已安装,参考<002.Docker版本及安装>. D ...

  4. 029.Docker Compose部署Zabbix实战

    一 前期规划 1.1 Zabbix架构图 1.2 其他规划 组件 类型 版本 备注 Zabbix Web zabbix-web-apache-mysql镜像 wordpress:latest 也可采用 ...

  5. kubernetes 实战6_命令_Share Process Namespace between Containers in a Pod&Translate a Docker Compose File to Kubernetes Resources

    Share Process Namespace between Containers in a Pod how to configure process namespace sharing for a ...

  6. Docker小白到实战之Docker Compose在手,一键足矣

    前言 Docker可以将应用程序及环境很方便的以容器的形式启动,但当应用程序依赖的服务比较多,或是遇到一个大系统拆分的服务很多时,如果还一个一个的根据镜像启动容器,那就有点累人了,到这有很多小伙伴会说 ...

  7. Docker入门(三)使用Docker Compose

    Compose介绍   Compose 项目是 Docker 官方的开源项目,负责实现对 Docker 容器集群的快速编排.Compose 是一个用户定义和运行多个容器的 Docker 应用程序.在 ...

  8. 【08】循序渐进学 docker:docker compose

    写在前面的话 在之前的操作中,即使是单个容器每次都需要敲很长的命令,当需要多个容器组合着用的时候更加麻烦,此时我们急需找到一种一次配置,随便运行的方法. 这就是这一节重点,单机容器编排工具:docke ...

  9. Docker Compose 部署 Redis 及原理讲解 | 懒人屋

    原文:Docker Compose 部署 Redis 及原理讲解 | 懒人屋 Docker Compose 部署 Redis 及原理讲解  4.4k  字    16  分钟    2019-10-1 ...

  10. 什么,容器太多操作不过来?我选择Docker Compose梭哈

    接上一篇:面试官:你说你精通 Docker,那你来详细说说 Dockerfile 吧 一.容器之间通信 1.单向通信 1.1.什么意思 mysql和tomcat是两个独立的容器,但是tomcat需要和 ...

随机推荐

  1. python numpy indexerror: too many indices for array

    import numpy as np #data 原来数组 #arr_1 新数组 #将data的第一列赋值给arr_1的第一列 arr_1 = np.array((data.shape[0],5)) ...

  2. redis(十):Redis 列表(List)

    Redis 列表(List) Redis列表是简单的字符串列表,按照插入顺序排序.你可以添加一个元素到列表的头部(左边)或者尾部(右边) 一个列表最多可以包含 232 - 1 个元素 (4294967 ...

  3. 09-Python异常

    一.简介 在实际的工作过程中,我们会遇到各种问题,比如文件不存在,代码运行不符合某些特定逻辑等,程序在运行时,遇到这些问题便会发生异常.英文是Exception. a = float(input('请 ...

  4. 在Java中使用AES加密

    本文转载https://blog.csdn.net/z69183787/article/details/82746686

  5. Python2爬取学生名单

    背景: 学校的网站可以根据学号查学生姓名和成绩(三年后的补充:借助sql注入漏洞跳过密码,但是该网站现在已经被弃用了),所以我希望通过Python的爬虫得到年级所有同学的学号与姓名对应表. 实现: 首 ...

  6. Ethical Hacking - NETWORK PENETRATION TESTING(10)

    WPA Craking WPA was designed to address the issues in WEP and provide better encryption. The main is ...

  7. oracle 在物理机上添加磁盘操作

    物理机上添加磁盘操作 注意:1)物理机上添加磁盘操作,不涉及到start_udev的动作.2)磁盘分区的操作,需要谨慎进行,核准无误后再操作. (1)查看磁盘名称命名 # su - grid$ sql ...

  8. DirectX11 With Windows SDK--35 粒子系统

    前言 在这一章中,我们主要关注的是如何模拟一系列粒子,并控制它们运动.这些粒子的行为都是类似的,但它们也带有一定的随机性.这一堆粒子的几何我们叫它为粒子系统,它可以被用于模拟一些比较现象,如:火焰.雨 ...

  9. Docker 概念-2

    Docker 是什么? 说了这么多, Docker 到底是个什么东西呢?我们在理解 Docker 之前,首先得先区分清楚两个概念,容器和虚拟机. 可能很多读者朋友都用过虚拟机,而对容器这个概念比较的陌 ...

  10. ICPC North Central NA Contest 2018

    目录 ICPC North Central NA Contest 2018 1. 题目分析 2. 题解 A.Pokegene B.Maximum Subarrays C.Rational Ratio ...